All Downloads are FREE. Search and download functionalities are using the official Maven repository.

nablarch.integration.workflow.WorkflowManager Maven / Gradle / Ivy

package nablarch.integration.workflow;

import java.util.Map;

/**
 * ワークフローの管理を行うクラス。
 *
 * @author Ryo Tanaka
 * @since 1.4.2
 */
public final class WorkflowManager {

    /**
     * 指定されたワークフローIDのワークフローを開始する。
     *
     * @param workflowId 新規に開始するワークフローのワークフローID
     * @return 開始されたワークフローのインスタンスをあらわす {@link WorkflowInstance}
     * @throws IllegalArgumentException 指定されたワークフローIDに対応するワークフロー定義が存在しない場合。
     */
    public static WorkflowInstance startInstance(String workflowId) throws IllegalArgumentException {
        return getWorkflowInstanceFactory().start(workflowId);
    }

    /**
     * 指定されたワークフローIDのワークフローを開始する。
     *
     * @param workflowId 新規に開始するワークフローのワークフローID
     * @param parameter 開始イベントから、次のタスクまでワークフローを進行させる際に、各フローノードで使用するパラメータ
     * @return 開始されたワークフローのインスタンスをあらわす {@link WorkflowInstance}
     * @throws IllegalArgumentException 指定されたワークフローIDに対応するワークフロー定義が存在しない場合。
     */
    public static WorkflowInstance startInstance(String workflowId, Map parameter) throws IllegalArgumentException {
        return getWorkflowInstanceFactory().start(workflowId, parameter);
    }

    /**
     * すでに開始されているワークフローのインスタンスを取得する。
     *
     * @param instanceId 取得するワークフローインスタンスのインスタンスID
     * @return 取得されたワークフローインスタンス
     */
    public static WorkflowInstance findInstance(String instanceId) {
        return getWorkflowInstanceFactory().find(instanceId);
    }

    /**
     * 指定されたワークフローIDのワークフロー定義で、現在有効なバージョンを取得する。
     *
     * @param workflowId ワークフローID
     * @return 現在有効なバージョン
     * @throws IllegalArgumentException 指定されたワークフローIDが存在しない場合。
     */
    public static int getCurrentVersion(String workflowId) throws IllegalArgumentException {
        return WorkflowConfig.get().getWorkflowDefinitionHolder().getWorkflowDefinition(workflowId).getVersion();
    }

    /**
     * ワークフローインスタンスのファクトリクラスを取得する。
     *
     * @return ワークフローインスタンスのファクトリクラス
     */
    private static WorkflowInstanceFactory getWorkflowInstanceFactory() {
        return WorkflowConfig.get().getWorkflowInstanceFactory();
    }

    /**
     * 隠蔽コンストラクタ
     */
    private WorkflowManager() {
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy