Enterprises collect data from hundreds and thousands of forms, various back-end systems, and online or offline data sources. They also have a dynamic set of users to take decisions on the data, which involves iterative review and approval processes.
Along with review and approval workflows for internal and external audiences, large organizations and businesses have repetitive tasks. For example, converting a PDF document to another format. When done manually, these tasks take up much time and resources. Enterprises also have legal requirements to digitally sign a document and archive form data for later use in pre-defined formats.
You can use AEM Workflows to rapidly build adaptive forms-based workflows. These workflows can be used for review and approvals, business process flows, to start document services, integrate with Adobe Sign signature workflow, and similar operations. For example, credit card application processing, employee leave approval workflows, saving a form as a PDF document. Moreover, these workflows can be used within an organization or across network firewall.
With Forms-centric workflow on OSGi, you can rapidly build and deploy workflows for various tasks on the OSGi stack, without having to install the full-fledged Process Management capability on JEE stack. The development and management of workflows uses the familiar AEM Workflow and AEM Inbox capabilities. Workflows form the basis of automating real-world business processes that span multiple software systems, networks, departments, and even organizations.
Once set up, these workflows can be triggered manually to complete a defined process or run programmatically when users submit a form or correspondence management letter. With this enhanced AEM Workflow capabilities, AEM Forms offers two distinct, yet similar, capabilities. As part of your deployment strategy, you need to decide which one works for you. See a comparison of the Forms-centric AEM Workflows on OSGi and Process Management on JEE. Moreover, for the deployment topology see, Architecture and deployment topologies for AEM Forms.
Forms-centric workflow on OSGi extends AEM Inbox and provides extra components (steps) for AEM Workflow editor to add support for AEM Forms-centric workflows. The extended AEM Inbox has functionalities similar to AEM Forms Workspace. Along with managing human-centric workflows (Approval, Review, and so on), you can use AEM workflows to automate document services-related operations (for example, Generate PDF) and electronically signing (Adobe Sign) documents.
All AEM Forms workflow steps support the use of variables. Variables enable workflow steps to hold and pass metadata across steps at runtime. You can create different types of variables for storing different types of data. You can also create variable collections (array) for storing multiple instances of related, same-typed data. Typically, you use a variable or a collection of variables when you need to make a decision based on the value that it holds or to store information that you need later in a process. For more information on using variables in these Forms-centric workflow components (steps), see Forms-centric workflow on OSGi - Step Reference. For information on creating and managing variables, see Variables in AEM workflows.
The following diagram depicts end-to-end procedure to create, run, and monitor a Forms-centric workflow on OSGi.
A workflow model consists of logic and flow of a business process. It is made up of a series of the steps. These steps are AEM components. You can extend workflow steps with parameters and scripts to provide more functionality and control, as required. AEM Forms provides a few steps in addition to AEM steps available out of the box. For a detailed list of AEM and AEM Forms steps, see AEM Workflow Step Reference and Forms-centric workflow on OSGi - Step Reference.
AEM provides an intuitive user interface to create a workflow model using the provided workflow steps. For step-by-step instructions to create a workflow model, see Creating Workflow Models. The following example provides step-by-step instructions to create a workflow model for an approval and review workflow:
You must be a member of the workflow-editor group to create or edit a workflow model.
Approval and review workflow are for the tasks which require human intervention to make decisions. The following example creates a workflow model for a mortgage loan application to be filled by a front-office banking agent. Once the application is filled, it is sent for approval. Later on, the approved application is sent to the applicant for electronic signatures using Adobe Sign.
The example is available as a package attached below. Import and install the example using the package manager. You can also perform the following steps to manually create the workflow model for the application:
The example creates a workflow model a mortgage application to be filled by a front-office banking agent. Once filled the application is sent for approval. Later on, the approved application is sent to the customer for electronic signatures using Adobe Sign. You can import and install the example using the package manager.
Open the Workflow Models console. The default URL is
Select Create, then Create Model. The Add Workflow Model dialog appears.
Enter the Title and Name (optional). For example, a mortgage application. Tap Done.
Select the newly created workflow model and tap Edit. Now, you can add workflow steps to build business logic. When you first create a workflow model, it contains:
Enable email notifications. You can configure Forms-centric workflow on OSGi to send email notifications to the users or assignees. Perform the following configurations to enable email notifications:
Create workflow stages. A workflow can have multiple stages. These stages are displayed in the AEM Inbox and report progress of the workflow.
To define a stage, tap the icon to open workflow model properties, open the Stages tab, add stages for the workflow model, and tap Save & Close. For the example mortgage application, create stages: loan request, loan request status, to be signed documents, and signed loan document.
Drag-and-drop the Assign Task steps browser to the workflow model. Make it the first step of the model.
The assign task component assigns the task, created by workflow, to a user or group. Along with assigning the task, you can use the component to specify an adaptive form or a non-interactive PDF for the task. The adaptive form is required to accept input from users and non-interactive PDF or a read-only adaptive form is used for review only workflows.
You can also use the step to control the behavior of the task. For example, creating an automatic document of record, assign the task to a specific user or group, the path of the submitted data, the path of data to be pre-populated, and default actions. For detailed information about the options of the assign task step, see Forms-centric workflow on OSGi - Step Reference document.
For the mortgage application example, configure the assign task step to use a Read-only adaptive form and display PDF Document once the task is complete. Also, select to user group allowed to approve the loan request. On the Actions tab, disable the Submit option. Create an actionTaken variable of String data type and specify the variable as the Route Variable. For example, actionTaken. Also, add the Approve and Reject routes. The routes are displayed as separate actions (buttons) in AEM Inbox. The workflow selects a branch based on the action (button) a user taps.
You can import the example package, available for download in the starting of the section, for the complete set of values of all the fields of the assign task step configured for example mortgage application.
Drag-and-drop the OR Split component from step browser to the workflow model. The OR Split creates a split in the workflow, after which only one branch is active. This step enables you to introduce conditional processing paths into your workflow. You add workflow steps to each branch as required.
You can define routing expression for a branch using a rule definition, ECMA script, or an external script.
Use the expression editor to create routing expressions for Branch 1 and Branch 2. These routing expressions help choose a branch based on the user action in AEM Inbox.
Routing expression for Branch 1
When a user taps Approve in AEM Inbox, Branch 1 is activated.
Routing expression for Branch 2
When a user taps Reject in AEM Inbox, Branch 2 is activated.
For information on creating routing expressions using variables, see Variables in AEM Forms workflows.
Add other workflow steps to build the business logic.
For the mortgage example, add a generate document of record, two assign task steps, and a sign document step to Branch 1 of the model, as displayed in the image below. One assign task step is to display and send to be signed loan documents to the applicant and another assign task component is to display signed documents. Also, add an assign task component to branch 2. It is activated, when a user taps Reject in AEM Inbox.
For the complete set of values of all the fields of the assign task steps, document of record step, and sign document step configured for example mortgage application, import the example package, available for download in the starting of this section.
The workflow model is ready. You can launch the workflow through various methods. For details, see Launch a Forms-centric workflow on OSGi.
The application is the adaptive form associated with the workflow. When an application is submitted through Inbox, it launches the associated workflow. To make a Forms workflow available as an application in AEM Inbox and AEM Forms App, do the following to create a workflow application:
You must be a member of the fd-administrator group to be able to create and manage workflow applications.
|Title||The title is visible in AEM Inbox and helps users choose an application. Keep it descriptive. For example, Savings Account Opening Application.
|Name||Specify the name of the application. All the characters other than alphabets, numbers, hyphens, and underscores are replaced with hyphens.|
|Description||The description is visible in AEM Inbox. Provide detailed information about the application in the description fields. For example, Purpose of the application.
Specify the path of an adaptive form. When a user starts an application, the specified adaptive form is displayed.
Note: Workflow applications do not support forms and PDF documents which are longer than one page or require scrolling on Apple iPad. When an application is opened on Apple iPad and the adaptive form or the PDF document is longer than a page, the form fields and content from the second page are lost.
Select a group. The application is visible in AEM Inbox only to the members of the selected group. The access group option makes all the groups of the workflow-users group available for selection.
|Prefill Service||Select a prefill service for the adaptive form.
|Workflow Model||Select a workflow model for the application. A workflow model consists of logic and flow of the business process.|
|Data File Path||Specify the path of the data file in crx-repository. The path is relative to adaptive form payload and contains the name of the data file. Always include the complete name of the file including extension, if applicable. For example, [payload]/data.xml.|
|Attachment Path||Specify the path of attachments folder in crx-repository. The attachment path is relative to payload location. For example, [payload]/data.xml.|
|Document of Record Path||Specify the path of Document of Record file in crx-repository. The path is relative to adaptive form payload location. Always include the complete name of the file including extension, if applicable. For example, [payload]/DOR/creditcard.pdf.|
You can launch or trigger a Forms-centric workflow by:
The workflow application you created is available as an application in Inbox. Users who are members of workflow-users group can fill and submit the application that triggers the associated workflow. For information about using AEM Inbox to submit applications and manage tasks, see Manage Forms applications and tasks in AEM Inbox.
The AEM Forms app syncs with an AEM Forms server and allows you to make changes to the form data, tasks, workflow applications, and saved information (drafts/templates) in your account. For more information, see AEM Forms app and related articles.
You can configure the submit actions of an adaptive form to start a workflow on submission of the adaptive form. Adaptive forms provides the Invoke an AEM Workflow submit action to start a workflow on submission of an adaptive form. For detailed information about the submit action, see Configuring the Submit action. To submit an Adaptive form through the AEM Forms app, enable Sync With AEM Forms App in the adaptive form properties.
You can configure an adaptive form to sync, submit, and trigger a workflow from AEM Forms app. For details, see working with a form.
An administrator (a member of fd-administrators group) can configure a network folder to run a pre-configured workflow when a user places a file (such as a PDF file) in the folder. After the workflow completes, it can save the result file to a specified output folder. Such a folder is known as Watched Folder. Perform the following procedure to configure a watched folder to launch a workflow:
|Name||Specify the name of the Watched Folder. This field support only alphanumeric.|
|Path||Specify the physical location of the Watched Folder. In a clustered environment, use a shared network folder that is accessible from AEM cluster node.|
|Process Files Using||Select the Workflow option.|
|Workflow Model||Select a workflow model.
|Output File Pattern||Specify the directory structure for output files and directories. You can also specify a pattern for output files and directories.|
Tap Advanced. Specify a value for the following field and taps Create. The Watched Folder is configured to launch a workflow. Now, whenever a file is placed in the input directory of the Watched Folder, the specified workflow is triggered.
|Payload Mapper Filter||When you create a watched folder, it creates a folder structure in the crx-repository. The folder structure can serve as a payload to the workflow. You can write a script to map an AEM Workflow to accept inputs from the watched folder structure. An out of the box implementation is available and listed in the Payload Mapper Filter. If you do not have a custom implementation, select the default implementation.|
The Advanced tab contains more fields. Most of these fields contain a default value. To learn about all the fields, see the Create or Configure a watched folder article.
You can associate and execute a Forms-centric workflow on OSGi on submission of an interactive communication or a letter. In correspondence management workflows are used for post processing interactive communications and letters. For example, emailing, printing, faxing, or archiving final letters. For detailed steps, see Post processing of interactive communications and letters.
You can use the Assign Task and Send Email steps of AEM Workflows to send an email. Perform the following steps to specify email servers and other configurations required to send email:
Minimizing the number of workflow instances increases the performance of the workflow engine, so you can regularly purge completed or running workflow instances from the repository. For detailed information see, Regular Purging of Workflow Instances purging of workflow instances.
Any data that is submitted from adaptive forms to Experience Manager workflows can have PII (Personally Identifiable Information) or SPD (Sensitive Personal Data) of your business’ end users. However, it is not mandatory to have your data stored in Adobe Experience Manager JCR repository. You can externalize the storage of end-user data into your managed data storage (for example Azure blob storage) by parameterizing the information into workflow variables.
In an Adobe Experience Manager Forms workflow, data is processed and passed through a series of workflow steps by way of workflow variables. These variables are named properties or key-value pairs that are stored in workflow instances metadata node; for example
/var/workflow/instances/<serverid>/<datebucket>/<uniquenameof model>_<id>/data/metaData. These workflow variables can be externalized into a separate repository other than JCR and then processed by Adobe Experience Manager workflows. Adobe Experience Manager provides API
UserMetaDataPersistenceProvider to store the workflow variables in your managed external storage. To know more about Using workflow variables for customer owned datastores in Adobe Experience Manager, see Administer workflow variables for external datastores.
Adobe provides the following sample to store variables from workflow metadata map to Azure blob storage, by using the API UserMetaDataPersistenceProvider. On the similar lines you can use the sample as a guide to use [UserMetaDataPersistenceProvider] API to externalize the workflow variables in any other data storage external to Adobe Experience Manager and manage the same.
When you store your workflow variables to an external data storage, refer the pointers in the guidelines for workflows external data storage.
To store workflow variables in your managed Azure blob storage:
Run in the project root directory the
mvn clean install command with Maven 3.
To deploy the bundle and the content package to author, run
mvn clean install -PautoInstallPackage.
To deploy only the bundle to the author, run
mvn clean install -PautoInstallBundle.
Initialize the following properties in the externalizer OSGi configuration file in the
ui.config content package:
accountKey="" accountName="" endpointSuffix="" containerName="" protocol=""
The following are the purposes (and examples) of these properties:
accountKey is the secret key to authorize access.
accountName is the azure account where data has to be stored.
endpointSuffix, for example
containerName is the container in the account where the data needs to be stored. The sample assumes the container is existing.
protocol, for example
To configure an AEM Workflow model for an external data storage:
Navigate to Tools > Workflow > Models.
Select a model name and select Edit.
Select the Page Information icon and select Open Properties.
Select Externalize workflow data storage.
Select Save & Close to save the properties.
The following are the guidelines when you are using Adobe Experience Manager workflows and storing data to external data storages (for example Microsoft Azure storage server):
Use variables to store data while defining input and output data files and attachments in workflow model steps. Do not select Relative to Payload and Available at an absolute path options. The Relative to Payload and Available at an absolute path options do not display automatically once you configure an Adobe Experience Manager workflow model for external data storage.
Use variables to store data file and attachments while submitting an adaptive form to an AEM Workflow. Do not select Relative to Payload option while submitting an adaptive form to an Adobe Experience Manager workflow. The Relative to Payload option does not display automatically once you configure an Adobe Experience Manager workflow model for external data storage.
Do not use a custom Adobe Experience Manager workflow step in a workflow model to store data in the CRX DE repository.
When you configure an Adobe Experience Manager workflow model for external data storage, do not create custom columns for Adobe Experience Manager Inbox since the values of the custom columns are not fetched if the work item in the Adobe Experience Manager Inbox belongs to a workflow that is marked for external storage.