/* * JBoss, Home of Professional Open Source * Copyright 2005, JBoss Inc., and individual contributors as indicated * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jbpm.command; import java.util.Iterator; import java.util.Map; import org.jbpm.JbpmContext; import org.jbpm.context.exe.ContextInstance; import org.jbpm.graph.def.ProcessDefinition; import org.jbpm.graph.exe.ProcessInstance; /** * Graph command to start a new process and create a task instance if the start * node has a start task definition. * * The result of this command, if requested, is a {@link Long} value containing * the process instance id. * * @author Jim Rigsbee, Tom Baeyens, Bernd Ruecker */ public class NewProcessInstanceCommand extends AbstractBaseCommand { private static final long serialVersionUID = 1L; private String processDefinitionName = null; private long processDefinitionId = 0; // TODO: This is not clear to me, what for do we need that actorId here? // // Bernd Ruecker // It specifies who is creating this new process instance command // Tom // Baeyens String actorId = null; private Map variables = null; private boolean createStartTask = false; private String key; public NewProcessInstanceCommand() { } public NewProcessInstanceCommand(String processDefinitionName) { this.processDefinitionName = processDefinitionName; } /** * a return the id of the newly created process instance. * * @throws Exception */ public Object execute(JbpmContext jbpmContext) throws Exception { if (actorId != null) { jbpmContext.setActorId(actorId); } ProcessInstance processInstance = null; if (processDefinitionName != null) { processInstance = jbpmContext.newProcessInstance(processDefinitionName); } else { ProcessDefinition processDefinition = jbpmContext.getGraphSession() .loadProcessDefinition(processDefinitionId); processInstance = new ProcessInstance(processDefinition); } if (key != null) { processInstance.setKey(key); } Object result = null; if (createStartTask) { result = processInstance.getTaskMgmtInstance().createStartTaskInstance(); } else { result = processInstance; } if (variables != null) { ContextInstance contextInstance = processInstance.getContextInstance(); Iterator iter = variables.keySet().iterator(); while (iter.hasNext()) { String variableName = (String) iter.next(); contextInstance.setVariable(variableName, variables.get(variableName)); } } jbpmContext.save(processInstance); return result; } public String getActorId() { return actorId; } public void setActorId(String actorId) { this.actorId = actorId; } public long getProcessDefinitionId() { return processDefinitionId; } public void setProcessDefinitionId(long processId) { this.processDefinitionId = processId; } /** * @deprecated use getProcessDefinitionId instead */ public long getProcessId() { return processDefinitionId; } /** * @deprecated use setProcessDefinitionId instead */ public void setProcessId(long processId) { this.processDefinitionId = processId; } /** * @deprecated use getProcessDefinitionName instead */ public String getProcessName() { return processDefinitionName; } /** * @deprecated use setProcessDefinitionName instead */ public void setProcessName(String processName) { this.processDefinitionName = processName; } public boolean isCreateStartTask() { return createStartTask; } public void setCreateStartTask(boolean createStartTask) { this.createStartTask = createStartTask; } public Map getVariables() { return variables; } public String getProcessDefinitionName() { return processDefinitionName; } public void setProcessDefinitionName(String processDefinitionName) { this.processDefinitionName = processDefinitionName; } public void setVariables(Map variables) { this.variables = variables; } public String getKey() { return key; } public void setKey(String key) { this.key = key; } @Override public String getAdditionalToStringInformation() { return "processDefinitionId=" + processDefinitionId + ";processDefinitionName=" + processDefinitionName + ";createStartTask=" + createStartTask + ";businessKey=" + key // TODO: not sure how this is + ";variables=" + variables; } // methods for fluent programming public NewProcessInstanceCommand actorId(String actorId) { setActorId(actorId); return this; } public NewProcessInstanceCommand processDefinitionId(long processId) { setProcessDefinitionId(processId); return this; } public NewProcessInstanceCommand processDefinitionName(String processName) { setProcessDefinitionName(processName); return this; } public NewProcessInstanceCommand createStartTask(boolean createStartTask) { setCreateStartTask(createStartTask); return this; } public NewProcessInstanceCommand variables(Map variables) { setVariables(variables); return this; } public NewProcessInstanceCommand key(String key) { setKey(key); return this; } }