Show Menu
トピック×

カスタム実装用のトランザクションの記録

TransactionRecorder APIを使用して、トランザクションとして計上されないアクションを自動的に記録します
カスタムコードを使用してPDFフォームを送信したり、エージェントUIプレビューURLをエンドユーザーに送信してインタラクティブ通信をプレビューしたり、AEM Formsで提供される送信メソッドを使用する代わりに、カスタムメソッドを使用してフォームを送信したりできます。 AEM Forms APIの前述のすべてのアクションおよびカスタム実装は、トランザクションと見なされません。 AEM Formsには、トランザクションなどのアクシ ョンを記録する API TransactionRecorderが用意されています。
トランザクションを記録するには、標準のスリング サーブレットを書き込み 、クライアントからサーブレットを呼び出してトランザクションを記録します。 サーブレットは、AJAXまたはその他の標準的な方法を使用して呼び出すことができます。

サーバー側コードの例

以下のサンプルコードを使用して、カスタムOSGiバンドルを使用してJAVAクラスからTransactionRecorder APIを実行できます。
import com.adobe.aem.transaction.core.ITransactionRecorder;
import com.adobe.aem.transaction.core.model.TransactionRecord;
import com.adobe.aem.transaction.core.exception.TransactionException;
import com.adobe.aem.transaction.core.FormsTransactionConstants;

@Reference
private ITransactionRecorder transactionRecorder;

doPost (SlingHttpServletRequest request, SlingHttpServletResponse response) {
    transactionRecorder.startContext();
    TransactionRecord txRecord = extractTxRecordFromRequest(request); //extract transaction relevant data from request
    try {
        bool success = doBillableWork();
        if (success) {
            transactionRecorder.recordTransaction(txRecord);
        }
    } catch (Exception e) {
        //exception handling
    } finally {
        transactionRecorder.endContext();
    }
}

//Here, it is assumed that txInfo is passed in Stringified json form in the ajax call (in data parameter). You can pass txInfo from client in any way that you find suitable.
private TransactionRecord extractTxRecordFromRequest(SlingHttpServletRequest request) {
    BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(request.getInputStream()));
    Map<String, Object> txDataMap = new HashMap<String, Object>();
    String txData = bufferedReader.readLine();
    JSONObject txInfo= new JSONObject(txData );
    try {
        String resourceType= txInfo.getString("resourceType");
        String transactionType = txInfo.getString("transactionType");
        Integer transactionCount = (Integer)txInfo.get("transactionCount");
        //Extract all the relevant tx record attributes similarly and pass them in Transaction Record constructor as per the java doc}
        return new TransactionRecord(transactionCount, transactionType, resourceType, ..);
    } catch (JSONException e) {
        //exception handling
    } finally {
        bufferedReader.close();
    }
}

クライアント側コードの例

以下のサンプルコードを使用して、 TransactionRecorder APIを持つサーブレットを呼び出すことができます。
$.ajax({
   type: 'POST',
   url: url, //servlet url
   contentType: 'application/json; UTF-8',
   data: JSON.stringify({transactionCount : 1,
                        transactionType: "SUBMIT",
                        resourceType: "FORM",
                        resourceSubType: "ADAPTIVE-FORM"}),
   success: successHandler,
   error: faultHandler
})