ドラフトおよび送信データサービスのカスタマイズ customizing-draft-and-submission-data-services
概要 overview
AEM Formsを使用すると、アダプティブフォームをドラフトとして保存できます。 ドラフト機能を使用すると、ユーザーは作業中のフォームを維持できます。 その後、ユーザーは任意のデバイスからいつでもフォームに入力して送信できます。
デフォルトでは、AEM Forms はドラフトと送信に関連付けられたユーザーデータを /content/forms/fp
ノードのパブリッシュインスタンスに保存します。
ただし、AEM Formsポータルコンポーネントは、ドラフトと送信用のユーザーデータの保存の実装をカスタマイズできるデータサービスを提供します。 例えば、組織に現在実装されているデータストアにデータを保存することができます。
ユーザーデータのストレージをカスタマイズするには、 下書きデータ および 送信データ サービス。
前提条件 prerequisites
- フォームポータルコンポーネントを有効にする
- フォームポータルページの作成
- フォームポータル用アダプティブフォームを有効にする
- カスタムストレージの実装の詳細を学ぶ
ドラフトデータサービス draft-data-service
ユーザーのドラフトデータのストレージをカスタマイズするには、DraftAFDataService
インターフェイスのすべてのメソッドに対して実装を指定する必要があります。
メソッドとその引数の説明を、次のインターフェイスのコードサンプルに示します。
public interface DraftAFDataService {
/**
* Deletes the user data stored against the ID passed as the argument
*
* @param draftDataID
* @return status for the just occurred delete draft UserData operation
* @throws FormsPortalException
*/
public Boolean deleteAFDraftUserData (String draftDataID) throws FormsPortalException;
/**
* Saves user data provided in the argument map
*
* @param draftUserDataMap contains Form Data (key - "guideState"), Adaptive Form Name (Key - "guideName"), and Draft DataID (Key - "userDataID") in case of update
* @return userData ID would be returned which needs to be saved in metadata node
* @throws FormsPortalException
*/
public String saveAFUserData (Map<String, Object> draftUserDataMap) throws FormsPortalException;
/**
* Gets the user data stored against the ID passed as the argument
*
* @param Draft DataID
* @return guideState (which would then be populated in adaptive form to reload the draft) which is stored against draftDataID
* @throws FormsPortalException
*/
public byte[] getAFDraftUserData(String draftDataID) throws FormsPortalException;
/**
* Saves the attachments for current adaptive form instance
*
* @param attachmentsBytes would expect byte array of the attachment to be saved
* @return id for the attachment just saved (so that it could be retrieved later)
* @throws FormsPortalException
*/
public String saveAttachments(byte[] attachmentBytes) throws FormsPortalException;
}
送信データサービス submission-data-service
ユーザーの送信データのストレージをカスタマイズするには、SubmittedAFDataService
インターフェイスのすべてのメソッドに対して実装を指定する必要があります。
メソッドとその引数の説明を、次のインターフェイスのコードサンプルに示します。
public interface SubmittedAFDataService {
/**
* Submits the user data passed in argument map
*
* @param submittedAFUserdataMap contains Form Data (key - "guideState"), Adaptive Form Name (Key - "guideName"), and Draft DataID (Key - "userDataID")
* @return userData ID is returned that needs to be saved in the metadata node
* @throws FormsPortalException
*/
public String submitAFUserData (Map<String, Object> submittedAFUserdataMap) throws FormsPortalException;
/**
* Gets the user data stored against the ID passed as argument
*
* @param submitDataID
* @return guideState which would be used to open DOR
* @throws FormsPortalException
*/
public byte[] getSubmittedAFUSerData(String submitDataID) throws FormsPortalException;
/**
* Deletes user data stored against the ID passed as argument
*
* @param Submit DataID
* @return status of the delete operation on Submitted User data
* @throws FormsPortalException
*/
public Boolean deleteSubmittedAFUserData(String submitDataID) throws FormsPortalException;
/**
* Submits the attachment bytes passed as argument
*
* @param attachmentsBytes would expect byte array of the attachment to be saved
* @return id for the attachment just saved (so that it could be retrieved later)
* @throws FormsPortalException
*/
public String submitAttachments(Object attachmentBytes) throws FormsPortalException;
}
recommendation-more-help
a6ebf046-2b8b-4543-bd46-42a0d77792da