提交 2168b365 编写于 作者: sq3536's avatar sq3536

工作流事务

上级 8c902863
...@@ -24,7 +24,7 @@ import java.util.Map; ...@@ -24,7 +24,7 @@ import java.util.Map;
@Slf4j @Slf4j
@Component @Component
public class ProcessInstanceListener implements FlowableEventListener { public class ProcessInstanceListener extends AbstractFlowableEventListener {
@Autowired @Autowired
...@@ -43,29 +43,8 @@ public class ProcessInstanceListener implements FlowableEventListener { ...@@ -43,29 +43,8 @@ public class ProcessInstanceListener implements FlowableEventListener {
@Override @Override
public void onEvent(FlowableEvent evt) { public void onEvent(FlowableEvent evt) {
if(evt instanceof FlowableEntityWithVariablesEventImpl)
{
FlowableEntityWithVariablesEventImpl event = (FlowableEntityWithVariablesEventImpl) evt;
if(event.getType() == FlowableEngineEventType.TASK_COMPLETED)
{
TaskEntity taskEntity = (TaskEntity)event.getEntity();
if(taskEntity.getTaskDefinitionKey().startsWith("tid-"))
{
Object data=taskEntity.getVariable("activedata");
Object link=taskEntity.getVariable("sequenceFlowName");
if(data!=null&&(data instanceof Map)&&link!=null) if(evt instanceof FlowableProcessStartedEventImpl)
{
Map activedata=(Map)data;
String srfwfmemo="";
if(activedata.get("srfwfmemo")!=null)
srfwfmemo=activedata.get("srfwfmemo").toString();
taskService.addComment(taskEntity.getId(),taskEntity.getProcessInstanceId(),link.toString(),srfwfmemo);
}
}
}
}
else if(evt instanceof FlowableProcessStartedEventImpl)
{ {
FlowableProcessStartedEventImpl event=(FlowableProcessStartedEventImpl)evt; FlowableProcessStartedEventImpl event=(FlowableProcessStartedEventImpl)evt;
if(event.getEntity() instanceof ExecutionEntityImpl){ if(event.getEntity() instanceof ExecutionEntityImpl){
...@@ -107,7 +86,7 @@ public class ProcessInstanceListener implements FlowableEventListener { ...@@ -107,7 +86,7 @@ public class ProcessInstanceListener implements FlowableEventListener {
executionEntity.setVariable("wfstatefield",wfstatefield); executionEntity.setVariable("wfstatefield",wfstatefield);
executionEntity.setVariable("wfverfield",wfverfield); executionEntity.setVariable("wfverfield",wfverfield);
executionEntity.setVariable("majortextfield",majortext_field); executionEntity.setVariable("majortextfield",majortext_field);
Map callbackArg=new LinkedHashMap(); Map callbackArg=new LinkedHashMap();
if(!StringUtils.isEmpty(wfinstfield)) if(!StringUtils.isEmpty(wfinstfield))
callbackArg.put(wfinstfield,executionEntity.getProcessInstanceId()); callbackArg.put(wfinstfield,executionEntity.getProcessInstanceId());
...@@ -126,7 +105,29 @@ public class ProcessInstanceListener implements FlowableEventListener { ...@@ -126,7 +105,29 @@ public class ProcessInstanceListener implements FlowableEventListener {
} }
} }
} }
else if(evt instanceof FlowableEntityEventImpl) else if(evt instanceof FlowableEntityWithVariablesEventImpl )
{
FlowableEntityWithVariablesEventImpl event = (FlowableEntityWithVariablesEventImpl) evt;
if(event.getType() == FlowableEngineEventType.TASK_COMPLETED)
{
TaskEntity taskEntity = (TaskEntity)event.getEntity();
if(taskEntity.getTaskDefinitionKey().startsWith("tid-"))
{
Object data=taskEntity.getVariable("activedata");
Object link=taskEntity.getVariable("sequenceFlowName");
if(data!=null&&(data instanceof Map)&&link!=null)
{
Map activedata=(Map)data;
String srfwfmemo="";
if(activedata.get("srfwfmemo")!=null)
srfwfmemo=activedata.get("srfwfmemo").toString();
taskService.addComment(taskEntity.getId(),taskEntity.getProcessInstanceId(),link.toString(),srfwfmemo);
}
}
}
}
else if(evt instanceof FlowableEntityEventImpl && evt.getType() != null && FlowableEngineEventType.PROCESS_COMPLETED == evt.getType() )
{ {
FlowableEntityEventImpl event=((FlowableEntityEventImpl) evt); FlowableEntityEventImpl event=((FlowableEntityEventImpl) evt);
FlowableEventType eventType = event.getType(); FlowableEventType eventType = event.getType();
...@@ -157,10 +158,7 @@ public class ProcessInstanceListener implements FlowableEventListener { ...@@ -157,10 +158,7 @@ public class ProcessInstanceListener implements FlowableEventListener {
} }
System.out.println("流程结束"); System.out.println("流程结束");
} }
if(eventType == FlowableEngineEventType.PROCESS_COMPLETED_WITH_ERROR_END_EVENT){
event.getEntity();
System.out.println("流程异常结束");
}
} }
else if(evt instanceof FlowableActivityEventImpl) else if(evt instanceof FlowableActivityEventImpl)
{ {
...@@ -187,20 +185,13 @@ public class ProcessInstanceListener implements FlowableEventListener { ...@@ -187,20 +185,13 @@ public class ProcessInstanceListener implements FlowableEventListener {
} }
} }
} }
@Override @Override
public boolean isFailOnException() { public boolean isFailOnException() {
return false; return true;
} }
@Override
public boolean isFireOnTransactionLifecycleEvent() {
return false;
}
@Override
public String getOnTransaction() {
return null;
}
} }
\ No newline at end of file
...@@ -54,7 +54,10 @@ import org.springframework.stereotype.Service; ...@@ -54,7 +54,10 @@ import org.springframework.stereotype.Service;
import org.springframework.util.CollectionUtils; import org.springframework.util.CollectionUtils;
import org.springframework.util.DigestUtils; import org.springframework.util.DigestUtils;
import org.springframework.util.StringUtils; import org.springframework.util.StringUtils;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;
import javax.servlet.http.HttpServletRequest;
import javax.xml.stream.XMLInputFactory; import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamReader; import javax.xml.stream.XMLStreamReader;
import java.io.*; import java.io.*;
...@@ -104,7 +107,20 @@ public class WFCoreService ...@@ -104,7 +107,20 @@ public class WFCoreService
AuthenticationUser user=AuthenticationUser.getAuthenticationUser(); AuthenticationUser user=AuthenticationUser.getAuthenticationUser();
FlowUser principal=new FlowUser(); FlowUser principal=new FlowUser();
principal.setUser(user); principal.setUser(user);
principal.setToken("Bearer "+jwtTokenUtil.generateToken(user)); String token="";
ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
if(requestAttributes!=null) {
HttpServletRequest request = requestAttributes.getRequest();
Object tk=request.getHeader("Authorization");
if(tk!=null)
token=tk.toString();
}
if(StringUtils.isEmpty(token))
{
token="Bearer "+jwtTokenUtil.generateToken(user);
}
principal.setToken(token);
context.setPrincipal((Principal) principal); context.setPrincipal((Principal) principal);
return context; return context;
} }
......
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册