update - 处理流程已结束后添加评论的逻辑
This commit is contained in:
parent
f8f385055b
commit
86cf230fcc
@ -0,0 +1,170 @@
|
||||
package org.flowable.engine.impl.cmd;
|
||||
|
||||
import org.flowable.common.engine.api.FlowableException;
|
||||
import org.flowable.common.engine.api.FlowableObjectNotFoundException;
|
||||
import org.flowable.common.engine.api.delegate.event.FlowableEngineEventType;
|
||||
import org.flowable.common.engine.api.delegate.event.FlowableEventDispatcher;
|
||||
import org.flowable.common.engine.impl.identity.Authentication;
|
||||
import org.flowable.common.engine.impl.interceptor.Command;
|
||||
import org.flowable.common.engine.impl.interceptor.CommandContext;
|
||||
import org.flowable.common.engine.impl.persistence.entity.ByteArrayEntity;
|
||||
import org.flowable.common.engine.impl.util.IoUtil;
|
||||
import org.flowable.engine.compatibility.Flowable5CompatibilityHandler;
|
||||
import org.flowable.engine.delegate.event.impl.FlowableEventBuilder;
|
||||
import org.flowable.engine.impl.cfg.ProcessEngineConfigurationImpl;
|
||||
import org.flowable.engine.impl.persistence.entity.AttachmentEntity;
|
||||
import org.flowable.engine.impl.persistence.entity.ExecutionEntity;
|
||||
import org.flowable.engine.impl.util.CommandContextUtil;
|
||||
import org.flowable.engine.impl.util.Flowable5Util;
|
||||
import org.flowable.engine.runtime.ProcessInstance;
|
||||
import org.flowable.engine.task.Attachment;
|
||||
import org.flowable.task.api.Task;
|
||||
import org.flowable.task.service.impl.persistence.entity.TaskEntity;
|
||||
|
||||
import java.io.InputStream;
|
||||
|
||||
/**
|
||||
* 覆盖 Flowable 自带的 CreateAttachmentCmd, 由于 Flowable 5 的实现导致异常,需要覆盖
|
||||
*
|
||||
* @author Tom Baeyens
|
||||
* @author Joram Barrez
|
||||
*/
|
||||
public class CreateAttachmentCmd implements Command<Attachment> {
|
||||
|
||||
protected String attachmentType;
|
||||
protected String taskId;
|
||||
protected String processInstanceId;
|
||||
protected String attachmentName;
|
||||
protected String attachmentDescription;
|
||||
protected InputStream content;
|
||||
protected String url;
|
||||
|
||||
public CreateAttachmentCmd(String attachmentType, String taskId, String processInstanceId, String attachmentName,
|
||||
String attachmentDescription, InputStream content, String url) {
|
||||
this.attachmentType = attachmentType;
|
||||
this.taskId = taskId;
|
||||
this.processInstanceId = processInstanceId;
|
||||
this.attachmentName = attachmentName;
|
||||
this.attachmentDescription = attachmentDescription;
|
||||
this.content = content;
|
||||
this.url = url;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Attachment execute(CommandContext commandContext) {
|
||||
|
||||
if (taskId != null) {
|
||||
TaskEntity task = verifyTaskParameters(commandContext);
|
||||
if (task.getProcessDefinitionId() != null && Flowable5Util.isFlowable5ProcessDefinitionId(commandContext,
|
||||
task.getProcessDefinitionId())) {
|
||||
Flowable5CompatibilityHandler compatibilityHandler = Flowable5Util.getFlowable5CompatibilityHandler();
|
||||
return compatibilityHandler.createAttachment(attachmentType, taskId, processInstanceId,
|
||||
attachmentName, attachmentDescription, content, url);
|
||||
}
|
||||
}
|
||||
|
||||
// 覆盖类的处理
|
||||
// if (processInstanceId != null) {
|
||||
// ExecutionEntity execution = verifyExecutionParameters(commandContext);
|
||||
// if (Flowable5Util.isFlowable5ProcessDefinitionId(commandContext, execution
|
||||
// .getProcessDefinitionId())) {
|
||||
// Flowable5CompatibilityHandler compatibilityHandler = Flowable5Util
|
||||
// .getFlowable5CompatibilityHandler();
|
||||
// return compatibilityHandler.createAttachment(attachmentType, taskId, processInstanceId,
|
||||
// attachmentName, attachmentDescription, content, url);
|
||||
// }
|
||||
// }
|
||||
|
||||
ProcessEngineConfigurationImpl processEngineConfiguration =
|
||||
CommandContextUtil.getProcessEngineConfiguration(commandContext);
|
||||
AttachmentEntity attachment = processEngineConfiguration.getAttachmentEntityManager().create();
|
||||
attachment.setName(attachmentName);
|
||||
attachment.setProcessInstanceId(processInstanceId);
|
||||
attachment.setTaskId(taskId);
|
||||
attachment.setDescription(attachmentDescription);
|
||||
attachment.setType(attachmentType);
|
||||
attachment.setUrl(url);
|
||||
attachment.setUserId(Authentication.getAuthenticatedUserId());
|
||||
attachment.setTime(processEngineConfiguration.getClock().getCurrentTime());
|
||||
|
||||
processEngineConfiguration.getAttachmentEntityManager().insert(attachment, false);
|
||||
|
||||
if (content != null) {
|
||||
byte[] bytes = IoUtil.readInputStream(content, attachmentName);
|
||||
ByteArrayEntity byteArray = processEngineConfiguration.getByteArrayEntityManager().create();
|
||||
byteArray.setBytes(bytes);
|
||||
processEngineConfiguration.getByteArrayEntityManager().insert(byteArray);
|
||||
attachment.setContentId(byteArray.getId());
|
||||
attachment.setContent(byteArray);
|
||||
}
|
||||
|
||||
ExecutionEntity processInstance = null;
|
||||
if (processInstanceId != null) {
|
||||
processInstance = processEngineConfiguration.getExecutionEntityManager().findById(processInstanceId);
|
||||
}
|
||||
|
||||
TaskEntity task = null;
|
||||
if (taskId != null) {
|
||||
task = processEngineConfiguration.getTaskServiceConfiguration().getTaskService().getTask(taskId);
|
||||
}
|
||||
|
||||
processEngineConfiguration.getHistoryManager().createAttachmentComment(task, processInstance, attachmentName,
|
||||
true);
|
||||
|
||||
FlowableEventDispatcher eventDispatcher = processEngineConfiguration.getEventDispatcher();
|
||||
if (eventDispatcher != null && eventDispatcher.isEnabled()) {
|
||||
// Forced to fetch the process-instance to associate the right
|
||||
// process definition
|
||||
String processDefinitionId = null;
|
||||
if (attachment.getProcessInstanceId() != null) {
|
||||
ExecutionEntity process =
|
||||
processEngineConfiguration.getExecutionEntityManager().findById(processInstanceId);
|
||||
if (process != null) {
|
||||
processDefinitionId = process.getProcessDefinitionId();
|
||||
}
|
||||
}
|
||||
|
||||
eventDispatcher.dispatchEvent(FlowableEventBuilder.createEntityEvent(FlowableEngineEventType.ENTITY_CREATED, attachment,
|
||||
processInstanceId, processInstanceId, processDefinitionId),
|
||||
processEngineConfiguration.getEngineCfgKey());
|
||||
eventDispatcher.dispatchEvent(FlowableEventBuilder.createEntityEvent(FlowableEngineEventType.ENTITY_INITIALIZED, attachment,
|
||||
processInstanceId, processInstanceId, processDefinitionId),
|
||||
processEngineConfiguration.getEngineCfgKey());
|
||||
}
|
||||
|
||||
return attachment;
|
||||
}
|
||||
|
||||
protected TaskEntity verifyTaskParameters(CommandContext commandContext) {
|
||||
ProcessEngineConfigurationImpl processEngineConfiguration =
|
||||
CommandContextUtil.getProcessEngineConfiguration(commandContext);
|
||||
TaskEntity task = processEngineConfiguration.getTaskServiceConfiguration().getTaskService().getTask(taskId);
|
||||
|
||||
if (task == null) {
|
||||
throw new FlowableObjectNotFoundException("Cannot find task with id " + taskId, Task.class);
|
||||
}
|
||||
|
||||
if (task.isSuspended()) {
|
||||
throw new FlowableException("It is not allowed to add an attachment to a suspended task");
|
||||
}
|
||||
|
||||
return task;
|
||||
}
|
||||
|
||||
protected ExecutionEntity verifyExecutionParameters(CommandContext commandContext) {
|
||||
ExecutionEntity execution =
|
||||
CommandContextUtil.getExecutionEntityManager(commandContext).findById(processInstanceId);
|
||||
|
||||
if (execution == null) {
|
||||
throw new FlowableObjectNotFoundException("Process instance " + processInstanceId + " doesn't exist",
|
||||
ProcessInstance.class);
|
||||
}
|
||||
|
||||
if (execution.isSuspended()) {
|
||||
throw new FlowableException("It is not allowed to add an attachment to a suspended process instance");
|
||||
}
|
||||
|
||||
return execution;
|
||||
}
|
||||
|
||||
}
|
||||
Loading…
Reference in New Issue
Block a user