AEM には、ワークフローモデルの作成に使用できるプロセスステップがいくつか用意されています。組み込みステップに含まれていないタスクについては、カスタムのプロセスステップを追加することができます(ワークフローモデルの作成を参照)。
プロセスステップごとに特徴を説明します。
プロセスステップは、Java クラスまたは ECMAScript によって定義されます。
ペイロードは、ワークフローインスタンスの処理対象となるエンティティです。ペイロードは、ワークフローインスタンスが開始されるコンテキストによって暗黙的に選択されます。
例えば、ワークフローが AEM ページ「P 」に適用された場合は、ワークフローが進むたびに「P」がステップからステップに引き渡され、各ステップで必要に応じて「P **」に対して何らかの処理がおこなわれます。
最も多いのは、ペイロードがリポジトリ内の JCR ノード(例えば AEM ページまたはアセット)である場合です。JCRノードのペイロードは、JCRパスまたはJCR識別子(UUID)の文字列として渡されます。 ペイロードがJCRプロパティ(JCRパスとして渡される)、URL、バイナリオブジェクト、または汎用のJavaオブジェクトである場合があります。 ペイロードで動作する個々のプロセスステップは、通常、特定のタイプのペイロードを期待するか、ペイロードのタイプに応じて動作が異なります。 以下に説明する各プロセスに対して、予想されるペイロードタイプ(存在する場合)が説明されます。
一部のワークフロープロセスは引数を受け取ります。引数は、ワークフローステップを設定するときに管理者が指定します。
引数は、ワークフローエディターのプロパティウィンドウの「プロセスの引数」プロパティに単一文字列として入力します。以下に説明する各プロセスに対して、引数文字列の形式を単純なEBNF文法で記述します。 例えば、次のように、引数文字列が1つ以上のカンマ区切りのペアで構成されていることを示します。各ペアは名前(文字列)と値で構成され、重複コロンで区切られています。
args := name '::' value [',' name '::' value]*
name := /* A string */
value := /* A string */
このタイムアウト期間が経過すると、ワークフローステップは動作しなくなります。タイムアウトを適用するワークフロープロセスもありますが、タイムアウトを適用せず、無視するワークフロープロセスもあります。
WorkflowProcess
に渡されたセッションは、ワークフロープロセスサービスのサービスユーザーによって支援されます。このユーザーは、リポジトリのルートに次の権限を持ちます。
jcr:read
rep:write
jcr:versionManagement
jcr:lockManagement
crx:replicate
WorkflowProcess
の実装にその権限セットが十分でない場合は、必要な権限を持つセッションを使用する必要があります。
これをおこなうには、必要な(ただし最小限の)権限のサブセットを持つよう作成されたサービスユーザーを使用する方法が推奨されます。
AEM 6.2 より前のバージョンからアップグレードする場合は、実装の更新が必要になる場合があります。
以前のバージョンでは、管理者セッションが WorkflowProcess
実装に渡されたので、特定の ACL を定義しなくてもリポジトリへのフルアクセスが可能でした。
現在、権限は上述のように定義されています(権限を参照)。実装を更新するために推奨される方法も同様です。
コードの変更を実行できない場合は、短期的な解決方法も後方互換性の目的で利用できます。
Webコンソール(/system/console/configMgr
)を使用して、AdobeGranite Workflow Configuration Serviceを探します
Workflow Process Legacy Mode を有効にします。
これにより、管理者セッションを WorkflowProcess
実装に渡すという古い動作に戻り、再びリポジトリ全体に無制限にアクセスできるようになります。
次のプロセスは、コンテンツに対して何も実行しません。 ワークフロー自体の動作を制御する役割を果たします。
AbsoluteTimeAutoAdvancer
(絶対時刻自動アドバンサー)プロセスは、AutoAdvancer とまったく同じように動作します。例外は、指定された長さの時間が経過した後ではなく、指定された日時にタイムアウトする点です。
com.adobe.granite.workflow.console.timeout.autoadvance.AbsoluteTimeAutoAdvancer
AutoAdvancer
プロセスは、ワークフローを次のステップに自動的に進めます。次に生じる可能性のあるステップが複数ある場合(例えば OR 分岐がある場合)、このプロセスは、デフォルトのルートが指定されているときはそのルートに沿ってワークフローを進め、指定されていないときはワークフローを進めません**。
Java クラス: com.adobe.granite.workflow.console.timeout.autoadvance.AutoAdvancer
ペイロード:なし
引数:なし
タイムアウト:設定された時間が経過すると、プロセスはタイムアウトします。
ProcessAssembler
プロセスは、単一のワークフローステップ内で複数のサブプロセスを順番に実行します。ProcessAssembler
を使用するには、ワークフロー内にこのタイプのステップを 1 つ作成し、実行するサブプロセスの名前と引数を示す引数を設定します。
Java クラス: com.day.cq.workflow.impl.process.ProcessAssembler
ペイロード:DAM アセット、AEM ページ、ペイロードなしのいずれか(サブプロセスの要件によって異なります)。
引数:
args := arg [',' arg]
arg := processname ['::' processargs]
processname := /* A fully qualified Java Class or absolute
repository path to an ECMAScript */
processargs := processarg [';' processarg]*
processarg := '[' nobracketprocessarg ']' | nobracketprocessarg
nobracketprocessarg := listitem [':' listitem]*
listitem := /* A string */
次に例を示します。
com.day.cq.dam.core.process.ExtractMetadataProcess,
com.day.cq.dam.core.process.CreateThumbnailProcess::[140:100];[48:48];[319:319:false],
com.day.cq.dam.core.process.CreateWebEnabledImageProcess::dimension:1280:1280;mimetype:image/jpeg,
com.day.cq.dam.core.process.AssetSetLastModifiedProcess
以下のプロセスは単純なタスクを実行するか、例として機能します。
/libs
パス内の設定は一切変更しないでください。
これは、次回インスタンスをアップグレードする際に/libs
の内容が上書きされるためです(修正プログラムまたは機能パックを適用すると、上書きされる場合があります)。
指定されたパスにある項目が削除されます。
ECMAScriptパス: /libs/workflow/scripts/delete.ecma
ペイロード:JCRパス
引数:なし
タイムアウト:無視
これはヌルプロセスです。処理は実行しませんが、デバッグメッセージをログに記録します。
ECMAScriptパス: /libs/workflow/scripts/noop.ecma
ペイロード:なし
引数:なし
タイムアウト:無視
これは、check()
メソッドでfalse
を返すnullプロセスです。
ECMAScriptパス: /libs/workflow/scripts/rule-false.ecma
ペイロード:なし
引数:なし
タイムアウト:無視
これは、ECMAScript プロセスのサンプルです。
ECMAScriptパス: /libs/workflow/scripts/sample.ecma
ペイロード:なし
引数:なし
タイムアウト:無視
これは、指定されたURLを呼び出す簡単なワークフロープロセスです。 通常、URLは、単純なタスクを実行するJSP(または他のサーブレットに相当する)への参照です。 このプロセスは開発およびデモンストレーションのときにのみ使用し、実稼動環境では使用しないようにする必要があります。引数は、URL、ログイン、パスワードを指定します。
ECMAScriptパス: /libs/workflow/scripts/urlcaller.ecma
ペイロード:なし
引数:
args := url [',' login ',' password]
url := /* The URL to be called */
login := /* The login to access the URL */
password := /* The password to access the URL */
例:http://localhost:4502/my.jsp, mylogin, mypassword
ワークフローのペイロードをロックします。
Java クラス: com.day.cq.workflow.impl.process.LockProcess
ペイロード: JCR_PATHおよびJCR_UUID
引数:なし
タイムアウト:無視されます。
次の状況下では、このステップは無効です。
ワークフローのペイロードをロック解除します。
Java クラス: com.day.cq.workflow.impl.process.UnlockProcess
ペイロード: JCR_PATHおよびJCR_UUID
引数:なし
タイムアウト:無視されます。
次の状況下では、このステップは無効です。
以下のプロセスは、バージョン関連のタスクを実行します。
ワークフローペイロード(AEM ページまたは DAM アセット)の新しいバージョンを作成します。
Java クラス: com.day.cq.wcm.workflow.process.CreateVersionProcess
ペイロード:ページまたはDAMアセットを参照するJCRパスまたはUUID
引数:なし
タイムアウト:尊敬