/*
* 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;
}
}