update 优化 工作流监听器消费切换动态切换租户(mq投递租户丢失)

This commit is contained in:
疯狂的狮子Li
2025-02-19 15:09:33 +08:00
parent 79775a0ac4
commit f1f6e04a67

View File

@@ -15,6 +15,7 @@ import org.dromara.common.core.utils.StringUtils;
import org.dromara.common.mybatis.core.domain.BaseEntity; import org.dromara.common.mybatis.core.domain.BaseEntity;
import org.dromara.common.mybatis.core.page.PageQuery; import org.dromara.common.mybatis.core.page.PageQuery;
import org.dromara.common.mybatis.core.page.TableDataInfo; import org.dromara.common.mybatis.core.page.TableDataInfo;
import org.dromara.common.tenant.helper.TenantHelper;
import org.dromara.workflow.api.event.ProcessCreateTaskEvent; import org.dromara.workflow.api.event.ProcessCreateTaskEvent;
import org.dromara.workflow.api.event.ProcessDeleteEvent; import org.dromara.workflow.api.event.ProcessDeleteEvent;
import org.dromara.workflow.api.event.ProcessEvent; import org.dromara.workflow.api.event.ProcessEvent;
@@ -131,23 +132,25 @@ public class TestLeaveServiceImpl implements ITestLeaveService {
*/ */
@EventListener(condition = "#processEvent.flowCode.startsWith('leave')") @EventListener(condition = "#processEvent.flowCode.startsWith('leave')")
public void processHandler(ProcessEvent processEvent) { public void processHandler(ProcessEvent processEvent) {
log.info("当前任务执行了{}", processEvent.toString()); TenantHelper.dynamic(processEvent.getTenantId(), () -> {
TestLeave testLeave = baseMapper.selectById(Long.valueOf(processEvent.getBusinessId())); log.info("当前任务执行了{}", processEvent.toString());
testLeave.setStatus(processEvent.getStatus()); TestLeave testLeave = baseMapper.selectById(Long.valueOf(processEvent.getBusinessId()));
// 用于例如审批附件 审批意见等 存储到业务表内 自行根据业务实现存储流程 testLeave.setStatus(processEvent.getStatus());
Map<String, Object> params = processEvent.getParams(); // 用于例如审批附件 审批意见等 存储到业务表内 自行根据业务实现存储流程
if (MapUtil.isNotEmpty(params)) { Map<String, Object> params = processEvent.getParams();
// 历史任务扩展(通常为附件) if (MapUtil.isNotEmpty(params)) {
String hisTaskExt = Convert.toStr(params.get("hisTaskExt")); // 历史任务扩展(通常为附件)
// 办理人 String hisTaskExt = Convert.toStr(params.get("hisTaskExt"));
String handler = Convert.toStr(params.get("handler")); // 办理人
// 办理意见 String handler = Convert.toStr(params.get("handler"));
String message = Convert.toStr(params.get("message")); // 办理意见
} String message = Convert.toStr(params.get("message"));
if (processEvent.isSubmit()) { }
testLeave.setStatus(BusinessStatusEnum.WAITING.getStatus()); if (processEvent.isSubmit()) {
} testLeave.setStatus(BusinessStatusEnum.WAITING.getStatus());
baseMapper.updateById(testLeave); }
baseMapper.updateById(testLeave);
});
} }
/** /**
@@ -162,10 +165,12 @@ public class TestLeaveServiceImpl implements ITestLeaveService {
*/ */
@EventListener(condition = "#processCreateTaskEvent.flowCode.startsWith('leave')") @EventListener(condition = "#processCreateTaskEvent.flowCode.startsWith('leave')")
public void processCreateTaskHandler(ProcessCreateTaskEvent processCreateTaskEvent) { public void processCreateTaskHandler(ProcessCreateTaskEvent processCreateTaskEvent) {
log.info("当前任务创建了{}", processCreateTaskEvent.toString()); TenantHelper.dynamic(processCreateTaskEvent.getTenantId(), () -> {
TestLeave testLeave = baseMapper.selectById(Long.valueOf(processCreateTaskEvent.getBusinessId())); log.info("当前任务创建了{}", processCreateTaskEvent.toString());
testLeave.setStatus(BusinessStatusEnum.WAITING.getStatus()); TestLeave testLeave = baseMapper.selectById(Long.valueOf(processCreateTaskEvent.getBusinessId()));
baseMapper.updateById(testLeave); testLeave.setStatus(BusinessStatusEnum.WAITING.getStatus());
baseMapper.updateById(testLeave);
});
} }
/** /**
@@ -177,12 +182,14 @@ public class TestLeaveServiceImpl implements ITestLeaveService {
*/ */
@EventListener(condition = "#processDeleteEvent.flowCode.startsWith('leave')") @EventListener(condition = "#processDeleteEvent.flowCode.startsWith('leave')")
public void processDeleteHandler(ProcessDeleteEvent processDeleteEvent) { public void processDeleteHandler(ProcessDeleteEvent processDeleteEvent) {
log.info("监听删除流程事件,当前任务执行了{}", processDeleteEvent.toString()); TenantHelper.dynamic(processDeleteEvent.getTenantId(), () -> {
TestLeave testLeave = baseMapper.selectById(Long.valueOf(processDeleteEvent.getBusinessId())); log.info("监听删除流程事件,当前任务执行了{}", processDeleteEvent.toString());
if (ObjectUtil.isNull(testLeave)) { TestLeave testLeave = baseMapper.selectById(Long.valueOf(processDeleteEvent.getBusinessId()));
return; if (ObjectUtil.isNull(testLeave)) {
} return;
baseMapper.deleteById(testLeave.getId()); }
baseMapper.deleteById(testLeave.getId());
});
} }
} }