# Conflicts: # hz-pm-api/src/main/resources/application-dev.yml # hz-pm-api/src/main/resources/application-prod.yml # hz-pm-api/src/test/resources/application-dev.ymltags/24090101
@@ -12,6 +12,18 @@ | |||||
<dependencies> | <dependencies> | ||||
<dependency> | <dependency> | ||||
<groupId>org.openjdk.jmh</groupId> | |||||
<artifactId>jmh-core</artifactId> | |||||
<version>1.37</version> | |||||
<scope>test</scope> | |||||
</dependency> | |||||
<dependency> | |||||
<groupId>org.openjdk.jmh</groupId> | |||||
<artifactId>jmh-generator-annprocess</artifactId> | |||||
<version>1.37</version> | |||||
<scope>test</scope> | |||||
</dependency> | |||||
<dependency> | |||||
<groupId>com.google.guava</groupId> | <groupId>com.google.guava</groupId> | ||||
<artifactId>guava</artifactId> | <artifactId>guava</artifactId> | ||||
<version>33.0.0-jre</version> | <version>33.0.0-jre</version> | ||||
@@ -17,14 +17,12 @@ import org.springframework.http.client.HttpComponentsClientHttpRequestFactory; | |||||
import org.springframework.http.converter.HttpMessageConverter; | import org.springframework.http.converter.HttpMessageConverter; | ||||
import org.springframework.http.converter.StringHttpMessageConverter; | import org.springframework.http.converter.StringHttpMessageConverter; | ||||
import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter; | import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter; | ||||
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; | |||||
import org.springframework.web.client.RestTemplate; | import org.springframework.web.client.RestTemplate; | ||||
import java.nio.charset.StandardCharsets; | import java.nio.charset.StandardCharsets; | ||||
import java.util.ArrayList; | import java.util.ArrayList; | ||||
import java.util.Arrays; | import java.util.Arrays; | ||||
import java.util.List; | import java.util.List; | ||||
import java.util.concurrent.ThreadPoolExecutor; | |||||
import java.util.concurrent.TimeUnit; | import java.util.concurrent.TimeUnit; | ||||
/** | /** | ||||
@@ -55,7 +53,7 @@ public class BeanConfig { | |||||
converterList.remove(converterTarget); | converterList.remove(converterTarget); | ||||
} | } | ||||
HttpMessageConverter<?> converter = new StringHttpMessageConverter(StandardCharsets.UTF_8); | HttpMessageConverter<?> converter = new StringHttpMessageConverter(StandardCharsets.UTF_8); | ||||
converterList.add(1,converter); | |||||
converterList.add(1, converter); | |||||
MappingJackson2HttpMessageConverter mappingJackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter(); | MappingJackson2HttpMessageConverter mappingJackson2HttpMessageConverter = new MappingJackson2HttpMessageConverter(); | ||||
mappingJackson2HttpMessageConverter.setSupportedMediaTypes(Arrays.asList( | mappingJackson2HttpMessageConverter.setSupportedMediaTypes(Arrays.asList( | ||||
@@ -4,8 +4,8 @@ import cn.hutool.core.date.StopWatch; | |||||
import cn.hutool.core.util.RandomUtil; | import cn.hutool.core.util.RandomUtil; | ||||
import cn.hutool.system.oshi.OshiUtil; | import cn.hutool.system.oshi.OshiUtil; | ||||
import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnExpression; | |||||
import org.springframework.context.annotation.Configuration; | import org.springframework.context.annotation.Configuration; | ||||
import org.springframework.context.annotation.Profile; | |||||
import org.springframework.lang.NonNull; | import org.springframework.lang.NonNull; | ||||
import org.springframework.scheduling.annotation.Scheduled; | import org.springframework.scheduling.annotation.Scheduled; | ||||
@@ -25,16 +25,21 @@ import java.util.stream.Stream; | |||||
* @since 20:30 2024/3/5 | * @since 20:30 2024/3/5 | ||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Profile("prod") | |||||
@Configuration | @Configuration | ||||
@ConditionalOnExpression("${cpu-load-task.open:false}") | |||||
public class CpuLoadTask { | public class CpuLoadTask { | ||||
private static final int LIMIT_COUNT = 2000000000; | |||||
private final AtomicInteger taskNo = new AtomicInteger(0); | |||||
public CpuLoadTask() { | |||||
CpuLoadThreadFactory threadFactory = new CpuLoadThreadFactory(Thread.MIN_PRIORITY); | |||||
fixedThreadPool = Executors.newFixedThreadPool(1, threadFactory); | |||||
} | |||||
private final ExecutorService fixedThreadPool; | |||||
private static final Integer CPU_LIMIT = 20; | private static final Integer CPU_LIMIT = 20; | ||||
private static final int LIMIT_COUNT = 1000000000; | |||||
private final AtomicInteger taskNo = new AtomicInteger(0); | |||||
private static final ExecutorService FIXED_THREAD_POOL; | |||||
private static class CpuLoadThreadFactory implements ThreadFactory { | private static class CpuLoadThreadFactory implements ThreadFactory { | ||||
@@ -53,13 +58,6 @@ public class CpuLoadTask { | |||||
} | } | ||||
static { | |||||
int logicalProcessorCount = OshiUtil.getProcessor().getLogicalProcessorCount(); | |||||
int max = Math.max(logicalProcessorCount * CPU_LIMIT / 100, 1); | |||||
CpuLoadThreadFactory threadFactory = new CpuLoadThreadFactory(Thread.MIN_PRIORITY); | |||||
FIXED_THREAD_POOL = Executors.newFixedThreadPool(max, threadFactory); | |||||
} | |||||
@Scheduled(fixedRate = 1, timeUnit = TimeUnit.MINUTES) | @Scheduled(fixedRate = 1, timeUnit = TimeUnit.MINUTES) | ||||
public void run() { | public void run() { | ||||
@@ -67,7 +65,7 @@ public class CpuLoadTask { | |||||
log.info("当前CPU使用率:{}", cpuUsage); | log.info("当前CPU使用率:{}", cpuUsage); | ||||
if (cpuUsage < CPU_LIMIT) { | if (cpuUsage < CPU_LIMIT) { | ||||
log.info("提交计算任务:{}", taskNo.incrementAndGet()); | log.info("提交计算任务:{}", taskNo.incrementAndGet()); | ||||
FIXED_THREAD_POOL.execute(() -> { | |||||
fixedThreadPool.execute(() -> { | |||||
StopWatch watch = new StopWatch(); | StopWatch watch = new StopWatch(); | ||||
watch.start(); | watch.start(); | ||||
long sum = Stream.generate(() -> RandomUtil.randomLong(1, LIMIT_COUNT)) | long sum = Stream.generate(() -> RandomUtil.randomLong(1, LIMIT_COUNT)) | ||||
@@ -6,11 +6,14 @@ import com.baomidou.mybatisplus.core.toolkit.StringUtils; | |||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||
import com.hz.pm.api.common.helper.UserInfoHelper; | import com.hz.pm.api.common.helper.UserInfoHelper; | ||||
import com.hz.pm.api.common.model.constant.BizConst; | import com.hz.pm.api.common.model.constant.BizConst; | ||||
import com.hz.pm.api.common.model.constant.MhUnitConst; | |||||
import com.hz.pm.api.common.util.StrUtils; | import com.hz.pm.api.common.util.StrUtils; | ||||
import com.hz.pm.api.sys.mapper.RoleMapper; | import com.hz.pm.api.sys.mapper.RoleMapper; | ||||
import com.hz.pm.api.sys.model.entity.Role; | import com.hz.pm.api.sys.model.entity.Role; | ||||
import com.hz.pm.api.sys.model.entity.UserRole; | import com.hz.pm.api.sys.model.entity.UserRole; | ||||
import com.hz.pm.api.sys.service.IUserRoleService; | import com.hz.pm.api.sys.service.IUserRoleService; | ||||
import com.hz.pm.api.user.helper.MhUnitCache; | |||||
import com.hz.pm.api.user.model.dto.UnitDTO; | |||||
import com.hz.pm.api.user.model.entity.UserInfo; | import com.hz.pm.api.user.model.entity.UserInfo; | ||||
import com.hz.pm.api.user.model.enumeration.RoleEnum; | import com.hz.pm.api.user.model.enumeration.RoleEnum; | ||||
import com.hz.pm.api.user.model.enumeration.UserAvailableEnum; | import com.hz.pm.api.user.model.enumeration.UserAvailableEnum; | ||||
@@ -38,6 +41,7 @@ public class UserInfoHelperImpl implements UserInfoHelper { | |||||
private final IUserInfoService userInfoService; | private final IUserInfoService userInfoService; | ||||
private final IUserRoleService iUserRoleService; | private final IUserRoleService iUserRoleService; | ||||
private final RoleMapper roleMapper; | private final RoleMapper roleMapper; | ||||
private final MhUnitCache mhUnitCache; | |||||
@Override | @Override | ||||
public UserFullInfoDTO getUserFullInfoByMhUserIdOrOpenId(String mhUserId) { | public UserFullInfoDTO getUserFullInfoByMhUserIdOrOpenId(String mhUserId) { | ||||
@@ -73,6 +77,28 @@ public class UserInfoHelperImpl implements UserInfoHelper { | |||||
.collect(Collectors.toList()); | .collect(Collectors.toList()); | ||||
userFullInfo.setUserRoleList(roleMapper.selectBatchIds(roleIdList)); | userFullInfo.setUserRoleList(roleMapper.selectBatchIds(roleIdList)); | ||||
} | } | ||||
UnitDTO unit = mhUnitCache.getById(userInfo.getMhUnitId()); | |||||
if (unit != null && unit.getType() != null) { | |||||
userFullInfo.setUnitStrip(unit.getType().getStrip().getCode()); | |||||
// 是否市属国有企业下用户 | |||||
List<Long> citySoeUnitIds = mhUnitCache.getViewChildIdsRecursion(MhUnitConst.CITY_SOE_UNIT_ID); | |||||
userFullInfo.setIsCitySoeUser(citySoeUnitIds.contains(userInfo.getMhUnitId())); | |||||
if (!userFullInfo.getIsCitySoeUser()) { | |||||
// 是否关键行业部门下用户 | |||||
List<Long> keyIndustryUnitIds = mhUnitCache.getViewChildIdsRecursion(MhUnitConst.KEY_INDUSTRY_UNIT_ID); | |||||
userFullInfo.setIsKeyIndustryUser(keyIndustryUnitIds.contains(userInfo.getMhUnitId())); | |||||
if (!userFullInfo.getIsKeyIndustryUser()) { | |||||
// 是否区县部门下用户 | |||||
List<Long> countyUnitIds = mhUnitCache.getViewChildIdsRecursion(MhUnitConst.COUNTY_PARENT_UNIT_ID); | |||||
userFullInfo.setIsCountyUser(countyUnitIds.contains(userInfo.getMhUnitId())); | |||||
if (!userFullInfo.getIsCountyUser()) { | |||||
// 是否市本级用户 | |||||
List<Long> cityDistrictUnitIds = mhUnitCache.getViewChildIdsRecursion(MhUnitConst.CITY_DISTRICT_UNIT_ID); | |||||
userFullInfo.setIsCityDistrictUser(cityDistrictUnitIds.contains(userInfo.getMhUnitId())); | |||||
} | |||||
} | |||||
} | |||||
} | |||||
// 装配返回 | // 装配返回 | ||||
userFullInfo.setUserId(userInfo.getId()); | userFullInfo.setUserId(userInfo.getId()); | ||||
@@ -105,7 +131,7 @@ public class UserInfoHelperImpl implements UserInfoHelper { | |||||
return userInfos.stream().map(this::convert).collect(Collectors.toList()); | return userInfos.stream().map(this::convert).collect(Collectors.toList()); | ||||
} | } | ||||
private UserFullInfoDTO convert(UserInfo userInfo){ | |||||
private UserFullInfoDTO convert(UserInfo userInfo) { | |||||
UserFullInfoDTO userFullInfo = new UserFullInfoDTO(); | UserFullInfoDTO userFullInfo = new UserFullInfoDTO(); | ||||
// 装配返回 | // 装配返回 | ||||
userFullInfo.setMhUnitName(userInfo.getMhUnitName()); | userFullInfo.setMhUnitName(userInfo.getMhUnitName()); | ||||
@@ -164,7 +190,7 @@ public class UserInfoHelperImpl implements UserInfoHelper { | |||||
.exists("select 1 from nd_user_role nur where nur.user_id = nd_user_info.id" + | .exists("select 1 from nd_user_role nur where nur.user_id = nd_user_info.id" + | ||||
" and nur.role_id = {0}", role.getId()); | " and nur.role_id = {0}", role.getId()); | ||||
List<UserInfo> userInfos = userInfoService.list(query); | List<UserInfo> userInfos = userInfoService.list(query); | ||||
return CollUtils.convert(userInfos,this::convert); | |||||
return CollUtils.convert(userInfos, this::convert); | |||||
} | } | ||||
@Override | @Override | ||||
@@ -16,6 +16,22 @@ public class MhUnitConst { | |||||
private MhUnitConst() { | private MhUnitConst() { | ||||
} | } | ||||
/** | |||||
* 重点行业 | |||||
*/ | |||||
public static final long KEY_INDUSTRY_UNIT_ID = 6788; | |||||
/** | |||||
* 市级部门 | |||||
*/ | |||||
public static final long CITY_DISTRICT_UNIT_ID = 970; | |||||
/** | |||||
* 市属国有企业 | |||||
*/ | |||||
public static final long CITY_SOE_UNIT_ID = 3269; | |||||
/** | |||||
* 区县部门 | |||||
*/ | |||||
public static final long COUNTY_PARENT_UNIT_ID = 1084; | public static final long COUNTY_PARENT_UNIT_ID = 1084; | ||||
public static final long ROOT_UNIT_ID = 1; | public static final long ROOT_UNIT_ID = 1; | ||||
@@ -3,7 +3,7 @@ package com.hz.pm.api.common.statemachine.builder.impl; | |||||
import com.hz.pm.api.common.statemachine.builder.BaseStateMachineBuilder; | import com.hz.pm.api.common.statemachine.builder.BaseStateMachineBuilder; | ||||
import com.hz.pm.api.common.statemachine.event.ProjectStateChangeEvent; | import com.hz.pm.api.common.statemachine.event.ProjectStateChangeEvent; | ||||
import com.hz.pm.api.common.statemachine.factory.ProjectGuardFactory; | import com.hz.pm.api.common.statemachine.factory.ProjectGuardFactory; | ||||
import com.hz.pm.api.common.statemachine.factory.ProjectGuardFactory.ProjectPurchaseToFirstAcceptGuard; | |||||
import com.hz.pm.api.common.statemachine.factory.ProjectGuardFactory.ProjectPurchaseToAcceptGuard; | |||||
import com.hz.pm.api.projectlib.model.entity.Project; | import com.hz.pm.api.projectlib.model.entity.Project; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.ProjectStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.ProjectStatus; | ||||
import lombok.RequiredArgsConstructor; | import lombok.RequiredArgsConstructor; | ||||
@@ -32,13 +32,15 @@ import java.util.EnumSet; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@EnableStateMachine(name = ProjectStateMachineBuilderImpl.MACHINE_ID) | |||||
@RequiredArgsConstructor | @RequiredArgsConstructor | ||||
@EnableStateMachine(name = ProjectStateMachineBuilderImpl.MACHINE_ID) | |||||
public class ProjectStateMachineBuilderImpl implements BaseStateMachineBuilder<Project, ProjectStateChangeEvent, ProjectStatus> { | public class ProjectStateMachineBuilderImpl implements BaseStateMachineBuilder<Project, ProjectStateChangeEvent, ProjectStatus> { | ||||
public static final String MACHINE_ID = "projectDeclareStateMachine"; | public static final String MACHINE_ID = "projectDeclareStateMachine"; | ||||
private final BeanFactory beanFactory; | private final BeanFactory beanFactory; | ||||
private final ProjectPurchaseToAcceptGuard projectPurchaseToAcceptGuard; | |||||
private final ProjectGuardFactory.ProjectPurchaseToAdaptGuard projectPurchaseToAdaptGuard; | |||||
@Override | @Override | ||||
public StateMachine<ProjectStatus, ProjectStateChangeEvent> build() throws StateMachineException { | public StateMachine<ProjectStatus, ProjectStateChangeEvent> build() throws StateMachineException { | ||||
@@ -149,13 +151,15 @@ public class ProjectStateMachineBuilderImpl implements BaseStateMachineBuilder<P | |||||
.withExternal() | .withExternal() | ||||
.source(ProjectStatus.ON_PURCHASING) | .source(ProjectStatus.ON_PURCHASING) | ||||
.target(ProjectStatus.ON_ADAPTING) | .target(ProjectStatus.ON_ADAPTING) | ||||
.event(ProjectStateChangeEvent.SUBMIT_PURCHASE_CONTRACT_RECORD).and() | |||||
.event(ProjectStateChangeEvent.SUBMIT_PURCHASE_CONTRACT_RECORD) | |||||
.guard(projectPurchaseToAdaptGuard) | |||||
.and() | |||||
// 填写试试计划 -> 待初验 | // 填写试试计划 -> 待初验 | ||||
.withExternal() | .withExternal() | ||||
.source(ProjectStatus.ON_PURCHASING) | .source(ProjectStatus.ON_PURCHASING) | ||||
.target(ProjectStatus.TO_BE_FIRST_INSPECTED) | .target(ProjectStatus.TO_BE_FIRST_INSPECTED) | ||||
.event(ProjectStateChangeEvent.SUBMIT_PURCHASE_CONTRACT_RECORD) | .event(ProjectStateChangeEvent.SUBMIT_PURCHASE_CONTRACT_RECORD) | ||||
.guard(new ProjectPurchaseToFirstAcceptGuard()) | |||||
.guard(projectPurchaseToAcceptGuard) | |||||
.and() | .and() | ||||
// 填写试试计划 -> 待初验 | // 填写试试计划 -> 待初验 | ||||
.withExternal() | .withExternal() | ||||
@@ -3,7 +3,7 @@ package com.hz.pm.api.common.statemachine.builder.impl; | |||||
import cn.hutool.core.collection.ListUtil; | import cn.hutool.core.collection.ListUtil; | ||||
import com.hz.pm.api.common.statemachine.builder.BaseStateMachineBuilder; | import com.hz.pm.api.common.statemachine.builder.BaseStateMachineBuilder; | ||||
import com.hz.pm.api.common.statemachine.event.TenderStateChangeEvent; | import com.hz.pm.api.common.statemachine.event.TenderStateChangeEvent; | ||||
import com.hz.pm.api.common.statemachine.factory.TenderGuardFactory; | |||||
import com.hz.pm.api.common.statemachine.factory.TenderGuardFactory.PurchaseContractRecordToAcceptGuard; | |||||
import com.hz.pm.api.projectdeclared.model.entity.Purchase; | import com.hz.pm.api.projectdeclared.model.entity.Purchase; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.TenderAdaptStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.TenderAdaptStatus; | ||||
@@ -26,6 +26,8 @@ import org.springframework.stereotype.Component; | |||||
import java.util.HashSet; | import java.util.HashSet; | ||||
import java.util.List; | import java.util.List; | ||||
import static com.hz.pm.api.common.statemachine.factory.TenderGuardFactory.PurchaseContractRecordToOperationGuard; | |||||
/** | /** | ||||
* <p> | * <p> | ||||
* 标段状态机 | * 标段状态机 | ||||
@@ -36,13 +38,16 @@ import java.util.List; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@EnableStateMachine(name = TenderStateMachineBuilderImpl.MACHINE_ID) | |||||
@RequiredArgsConstructor | @RequiredArgsConstructor | ||||
@EnableStateMachine(name = TenderStateMachineBuilderImpl.MACHINE_ID) | |||||
public class TenderStateMachineBuilderImpl implements BaseStateMachineBuilder<Purchase, TenderStateChangeEvent, ITenderStatus> { | public class TenderStateMachineBuilderImpl implements BaseStateMachineBuilder<Purchase, TenderStateChangeEvent, ITenderStatus> { | ||||
public static final String MACHINE_ID = "tenderStateMachine"; | public static final String MACHINE_ID = "tenderStateMachine"; | ||||
private final BeanFactory beanFactory; | private final BeanFactory beanFactory; | ||||
private final PurchaseContractRecordToAcceptGuard purchaseContractRecordToAcceptGuard; | |||||
private final PurchaseContractRecordToOperationGuard purchaseContractRecordToOperationGuard; | |||||
@Override | @Override | ||||
public StateMachine<ITenderStatus, TenderStateChangeEvent> build() throws StateMachineException { | public StateMachine<ITenderStatus, TenderStateChangeEvent> build() throws StateMachineException { | ||||
@@ -81,12 +86,13 @@ public class TenderStateMachineBuilderImpl implements BaseStateMachineBuilder<Pu | |||||
.source(TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO) | .source(TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO) | ||||
.target(TenderMainStatus.TO_BE_SUBMIT_OPERATION_PLAN) | .target(TenderMainStatus.TO_BE_SUBMIT_OPERATION_PLAN) | ||||
.event(TenderStateChangeEvent.SUBMIT_PURCHASE_CONSTRUCTION_INFO) | .event(TenderStateChangeEvent.SUBMIT_PURCHASE_CONSTRUCTION_INFO) | ||||
.guard(purchaseContractRecordToOperationGuard) | |||||
.and() | .and() | ||||
.withExternal() | .withExternal() | ||||
.source(TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO) | .source(TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO) | ||||
.target(TenderMainStatus.TO_BE_SUBMIT_FIRST_INSPECTED_INFO) | .target(TenderMainStatus.TO_BE_SUBMIT_FIRST_INSPECTED_INFO) | ||||
.event(TenderStateChangeEvent.SUBMIT_PURCHASE_CONSTRUCTION_INFO) | .event(TenderStateChangeEvent.SUBMIT_PURCHASE_CONSTRUCTION_INFO) | ||||
.guard(new TenderGuardFactory.PurchaseContractRecordGuard()) | |||||
.guard(purchaseContractRecordToAcceptGuard) | |||||
.and() | .and() | ||||
// 填写实施计划 | // 填写实施计划 | ||||
.withExternal() | .withExternal() | ||||
@@ -4,7 +4,6 @@ import com.hz.pm.api.common.statemachine.builder.BaseStateMachineBuilder; | |||||
import com.hz.pm.api.common.statemachine.event.XcfhxStateChangeEvent; | import com.hz.pm.api.common.statemachine.event.XcfhxStateChangeEvent; | ||||
import com.hz.pm.api.projectdeclared.model.entity.Purchase; | import com.hz.pm.api.projectdeclared.model.entity.Purchase; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.TenderXcfhxApplyStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.TenderXcfhxApplyStatus; | ||||
import com.ningdatech.basic.exception.BizException; | |||||
import lombok.RequiredArgsConstructor; | import lombok.RequiredArgsConstructor; | ||||
import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||
import org.springframework.beans.factory.BeanFactory; | import org.springframework.beans.factory.BeanFactory; | ||||
@@ -2,7 +2,6 @@ package com.hz.pm.api.common.statemachine.factory; | |||||
import cn.hutool.core.collection.CollUtil; | import cn.hutool.core.collection.CollUtil; | ||||
import com.baomidou.mybatisplus.core.conditions.Wrapper; | import com.baomidou.mybatisplus.core.conditions.Wrapper; | ||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; | |||||
import com.baomidou.mybatisplus.core.toolkit.Wrappers; | import com.baomidou.mybatisplus.core.toolkit.Wrappers; | ||||
import com.hz.pm.api.common.statemachine.action.ProjectStateChangeAction; | import com.hz.pm.api.common.statemachine.action.ProjectStateChangeAction; | ||||
import com.hz.pm.api.common.statemachine.event.ProjectStateChangeEvent; | import com.hz.pm.api.common.statemachine.event.ProjectStateChangeEvent; | ||||
@@ -11,8 +10,9 @@ import com.hz.pm.api.projectdeclared.model.enumerization.BidTypeEnum; | |||||
import com.hz.pm.api.projectdeclared.service.IPurchaseService; | import com.hz.pm.api.projectdeclared.service.IPurchaseService; | ||||
import com.hz.pm.api.projectlib.model.entity.Project; | import com.hz.pm.api.projectlib.model.entity.Project; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.ProjectStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.ProjectStatus; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.TenderMainStatus; | |||||
import com.ningdatech.basic.util.SpringUtils; | |||||
import lombok.AllArgsConstructor; | |||||
import org.springframework.context.annotation.Bean; | |||||
import org.springframework.context.annotation.Configuration; | |||||
import org.springframework.statemachine.StateContext; | import org.springframework.statemachine.StateContext; | ||||
import org.springframework.statemachine.guard.Guard; | import org.springframework.statemachine.guard.Guard; | ||||
@@ -26,25 +26,58 @@ import java.util.List; | |||||
* @author WendyYang | * @author WendyYang | ||||
* @since 11:28 2024/8/22 | * @since 11:28 2024/8/22 | ||||
*/ | */ | ||||
@Configuration | |||||
public class ProjectGuardFactory { | public class ProjectGuardFactory { | ||||
private ProjectGuardFactory() { | |||||
private final IPurchaseService purchaseService; | |||||
public ProjectGuardFactory(IPurchaseService purchaseService) { | |||||
this.purchaseService = purchaseService; | |||||
} | |||||
@AllArgsConstructor | |||||
public static class ProjectPurchaseToAcceptGuard implements Guard<ProjectStatus, ProjectStateChangeEvent> { | |||||
private IPurchaseService purchaseService; | |||||
@Override | |||||
public boolean evaluate(StateContext<ProjectStatus, ProjectStateChangeEvent> ctx) { | |||||
return !canTurnToAdapt(ctx, purchaseService); | |||||
} | |||||
} | } | ||||
public static class ProjectPurchaseToFirstAcceptGuard implements Guard<ProjectStatus, ProjectStateChangeEvent> { | |||||
@AllArgsConstructor | |||||
public static class ProjectPurchaseToAdaptGuard implements Guard<ProjectStatus, ProjectStateChangeEvent> { | |||||
private final IPurchaseService purchaseService = SpringUtils.getBean(IPurchaseService.class); | |||||
private IPurchaseService purchaseService; | |||||
@Override | @Override | ||||
public boolean evaluate(StateContext<ProjectStatus, ProjectStateChangeEvent> stateContext) { | |||||
Project project = ProjectStateChangeAction.getProject(stateContext.getMessage()); | |||||
Wrapper<Purchase> query = Wrappers.lambdaQuery(Purchase.class) | |||||
.select(Purchase::getId, Purchase::getBidType) | |||||
.eq(Purchase::getProjectId, project.getId()); | |||||
List<Purchase> purchases = purchaseService.list(query); | |||||
return CollUtil.allMatch(purchases, w -> !BidTypeEnum.BUILD_APP.eq(w.getBidType())); | |||||
public boolean evaluate(StateContext<ProjectStatus, ProjectStateChangeEvent> ctx) { | |||||
return canTurnToAdapt(ctx, purchaseService); | |||||
} | } | ||||
} | } | ||||
private static boolean canTurnToAdapt(StateContext<ProjectStatus, ProjectStateChangeEvent> ctx, | |||||
IPurchaseService purchaseService) { | |||||
Project project = ProjectStateChangeAction.getProject(ctx.getMessage()); | |||||
Wrapper<Purchase> query = Wrappers.lambdaQuery(Purchase.class) | |||||
.select(Purchase::getId, Purchase::getBidType) | |||||
.eq(Purchase::getProjectId, project.getId()); | |||||
List<Purchase> purchases = purchaseService.list(query); | |||||
return CollUtil.anyMatch(purchases, w -> BidTypeEnum.BUILD_APP.eq(w.getBidType())); | |||||
} | |||||
@Bean | |||||
public ProjectPurchaseToAcceptGuard projectPurchaseToAcceptGuard() { | |||||
return new ProjectPurchaseToAcceptGuard(purchaseService); | |||||
} | |||||
@Bean | |||||
public ProjectPurchaseToAdaptGuard projectPurchaseToAdaptGuard() { | |||||
return new ProjectPurchaseToAdaptGuard(purchaseService); | |||||
} | |||||
} | } |
@@ -5,6 +5,8 @@ import com.hz.pm.api.common.statemachine.event.TenderStateChangeEvent; | |||||
import com.hz.pm.api.projectdeclared.model.entity.Purchase; | import com.hz.pm.api.projectdeclared.model.entity.Purchase; | ||||
import com.hz.pm.api.projectdeclared.model.enumerization.BidTypeEnum; | import com.hz.pm.api.projectdeclared.model.enumerization.BidTypeEnum; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | ||||
import org.springframework.context.annotation.Bean; | |||||
import org.springframework.context.annotation.Configuration; | |||||
import org.springframework.statemachine.StateContext; | import org.springframework.statemachine.StateContext; | ||||
import org.springframework.statemachine.guard.Guard; | import org.springframework.statemachine.guard.Guard; | ||||
@@ -16,12 +18,28 @@ import org.springframework.statemachine.guard.Guard; | |||||
* @author WendyYang | * @author WendyYang | ||||
* @since 17:51 2024/8/20 | * @since 17:51 2024/8/20 | ||||
*/ | */ | ||||
@Configuration | |||||
public class TenderGuardFactory { | public class TenderGuardFactory { | ||||
private TenderGuardFactory() { | |||||
@Bean | |||||
public PurchaseContractRecordToOperationGuard purchaseContractRecordToOperationGuard() { | |||||
return new PurchaseContractRecordToOperationGuard(); | |||||
} | } | ||||
public static class PurchaseContractRecordGuard implements Guard<ITenderStatus, TenderStateChangeEvent> { | |||||
@Bean | |||||
public PurchaseContractRecordToAcceptGuard purchaseContractRecordToAcceptGuard() { | |||||
return new PurchaseContractRecordToAcceptGuard(); | |||||
} | |||||
public static class PurchaseContractRecordToOperationGuard implements Guard<ITenderStatus, TenderStateChangeEvent> { | |||||
@Override | |||||
public boolean evaluate(StateContext<ITenderStatus, TenderStateChangeEvent> context) { | |||||
Purchase purchase = TenderStateChangeActionUtil.getPurchaseInfo(context.getMessage()); | |||||
return BidTypeEnum.BUILD_APP.eq(purchase.getBidType()); | |||||
} | |||||
} | |||||
public static class PurchaseContractRecordToAcceptGuard implements Guard<ITenderStatus, TenderStateChangeEvent> { | |||||
@Override | @Override | ||||
public boolean evaluate(StateContext<ITenderStatus, TenderStateChangeEvent> context) { | public boolean evaluate(StateContext<ITenderStatus, TenderStateChangeEvent> context) { | ||||
Purchase purchase = TenderStateChangeActionUtil.getPurchaseInfo(context.getMessage()); | Purchase purchase = TenderStateChangeActionUtil.getPurchaseInfo(context.getMessage()); | ||||
@@ -1,9 +1,10 @@ | |||||
package com.hz.pm.api.common.statemachine.util; | package com.hz.pm.api.common.statemachine.util; | ||||
import cn.hutool.log.Log; | |||||
import cn.hutool.log.LogFactory; | |||||
import com.hz.pm.api.common.statemachine.event.AbstractStateChangeEvent; | import com.hz.pm.api.common.statemachine.event.AbstractStateChangeEvent; | ||||
import com.ningdatech.basic.exception.BizException; | import com.ningdatech.basic.exception.BizException; | ||||
import com.wflow.exception.BusinessException; | import com.wflow.exception.BusinessException; | ||||
import org.slf4j.LoggerFactory; | |||||
import java.lang.reflect.ParameterizedType; | import java.lang.reflect.ParameterizedType; | ||||
import java.lang.reflect.Type; | import java.lang.reflect.Type; | ||||
@@ -19,6 +20,8 @@ import java.util.function.Function; | |||||
*/ | */ | ||||
public interface AbstractStateMachineUtil<O, E extends Enum<E> & AbstractStateChangeEvent> { | public interface AbstractStateMachineUtil<O, E extends Enum<E> & AbstractStateChangeEvent> { | ||||
Log LOG = LogFactory.get(AbstractStateMachineUtil.class); | |||||
/** | /** | ||||
* 获取状态变更事件类型 | * 获取状态变更事件类型 | ||||
* | * | ||||
@@ -29,12 +32,19 @@ public interface AbstractStateMachineUtil<O, E extends Enum<E> & AbstractStateCh | |||||
return (Class<E>) ((ParameterizedType) type).getActualTypeArguments()[1]; | return (Class<E>) ((ParameterizedType) type).getActualTypeArguments()[1]; | ||||
} | } | ||||
default AbstractStateMachineUtil<O, E> getLockClass() { | |||||
LOG.info("acquire state machine lock:{}", this.getClass().getSimpleName()); | |||||
return this; | |||||
} | |||||
//通过审核 | //通过审核 | ||||
default void pass(O obj) { | default void pass(O obj) { | ||||
try { | try { | ||||
execute(obj, AbstractStateChangeEvent.getPassEvent(eventClass(), statusFunction().apply(obj))); | |||||
synchronized (getLockClass()) { | |||||
execute(obj, AbstractStateChangeEvent.getPassEvent(eventClass(), statusFunction().apply(obj))); | |||||
} | |||||
} catch (Exception e) { | } catch (Exception e) { | ||||
LoggerFactory.getLogger(this.getClass()).info("状态机 通过失败", e); | |||||
LOG.error("状态机通过失败", e); | |||||
throw BizException.wrap("状态机通过失败"); | throw BizException.wrap("状态机通过失败"); | ||||
} | } | ||||
} | } | ||||
@@ -43,9 +53,11 @@ public interface AbstractStateMachineUtil<O, E extends Enum<E> & AbstractStateCh | |||||
//拒绝 | //拒绝 | ||||
default void reject(O obj) { | default void reject(O obj) { | ||||
try { | try { | ||||
execute(obj, AbstractStateChangeEvent.getRejectEvent(eventClass(), statusFunction().apply(obj))); | |||||
synchronized (getLockClass()) { | |||||
execute(obj, AbstractStateChangeEvent.getRejectEvent(eventClass(), statusFunction().apply(obj))); | |||||
} | |||||
} catch (Exception e) { | } catch (Exception e) { | ||||
LoggerFactory.getLogger(this.getClass()).info("状态机 拒绝失败 :{}", e.getMessage()); | |||||
LOG.error("状态机拒绝失败", e); | |||||
throw new BusinessException("状态机拒绝失败"); | throw new BusinessException("状态机拒绝失败"); | ||||
} | } | ||||
} | } | ||||
@@ -53,9 +65,11 @@ public interface AbstractStateMachineUtil<O, E extends Enum<E> & AbstractStateCh | |||||
//撤回 | //撤回 | ||||
default void withDraw(O obj) { | default void withDraw(O obj) { | ||||
try { | try { | ||||
execute(obj, AbstractStateChangeEvent.getWithdrawEvent(eventClass(), statusFunction().apply(obj))); | |||||
synchronized (getLockClass()) { | |||||
execute(obj, AbstractStateChangeEvent.getWithdrawEvent(eventClass(), statusFunction().apply(obj))); | |||||
} | |||||
} catch (Exception e) { | } catch (Exception e) { | ||||
LoggerFactory.getLogger(this.getClass()).info("状态机 撤回失败 :{}", e.getMessage()); | |||||
LOG.error("状态机撤回失败", e); | |||||
throw new BusinessException("状态机撤回失败"); | throw new BusinessException("状态机撤回失败"); | ||||
} | } | ||||
} | } | ||||
@@ -5,10 +5,8 @@ import com.hz.pm.api.common.statemachine.event.AdaptStateChangeEvent; | |||||
import com.hz.pm.api.projectdeclared.model.entity.Purchase; | import com.hz.pm.api.projectdeclared.model.entity.Purchase; | ||||
import com.hz.pm.api.projectdeclared.utils.ProjectIdCodeCacheUtil; | import com.hz.pm.api.projectdeclared.utils.ProjectIdCodeCacheUtil; | ||||
import com.hz.pm.api.projectlib.entity.PurchaseStatusChange; | import com.hz.pm.api.projectlib.entity.PurchaseStatusChange; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | |||||
import com.hz.pm.api.projectlib.model.enumeration.status.TenderAdaptStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.TenderAdaptStatus; | ||||
import com.hz.pm.api.projectlib.service.IPurchaseStatusChangeService; | import com.hz.pm.api.projectlib.service.IPurchaseStatusChangeService; | ||||
import lombok.RequiredArgsConstructor; | |||||
import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||
import org.springframework.messaging.Message; | import org.springframework.messaging.Message; | ||||
import org.springframework.messaging.support.MessageBuilder; | import org.springframework.messaging.support.MessageBuilder; | ||||
@@ -29,16 +27,23 @@ import java.util.function.Function; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@RequiredArgsConstructor | |||||
public class AdaptStateMachineUtil implements AbstractStateMachineUtil<Purchase, AdaptStateChangeEvent> { | public class AdaptStateMachineUtil implements AbstractStateMachineUtil<Purchase, AdaptStateChangeEvent> { | ||||
public static final String PURCHASE = "purchaseInfo"; | public static final String PURCHASE = "purchaseInfo"; | ||||
//================================================================================================================== | //================================================================================================================== | ||||
private final AdaptStateMachineBuilderImpl adaptStateMachineBuilder; | |||||
private final StateMachinePersister<TenderAdaptStatus, AdaptStateChangeEvent, Purchase> stateMachinePersister; | |||||
private final StateMachine<TenderAdaptStatus, AdaptStateChangeEvent> stateMachine; | |||||
private final IPurchaseStatusChangeService purchaseStatusChangeService; | private final IPurchaseStatusChangeService purchaseStatusChangeService; | ||||
public AdaptStateMachineUtil(AdaptStateMachineBuilderImpl adaptStateMachineBuilder, | |||||
IPurchaseStatusChangeService purchaseStatusChangeService) { | |||||
this.purchaseStatusChangeService = purchaseStatusChangeService; | |||||
this.stateMachine = adaptStateMachineBuilder.build(); | |||||
this.stateMachinePersister = adaptStateMachineBuilder.stateMachinePersister(); | |||||
} | |||||
@Override | @Override | ||||
public Function<Purchase, Integer> statusFunction() { | public Function<Purchase, Integer> statusFunction() { | ||||
return Purchase::getAdaptStatus; | return Purchase::getAdaptStatus; | ||||
@@ -46,8 +51,6 @@ public class AdaptStateMachineUtil implements AbstractStateMachineUtil<Purchase, | |||||
@Override | @Override | ||||
public void execute(Purchase purchase, AdaptStateChangeEvent event) throws Exception { | public void execute(Purchase purchase, AdaptStateChangeEvent event) throws Exception { | ||||
log.info("调用状态机前的标段状态为:{}", purchase.getStatus()); | |||||
// 获取TO状态机 | |||||
PurchaseStatusChange change = new PurchaseStatusChange(); | PurchaseStatusChange change = new PurchaseStatusChange(); | ||||
change.setBeforeStatus(purchase.getAdaptStatus()); | change.setBeforeStatus(purchase.getAdaptStatus()); | ||||
change.setEvent(event.name()); | change.setEvent(event.name()); | ||||
@@ -55,17 +58,15 @@ public class AdaptStateMachineUtil implements AbstractStateMachineUtil<Purchase, | |||||
change.setProjectId(purchase.getProjectId()); | change.setProjectId(purchase.getProjectId()); | ||||
change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | ||||
change.setCreateOn(LocalDateTime.now()); | change.setCreateOn(LocalDateTime.now()); | ||||
StateMachine<TenderAdaptStatus, AdaptStateChangeEvent> stateMachine = adaptStateMachineBuilder.build(); | |||||
Message<AdaptStateChangeEvent> message = MessageBuilder.withPayload(event) | Message<AdaptStateChangeEvent> message = MessageBuilder.withPayload(event) | ||||
.setHeader(PURCHASE, purchase) | .setHeader(PURCHASE, purchase) | ||||
.build(); | .build(); | ||||
//初始化状态机 | //初始化状态机 | ||||
StateMachinePersister<TenderAdaptStatus, AdaptStateChangeEvent, Purchase> stateMachinePersister = adaptStateMachineBuilder.stateMachinePersister(); | |||||
stateMachinePersister.restore(stateMachine, purchase); | stateMachinePersister.restore(stateMachine, purchase); | ||||
stateMachine.sendEvent(message); | stateMachine.sendEvent(message); | ||||
change.setAfterStatus(purchase.getAdaptStatus()); | change.setAfterStatus(purchase.getAdaptStatus()); | ||||
purchaseStatusChangeService.save(change); | purchaseStatusChangeService.save(change); | ||||
log.info("调用状态机后的标段状态为:{}", purchase.getAdaptStatus()); | |||||
log.info("调用状态机后的标段状态为:{} ==> {}", change.getBeforeStatus(), change.getAfterStatus()); | |||||
} | } | ||||
} | } |
@@ -27,7 +27,6 @@ import java.util.function.Function; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@RequiredArgsConstructor | |||||
public class ProjectStateMachineUtil implements AbstractStateMachineUtil<Project, ProjectStateChangeEvent> { | public class ProjectStateMachineUtil implements AbstractStateMachineUtil<Project, ProjectStateChangeEvent> { | ||||
private static final String PROJECT_DECLARE = StateMachineConst.PROJECT_DECLARE; | private static final String PROJECT_DECLARE = StateMachineConst.PROJECT_DECLARE; | ||||
@@ -36,12 +35,20 @@ public class ProjectStateMachineUtil implements AbstractStateMachineUtil<Project | |||||
//================================================================================================================== | //================================================================================================================== | ||||
private final ProjectStateMachineBuilderImpl projectStateMachineBuilder; | |||||
private final StateMachinePersister<ProjectStatus, ProjectStateChangeEvent, Project> stateMachinePersister; | |||||
private final StateMachine<ProjectStatus, ProjectStateChangeEvent> stateMachine; | |||||
private final IProjectStatusChangeService projectStatusChangeService; | private final IProjectStatusChangeService projectStatusChangeService; | ||||
private final IProjectApplicationService projectApplicationService; | private final IProjectApplicationService projectApplicationService; | ||||
public ProjectStateMachineUtil(ProjectStateMachineBuilderImpl projectStateMachineBuilder, | |||||
IProjectStatusChangeService projectStatusChangeService, | |||||
IProjectApplicationService projectApplicationService) { | |||||
this.projectStatusChangeService = projectStatusChangeService; | |||||
this.projectApplicationService = projectApplicationService; | |||||
this.stateMachinePersister = projectStateMachineBuilder.stateMachinePersister(); | |||||
this.stateMachine = projectStateMachineBuilder.build(); | |||||
} | |||||
@Override | @Override | ||||
public Function<Project, Integer> statusFunction() { | public Function<Project, Integer> statusFunction() { | ||||
return Project::getStatus; | return Project::getStatus; | ||||
@@ -49,29 +56,25 @@ public class ProjectStateMachineUtil implements AbstractStateMachineUtil<Project | |||||
@Override | @Override | ||||
public void execute(Project project, ProjectStateChangeEvent event) throws Exception { | public void execute(Project project, ProjectStateChangeEvent event) throws Exception { | ||||
log.info("调用状态机前的项目状态为:{}", project.getStatus()); | |||||
// 将状态变更记录保存到项目状态变更表中 | // 将状态变更记录保存到项目状态变更表中 | ||||
ProjectStatusChange projectStatusChange = new ProjectStatusChange(); | |||||
projectStatusChange.setBeforeStatus(project.getStatus()); | |||||
ProjectStatusChange change = new ProjectStatusChange(); | |||||
change.setBeforeStatus(project.getStatus()); | |||||
// 获取TO状态机 | // 获取TO状态机 | ||||
StateMachine<ProjectStatus, ProjectStateChangeEvent> stateMachine = projectStateMachineBuilder.build(); | |||||
Message<ProjectStateChangeEvent> message = MessageBuilder.withPayload(event) | Message<ProjectStateChangeEvent> message = MessageBuilder.withPayload(event) | ||||
.setHeader(PROJECT_DECLARE, project) | .setHeader(PROJECT_DECLARE, project) | ||||
.setHeader(APPLICATION_DECLARE, projectApplicationService.getApplicationsByProject(project)) | .setHeader(APPLICATION_DECLARE, projectApplicationService.getApplicationsByProject(project)) | ||||
.build(); | .build(); | ||||
//初始化状态机 | //初始化状态机 | ||||
StateMachinePersister<ProjectStatus, ProjectStateChangeEvent, Project> projectDeclareStateMachinePersister = projectStateMachineBuilder.stateMachinePersister(); | |||||
projectDeclareStateMachinePersister.restore(stateMachine, project); | |||||
stateMachinePersister.restore(stateMachine, project); | |||||
stateMachine.sendEvent(message); | stateMachine.sendEvent(message); | ||||
projectStatusChange.setProjectId(project.getId()); | |||||
projectStatusChange.setAfterStatus(project.getStatus()); | |||||
projectStatusChange.setEvent(event.name()); | |||||
projectStatusChange.setCreateOn(LocalDateTime.now()); | |||||
projectStatusChange.setProjectCode(project.getProjectCode()); | |||||
change.setProjectId(project.getId()); | |||||
change.setAfterStatus(project.getStatus()); | |||||
change.setEvent(event.name()); | |||||
change.setCreateOn(LocalDateTime.now()); | |||||
change.setProjectCode(project.getProjectCode()); | |||||
// 插入项目状态变更表中 | // 插入项目状态变更表中 | ||||
projectStatusChangeService.save(projectStatusChange); | |||||
log.info("调用状态机后的项目状态为:{}", project.getStatus()); | |||||
projectStatusChangeService.save(change); | |||||
log.info("调用状态机后的标段状态为:{} ==> {}", change.getBeforeStatus(), change.getAfterStatus()); | |||||
} | } | ||||
} | } |
@@ -28,15 +28,21 @@ import java.util.function.Function; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@RequiredArgsConstructor | |||||
public class SelfTestStateMachineUtil implements AbstractStateMachineUtil<Purchase, SelfTestStateChangeEvent> { | public class SelfTestStateMachineUtil implements AbstractStateMachineUtil<Purchase, SelfTestStateChangeEvent> { | ||||
public static final String PURCHASE = "purchaseInfo"; | public static final String PURCHASE = "purchaseInfo"; | ||||
//================================================================================================================== | //================================================================================================================== | ||||
private final SelfTestStateMachineBuilderImpl selfTestStateMachineBuilder; | |||||
private final IPurchaseStatusChangeService purchaseStatusChangeService; | private final IPurchaseStatusChangeService purchaseStatusChangeService; | ||||
private final StateMachinePersister<TenderSelfTestStatus, SelfTestStateChangeEvent, Purchase> stateMachinePersister; | |||||
private final StateMachine<TenderSelfTestStatus, SelfTestStateChangeEvent> stateMachine; | |||||
public SelfTestStateMachineUtil(SelfTestStateMachineBuilderImpl selfTestStateMachineBuilder, IPurchaseStatusChangeService purchaseStatusChangeService) { | |||||
this.purchaseStatusChangeService = purchaseStatusChangeService; | |||||
this.stateMachinePersister = selfTestStateMachineBuilder.stateMachinePersister(); | |||||
this.stateMachine = selfTestStateMachineBuilder.build(); | |||||
} | |||||
@Override | @Override | ||||
public Function<Purchase, Integer> statusFunction() { | public Function<Purchase, Integer> statusFunction() { | ||||
@@ -45,7 +51,6 @@ public class SelfTestStateMachineUtil implements AbstractStateMachineUtil<Purcha | |||||
@Override | @Override | ||||
public void execute(Purchase purchase, SelfTestStateChangeEvent event) throws Exception { | public void execute(Purchase purchase, SelfTestStateChangeEvent event) throws Exception { | ||||
log.info("调用状态机前的标段状态为:{}", purchase.getSelfTestStatus()); | |||||
// 获取TO状态机 | // 获取TO状态机 | ||||
PurchaseStatusChange change = new PurchaseStatusChange(); | PurchaseStatusChange change = new PurchaseStatusChange(); | ||||
change.setBeforeStatus(purchase.getSelfTestStatus()); | change.setBeforeStatus(purchase.getSelfTestStatus()); | ||||
@@ -54,17 +59,15 @@ public class SelfTestStateMachineUtil implements AbstractStateMachineUtil<Purcha | |||||
change.setProjectId(purchase.getProjectId()); | change.setProjectId(purchase.getProjectId()); | ||||
change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | ||||
change.setCreateOn(LocalDateTime.now()); | change.setCreateOn(LocalDateTime.now()); | ||||
StateMachine<TenderSelfTestStatus, SelfTestStateChangeEvent> stateMachine = selfTestStateMachineBuilder.build(); | |||||
Message<SelfTestStateChangeEvent> message = MessageBuilder.withPayload(event) | Message<SelfTestStateChangeEvent> message = MessageBuilder.withPayload(event) | ||||
.setHeader(PURCHASE, purchase) | .setHeader(PURCHASE, purchase) | ||||
.build(); | .build(); | ||||
//初始化状态机 | //初始化状态机 | ||||
StateMachinePersister<TenderSelfTestStatus, SelfTestStateChangeEvent, Purchase> stateMachinePersister = selfTestStateMachineBuilder.stateMachinePersister(); | |||||
stateMachinePersister.restore(stateMachine, purchase); | stateMachinePersister.restore(stateMachine, purchase); | ||||
stateMachine.sendEvent(message); | stateMachine.sendEvent(message); | ||||
change.setAfterStatus(purchase.getSelfTestStatus()); | change.setAfterStatus(purchase.getSelfTestStatus()); | ||||
purchaseStatusChangeService.save(change); | purchaseStatusChangeService.save(change); | ||||
log.info("调用状态机后的标段状态为:{}", purchase.getSelfTestStatus()); | |||||
log.info("调用状态机后的标段状态为:{} ==> {}", change.getBeforeStatus(), change.getAfterStatus()); | |||||
} | } | ||||
} | } |
@@ -7,6 +7,7 @@ import com.hz.pm.api.projectdeclared.utils.ProjectIdCodeCacheUtil; | |||||
import com.hz.pm.api.projectlib.entity.PurchaseStatusChange; | import com.hz.pm.api.projectlib.entity.PurchaseStatusChange; | ||||
import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | import com.hz.pm.api.projectlib.model.enumeration.status.ITenderStatus; | ||||
import com.hz.pm.api.projectlib.service.IPurchaseStatusChangeService; | import com.hz.pm.api.projectlib.service.IPurchaseStatusChangeService; | ||||
import com.ningdatech.basic.exception.BizException; | |||||
import lombok.RequiredArgsConstructor; | import lombok.RequiredArgsConstructor; | ||||
import lombok.extern.slf4j.Slf4j; | import lombok.extern.slf4j.Slf4j; | ||||
import org.springframework.messaging.Message; | import org.springframework.messaging.Message; | ||||
@@ -28,15 +29,21 @@ import java.util.function.Function; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@RequiredArgsConstructor | |||||
public class TenderStateMachineUtil implements AbstractStateMachineUtil<Purchase, TenderStateChangeEvent> { | public class TenderStateMachineUtil implements AbstractStateMachineUtil<Purchase, TenderStateChangeEvent> { | ||||
public static final String PURCHASE = "purchaseInfo"; | public static final String PURCHASE = "purchaseInfo"; | ||||
//================================================================================================================== | //================================================================================================================== | ||||
private final TenderStateMachineBuilderImpl tenderStateMachineBuilder; | |||||
private final IPurchaseStatusChangeService purchaseStatusChangeService; | private final IPurchaseStatusChangeService purchaseStatusChangeService; | ||||
private final StateMachinePersister<ITenderStatus, TenderStateChangeEvent, Purchase> stateMachinePersister; | |||||
private final StateMachine<ITenderStatus, TenderStateChangeEvent> stateMachine; | |||||
public TenderStateMachineUtil(IPurchaseStatusChangeService purchaseStatusChangeService, TenderStateMachineBuilderImpl tenderStateMachineBuilder) { | |||||
this.purchaseStatusChangeService = purchaseStatusChangeService; | |||||
this.stateMachinePersister = tenderStateMachineBuilder.stateMachinePersister(); | |||||
this.stateMachine = tenderStateMachineBuilder.build(); | |||||
} | |||||
@Override | @Override | ||||
public Function<Purchase, Integer> statusFunction() { | public Function<Purchase, Integer> statusFunction() { | ||||
@@ -45,7 +52,6 @@ public class TenderStateMachineUtil implements AbstractStateMachineUtil<Purchase | |||||
@Override | @Override | ||||
public void execute(Purchase purchase, TenderStateChangeEvent event) throws Exception { | public void execute(Purchase purchase, TenderStateChangeEvent event) throws Exception { | ||||
log.info("调用状态机前的标段状态为:{}", purchase.getStatus()); | |||||
// 获取TO状态机 | // 获取TO状态机 | ||||
PurchaseStatusChange change = new PurchaseStatusChange(); | PurchaseStatusChange change = new PurchaseStatusChange(); | ||||
change.setBeforeStatus(purchase.getStatus()); | change.setBeforeStatus(purchase.getStatus()); | ||||
@@ -54,17 +60,15 @@ public class TenderStateMachineUtil implements AbstractStateMachineUtil<Purchase | |||||
change.setProjectId(purchase.getProjectId()); | change.setProjectId(purchase.getProjectId()); | ||||
change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | ||||
change.setCreateOn(LocalDateTime.now()); | change.setCreateOn(LocalDateTime.now()); | ||||
StateMachine<ITenderStatus, TenderStateChangeEvent> stateMachine = tenderStateMachineBuilder.build(); | |||||
Message<TenderStateChangeEvent> message = MessageBuilder.withPayload(event) | Message<TenderStateChangeEvent> message = MessageBuilder.withPayload(event) | ||||
.setHeader(PURCHASE, purchase) | .setHeader(PURCHASE, purchase) | ||||
.build(); | .build(); | ||||
//初始化状态机 | //初始化状态机 | ||||
StateMachinePersister<ITenderStatus, TenderStateChangeEvent, Purchase> stateMachinePersister = tenderStateMachineBuilder.stateMachinePersister(); | |||||
stateMachinePersister.restore(stateMachine, purchase); | stateMachinePersister.restore(stateMachine, purchase); | ||||
stateMachine.sendEvent(message); | stateMachine.sendEvent(message); | ||||
change.setAfterStatus(purchase.getStatus()); | change.setAfterStatus(purchase.getStatus()); | ||||
purchaseStatusChangeService.save(change); | purchaseStatusChangeService.save(change); | ||||
log.info("调用状态机后的标段状态为:{}", purchase.getStatus()); | |||||
log.info("调用状态机后的标段状态为:{} ==> {}", change.getBeforeStatus(), change.getAfterStatus()); | |||||
} | } | ||||
} | } |
@@ -45,8 +45,6 @@ public class TestValidStateMachineUtil implements AbstractStateMachineUtil<Purch | |||||
@Override | @Override | ||||
public void execute(Purchase purchase, TestValidStateChangeEvent event) throws Exception { | public void execute(Purchase purchase, TestValidStateChangeEvent event) throws Exception { | ||||
log.info("调用状态机前的标段状态为:{}", purchase.getStatus()); | |||||
// 获取TO状态机 | |||||
PurchaseStatusChange change = new PurchaseStatusChange(); | PurchaseStatusChange change = new PurchaseStatusChange(); | ||||
change.setBeforeStatus(purchase.getTestValidStatus()); | change.setBeforeStatus(purchase.getTestValidStatus()); | ||||
change.setEvent(event.name()); | change.setEvent(event.name()); | ||||
@@ -64,7 +62,7 @@ public class TestValidStateMachineUtil implements AbstractStateMachineUtil<Purch | |||||
stateMachine.sendEvent(message); | stateMachine.sendEvent(message); | ||||
change.setAfterStatus(purchase.getTestValidStatus()); | change.setAfterStatus(purchase.getTestValidStatus()); | ||||
purchaseStatusChangeService.save(change); | purchaseStatusChangeService.save(change); | ||||
log.info("调用状态机后的标段状态为:{}", purchase.getStatus()); | |||||
log.info("调用状态机后的标段状态为:{} ==> {}", change.getBeforeStatus(), change.getAfterStatus()); | |||||
} | } | ||||
} | } |
@@ -28,15 +28,22 @@ import java.util.function.Function; | |||||
*/ | */ | ||||
@Slf4j | @Slf4j | ||||
@Component | @Component | ||||
@RequiredArgsConstructor | |||||
public class XcfhxStateMachineUtil implements AbstractStateMachineUtil<Purchase, XcfhxStateChangeEvent> { | public class XcfhxStateMachineUtil implements AbstractStateMachineUtil<Purchase, XcfhxStateChangeEvent> { | ||||
public static final String PURCHASE = "purchaseInfo"; | public static final String PURCHASE = "purchaseInfo"; | ||||
//================================================================================================================== | //================================================================================================================== | ||||
private final XcfhxStateMachineBuilderImpl xcfhxStateMachineBuilder; | |||||
private final IPurchaseStatusChangeService purchaseStatusChangeService; | private final IPurchaseStatusChangeService purchaseStatusChangeService; | ||||
private final StateMachinePersister<TenderXcfhxApplyStatus, XcfhxStateChangeEvent, Purchase> stateMachinePersister; | |||||
private final StateMachine<TenderXcfhxApplyStatus, XcfhxStateChangeEvent> stateMachine; | |||||
public XcfhxStateMachineUtil(XcfhxStateMachineBuilderImpl xcfhxStateMachineBuilder, | |||||
IPurchaseStatusChangeService purchaseStatusChangeService) { | |||||
this.purchaseStatusChangeService = purchaseStatusChangeService; | |||||
this.stateMachine = xcfhxStateMachineBuilder.build(); | |||||
this.stateMachinePersister = xcfhxStateMachineBuilder.stateMachinePersister(); | |||||
} | |||||
@Override | @Override | ||||
public Function<Purchase, Integer> statusFunction() { | public Function<Purchase, Integer> statusFunction() { | ||||
@@ -45,8 +52,6 @@ public class XcfhxStateMachineUtil implements AbstractStateMachineUtil<Purchase, | |||||
@Override | @Override | ||||
public void execute(Purchase purchase, XcfhxStateChangeEvent event) throws Exception { | public void execute(Purchase purchase, XcfhxStateChangeEvent event) throws Exception { | ||||
log.info("调用状态机前的标段状态为:{}", purchase.getXcfhxApplyStatus()); | |||||
// 获取TO状态机 | |||||
PurchaseStatusChange change = new PurchaseStatusChange(); | PurchaseStatusChange change = new PurchaseStatusChange(); | ||||
change.setBeforeStatus(purchase.getXcfhxApplyStatus()); | change.setBeforeStatus(purchase.getXcfhxApplyStatus()); | ||||
change.setEvent(event.name()); | change.setEvent(event.name()); | ||||
@@ -54,17 +59,15 @@ public class XcfhxStateMachineUtil implements AbstractStateMachineUtil<Purchase, | |||||
change.setProjectId(purchase.getProjectId()); | change.setProjectId(purchase.getProjectId()); | ||||
change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | change.setProjectCode(ProjectIdCodeCacheUtil.get(purchase.getProjectId())); | ||||
change.setCreateOn(LocalDateTime.now()); | change.setCreateOn(LocalDateTime.now()); | ||||
StateMachine<TenderXcfhxApplyStatus, XcfhxStateChangeEvent> stateMachine = xcfhxStateMachineBuilder.build(); | |||||
Message<XcfhxStateChangeEvent> message = MessageBuilder.withPayload(event) | Message<XcfhxStateChangeEvent> message = MessageBuilder.withPayload(event) | ||||
.setHeader(PURCHASE, purchase) | .setHeader(PURCHASE, purchase) | ||||
.build(); | .build(); | ||||
//初始化状态机 | //初始化状态机 | ||||
StateMachinePersister<TenderXcfhxApplyStatus, XcfhxStateChangeEvent, Purchase> stateMachinePersister = xcfhxStateMachineBuilder.stateMachinePersister(); | |||||
stateMachinePersister.restore(stateMachine, purchase); | stateMachinePersister.restore(stateMachine, purchase); | ||||
stateMachine.sendEvent(message); | stateMachine.sendEvent(message); | ||||
change.setAfterStatus(purchase.getXcfhxApplyStatus()); | change.setAfterStatus(purchase.getXcfhxApplyStatus()); | ||||
purchaseStatusChangeService.save(change); | purchaseStatusChangeService.save(change); | ||||
log.info("调用状态机后的标段状态为:{}", purchase.getXcfhxApplyStatus()); | |||||
log.info("调用状态机后的标段状态为:{} ==> {}", change.getBeforeStatus(), change.getAfterStatus()); | |||||
} | } | ||||
} | } |
@@ -28,7 +28,6 @@ public class ThreadPoolUtil { | |||||
static { | static { | ||||
ThreadPoolUtilProperties properties = SpringUtil.getBean(ThreadPoolUtilProperties.class); | ThreadPoolUtilProperties properties = SpringUtil.getBean(ThreadPoolUtilProperties.class); | ||||
log.info("ThreadPoolUtilProperties:{}", properties); | |||||
ThreadPoolProperties requestProps = properties.getRequest(); | ThreadPoolProperties requestProps = properties.getRequest(); | ||||
REQUEST = new MDCThreadPoolTaskExecutor(); | REQUEST = new MDCThreadPoolTaskExecutor(); | ||||
REQUEST.setCorePoolSize(requestProps.getCorePoolSize()); | REQUEST.setCorePoolSize(requestProps.getCorePoolSize()); | ||||
@@ -47,7 +46,6 @@ public class ThreadPoolUtil { | |||||
SCHEDULER.setPoolSize(schedulerProps.getCorePoolSize()); | SCHEDULER.setPoolSize(schedulerProps.getCorePoolSize()); | ||||
SCHEDULER.setThreadPriority(Thread.NORM_PRIORITY - 1); | SCHEDULER.setThreadPriority(Thread.NORM_PRIORITY - 1); | ||||
SCHEDULER.setWaitForTasksToCompleteOnShutdown(schedulerProps.getWaitForTasksToCompleteOnShutdown()); | SCHEDULER.setWaitForTasksToCompleteOnShutdown(schedulerProps.getWaitForTasksToCompleteOnShutdown()); | ||||
SCHEDULER.setThreadNamePrefix("scheduler-"); | |||||
SCHEDULER.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); | SCHEDULER.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); | ||||
SCHEDULER.initialize(); | SCHEDULER.initialize(); | ||||
} | } | ||||
@@ -1,5 +1,7 @@ | |||||
package com.hz.pm.api.meeting.task; | package com.hz.pm.api.meeting.task; | ||||
import com.hz.pm.api.common.config.ThreadPoolUtilProperties.ThreadPoolProperties; | |||||
import com.hz.pm.api.common.util.MDCThreadPoolTaskScheduler; | |||||
import org.springframework.context.annotation.Bean; | import org.springframework.context.annotation.Bean; | ||||
import org.springframework.context.annotation.Configuration; | import org.springframework.context.annotation.Configuration; | ||||
import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler; | import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler; | ||||
@@ -16,13 +18,14 @@ import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler; | |||||
public class ExpertInviteExecutorConfig { | public class ExpertInviteExecutorConfig { | ||||
@Bean(name = "expertInviteScheduler") | @Bean(name = "expertInviteScheduler") | ||||
public ThreadPoolTaskScheduler threadPoolTaskScheduler() { | |||||
ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler(); | |||||
scheduler.setPoolSize(3); | |||||
public ThreadPoolTaskScheduler threadPoolTaskScheduler(RandomInviteProperties properties) { | |||||
ThreadPoolProperties threadPoolProperties = properties.getThreadPoolProperties(); | |||||
MDCThreadPoolTaskScheduler scheduler = new MDCThreadPoolTaskScheduler(); | |||||
scheduler.setPoolSize(threadPoolProperties.getCorePoolSize()); | |||||
scheduler.setThreadGroupName("expert-invite"); | scheduler.setThreadGroupName("expert-invite"); | ||||
scheduler.setThreadNamePrefix("invite-executor-"); | |||||
scheduler.setAwaitTerminationSeconds(60); | |||||
scheduler.setWaitForTasksToCompleteOnShutdown(true); | |||||
scheduler.setThreadNamePrefix(threadPoolProperties.getThreadNamePrefix()); | |||||
scheduler.setAwaitTerminationSeconds(120); | |||||
scheduler.setWaitForTasksToCompleteOnShutdown(threadPoolProperties.getWaitForTasksToCompleteOnShutdown()); | |||||
return scheduler; | return scheduler; | ||||
} | } | ||||
@@ -48,13 +48,15 @@ public class MsgCallReplyRewriteTask { | |||||
static { | static { | ||||
// 初始化线程池 | // 初始化线程池 | ||||
EXECUTOR = new MDCThreadPoolTaskExecutor(); | EXECUTOR = new MDCThreadPoolTaskExecutor(); | ||||
EXECUTOR.setBeanName("msgCallReplyRewriteExecutor"); | |||||
EXECUTOR.setCorePoolSize(2); | EXECUTOR.setCorePoolSize(2); | ||||
EXECUTOR.setMaxPoolSize(4); | EXECUTOR.setMaxPoolSize(4); | ||||
EXECUTOR.setQueueCapacity(100); | EXECUTOR.setQueueCapacity(100); | ||||
EXECUTOR.setKeepAliveSeconds(120); | EXECUTOR.setKeepAliveSeconds(120); | ||||
EXECUTOR.setThreadPriority(Thread.NORM_PRIORITY); | |||||
EXECUTOR.setThreadPriority(Thread.NORM_PRIORITY - 1); | |||||
EXECUTOR.setWaitForTasksToCompleteOnShutdown(true); | EXECUTOR.setWaitForTasksToCompleteOnShutdown(true); | ||||
EXECUTOR.setThreadNamePrefix("callRewriteExecutor-"); | EXECUTOR.setThreadNamePrefix("callRewriteExecutor-"); | ||||
EXECUTOR.setAllowCoreThreadTimeOut(true); | |||||
EXECUTOR.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); | EXECUTOR.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy()); | ||||
} | } | ||||
@@ -1,7 +1,10 @@ | |||||
package com.hz.pm.api.meeting.task; | package com.hz.pm.api.meeting.task; | ||||
import com.hz.pm.api.common.config.ThreadPoolUtilProperties; | |||||
import com.hz.pm.api.common.config.ThreadPoolUtilProperties.ThreadPoolProperties; | |||||
import lombok.Data; | import lombok.Data; | ||||
import org.springframework.boot.context.properties.ConfigurationProperties; | import org.springframework.boot.context.properties.ConfigurationProperties; | ||||
import org.springframework.boot.context.properties.NestedConfigurationProperty; | |||||
import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||
/** | /** | ||||
@@ -56,4 +59,7 @@ public class RandomInviteProperties { | |||||
private Integer inviteEndHour = 20; | private Integer inviteEndHour = 20; | ||||
@NestedConfigurationProperty | |||||
private ThreadPoolProperties threadPoolProperties; | |||||
} | } |
@@ -88,8 +88,8 @@ public class PurchaseController { | |||||
@GetMapping("/adaptionProgressStatistics") | @GetMapping("/adaptionProgressStatistics") | ||||
@ApiOperation("获取采购进度统计") | @ApiOperation("获取采购进度统计") | ||||
public AdaptionProgressStatVO adaptionProgressStatistics() { | |||||
return purchaseManage.adaptionProgressStatistics(); | |||||
public AdaptionProgressStatVO adaptionProgressStatistics(PurchaseAdaptionListReq req) { | |||||
return purchaseManage.adaptionProgressStatistics(req); | |||||
} | } | ||||
@GetMapping("/pageAdaption") | @GetMapping("/pageAdaption") | ||||
@@ -152,7 +152,7 @@ public class PurchaseManage { | |||||
w -> CollUtil.anyMatch(w, x -> TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO.eq(x.getStatus())))); | w -> CollUtil.anyMatch(w, x -> TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO.eq(x.getStatus())))); | ||||
stat.setToBePurchaseCount(CollUtil.count(projectPurchaseMap.values(), Collection::isEmpty)); | stat.setToBePurchaseCount(CollUtil.count(projectPurchaseMap.values(), Collection::isEmpty)); | ||||
stat.setPurchaseFinishedCount(CollUtil.count(projectPurchaseMap.values(), | stat.setPurchaseFinishedCount(CollUtil.count(projectPurchaseMap.values(), | ||||
w -> CollUtil.anyMatch(w, x -> !TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO.eq(x.getStatus())))); | |||||
w -> !w.isEmpty() && CollUtil.allMatch(w, x -> !TenderMainStatus.TO_BE_SUBMIT_PURCHASE_CONSTRUCTION_INFO.eq(x.getStatus())))); | |||||
stat.setTotalCount(projects.size()); | stat.setTotalCount(projects.size()); | ||||
return stat; | return stat; | ||||
} | } | ||||
@@ -180,8 +180,8 @@ public class PurchaseManage { | |||||
query.exists(ExistsSqlConst.PROJECT_EXISTS_PURCHASE + | query.exists(ExistsSqlConst.PROJECT_EXISTS_PURCHASE + | ||||
" and np.status = {0} ", req.getTabStatus()); | " and np.status = {0} ", req.getTabStatus()); | ||||
} else if (TenderMainStatus.PURCHASE_FINISHED.eq(req.getTabStatus())) { | } else if (TenderMainStatus.PURCHASE_FINISHED.eq(req.getTabStatus())) { | ||||
query.exists(ExistsSqlConst.PROJECT_EXISTS_PURCHASE_STATUS_CHANGE + | |||||
" and npsc.event = {0} ", TenderStateChangeEvent.SUBMIT_PURCHASE_CONSTRUCTION_INFO); | |||||
query.exists(ExistsSqlConst.PROJECT_EXISTS_STATUS_CHANGE + | |||||
" and npsc.event = {0} ", ProjectStateChangeEvent.SUBMIT_PURCHASE_CONTRACT_RECORD); | |||||
} else if (ProjectStatus.TO_BE_PURCHASED.eq(req.getTabStatus())) { | } else if (ProjectStatus.TO_BE_PURCHASED.eq(req.getTabStatus())) { | ||||
query.eq(Project::getStatus, ProjectStatus.TO_BE_PURCHASED.getCode()); | query.eq(Project::getStatus, ProjectStatus.TO_BE_PURCHASED.getCode()); | ||||
} else { | } else { | ||||
@@ -540,7 +540,7 @@ public class PurchaseManage { | |||||
projectService.updateById(project); | projectService.updateById(project); | ||||
} | } | ||||
public AdaptionProgressStatVO adaptionProgressStatistics() { | |||||
public AdaptionProgressStatVO adaptionProgressStatistics(PurchaseAdaptionListReq req) { | |||||
LambdaQueryWrapper<Purchase> query = Wrappers.lambdaQuery(Purchase.class) | LambdaQueryWrapper<Purchase> query = Wrappers.lambdaQuery(Purchase.class) | ||||
.select(Purchase::getStatus, Purchase::getId) | .select(Purchase::getStatus, Purchase::getId) | ||||
.eq(Purchase::getBidType, BidTypeEnum.BUILD_APP.getCode()) | .eq(Purchase::getBidType, BidTypeEnum.BUILD_APP.getCode()) | ||||
@@ -554,6 +554,16 @@ public class PurchaseManage { | |||||
if (!purchaseService.buildPurchaseQueryPermission(query, user)) { | if (!purchaseService.buildPurchaseQueryPermission(query, user)) { | ||||
return null; | return null; | ||||
} | } | ||||
if (req.hasProjectQuery()) { | |||||
List<Long> projectIds = filterProjectIdsForPurchase(req); | |||||
if (projectIds.isEmpty()) { | |||||
return null; | |||||
} | |||||
query.in(Purchase::getProjectId, projectIds); | |||||
} | |||||
query.like(StrUtil.isNotBlank(req.getBidName()), Purchase::getBidName, req.getBidName()) | |||||
.le(req.getCreateOnMax() != null, Purchase::getCreateOn, req.getCreateOnMax()) | |||||
.ge(req.getCreateOnMin() != null, Purchase::getCreateOn, req.getCreateOnMin()); | |||||
List<Purchase> purchases = purchaseService.list(query); | List<Purchase> purchases = purchaseService.list(query); | ||||
return adaptionProgressStatistics(purchases); | return adaptionProgressStatistics(purchases); | ||||
} | } | ||||
@@ -69,7 +69,7 @@ public class SubmitPurchaseNoticeReq { | |||||
private String purchaseMethod; | private String purchaseMethod; | ||||
@ApiModelProperty("是否发布信创云图") | @ApiModelProperty("是否发布信创云图") | ||||
public Boolean publishMhNotice; | |||||
private Boolean publishMhNotice; | |||||
@ApiModelProperty("采购范围:1 公开采购、2 非公开采购") | @ApiModelProperty("采购范围:1 公开采购、2 非公开采购") | ||||
private Integer purchaseScope; | private Integer purchaseScope; | ||||
@@ -359,6 +359,21 @@ | |||||
<if test="req.status != null"> | <if test="req.status != null"> | ||||
and p.status = #{req.status} | and p.status = #{req.status} | ||||
</if> | </if> | ||||
<if test="req.stage != null"> | |||||
and p.stage = #{req.stage} | |||||
</if> | |||||
<if test="req.statusList != null and req.statusList.size > 0"> | |||||
and p.status in | |||||
<foreach collection="req.statusList" open="(" close=")" separator="," item="statusItem"> | |||||
#{statusItem} | |||||
</foreach> | |||||
</if> | |||||
<if test="req.stageList != null and req.stageList.size > 0"> | |||||
and p.stage in | |||||
<foreach collection="req.stageList" open="(" close=")" separator="," item="stageItem"> | |||||
#{stageItem} | |||||
</foreach> | |||||
</if> | |||||
<if test="req.projectYear != null"> | <if test="req.projectYear != null"> | ||||
and p.project_year = #{req.projectYear} | and p.project_year = #{req.projectYear} | ||||
</if> | </if> | ||||
@@ -29,6 +29,10 @@ public class UserInfoConvertor { | |||||
userInfoDetails.setMhUnitName(userFullInfo.getMhUnitName()); | userInfoDetails.setMhUnitName(userFullInfo.getMhUnitName()); | ||||
userInfoDetails.setMobile(userFullInfo.getMobile()); | userInfoDetails.setMobile(userFullInfo.getMobile()); | ||||
userInfoDetails.setMhUserId(userFullInfo.getMhUserId()); | userInfoDetails.setMhUserId(userFullInfo.getMhUserId()); | ||||
userInfoDetails.setIsCountyUser(userFullInfo.getIsCountyUser()); | |||||
userInfoDetails.setIsCitySoeUser(userFullInfo.getIsCitySoeUser()); | |||||
userInfoDetails.setIsCityDistrictUser(userFullInfo.getIsCityDistrictUser()); | |||||
userInfoDetails.setIsKeyIndustryUser(userFullInfo.getIsKeyIndustryUser()); | |||||
return userInfoDetails; | return userInfoDetails; | ||||
} | } | ||||
@@ -280,10 +280,7 @@ public class UserInfoManage { | |||||
resUserDetail.setStatus(userInfo.getAvailable()); | resUserDetail.setStatus(userInfo.getAvailable()); | ||||
resUserDetail.setEmployeeCode(userInfo.getEmployeeCode()); | resUserDetail.setEmployeeCode(userInfo.getEmployeeCode()); | ||||
resUserDetail.setMhUnitId(userInfo.getMhUnitId()); | resUserDetail.setMhUnitId(userInfo.getMhUnitId()); | ||||
UnitDTO unit = mhUnitCache.getById(userInfo.getMhUnitId()); | |||||
if (unit != null && unit.getType() != null) { | |||||
resUserDetail.setUnitStrip(unit.getType().getStrip().getCode()); | |||||
} | |||||
resUserDetail.setUnitStrip(userDetail.getUnitStrip()); | |||||
resUserDetail.setMhUnitName(userInfo.getMhUnitName()); | resUserDetail.setMhUnitName(userInfo.getMhUnitName()); | ||||
// 装配用户角色信息列表 | // 装配用户角色信息列表 | ||||
@@ -300,7 +297,10 @@ public class UserInfoManage { | |||||
}).collect(Collectors.toList()); | }).collect(Collectors.toList()); | ||||
resUserDetail.setUserRoleInfoList(userRoles); | resUserDetail.setUserRoleInfoList(userRoles); | ||||
} | } | ||||
resUserDetail.setIsCountyUser(userDetail.isCountyUser()); | |||||
resUserDetail.setIsCountyUser(userDetail.getIsCountyUser()); | |||||
resUserDetail.setIsCityDistrictUser(userDetail.getIsCityDistrictUser()); | |||||
resUserDetail.setIsCityDistrictUser(userDetail.getIsCitySoeUser()); | |||||
resUserDetail.setIsKeyIndustryUser(userDetail.getIsKeyIndustryUser()); | |||||
return resUserDetail; | return resUserDetail; | ||||
} | } | ||||
@@ -54,4 +54,19 @@ public class ResUserDetailVO { | |||||
@ApiModelProperty("是否是区县用户") | @ApiModelProperty("是否是区县用户") | ||||
private Boolean isCountyUser; | private Boolean isCountyUser; | ||||
/** | |||||
* 是否是市属国有企业用户 | |||||
*/ | |||||
private Boolean isCitySoeUser; | |||||
/** | |||||
* 是否是市级单位用户 | |||||
*/ | |||||
private Boolean isCityDistrictUser; | |||||
/** | |||||
* 是否是重点行业用户 | |||||
*/ | |||||
private Boolean isKeyIndustryUser; | |||||
} | } |
@@ -51,6 +51,27 @@ public class UserFullInfoDTO { | |||||
*/ | */ | ||||
private UserAvailableEnum available; | private UserAvailableEnum available; | ||||
/** | |||||
* 是否是区县用户 | |||||
*/ | |||||
private Boolean isCountyUser; | |||||
/** | |||||
* 是否是市属国有企业 | |||||
*/ | |||||
private Boolean isCitySoeUser; | |||||
/** | |||||
* 是否是市级单位 | |||||
*/ | |||||
private Boolean isCityDistrictUser; | |||||
/** | |||||
* 是否是重点行业 | |||||
*/ | |||||
private Boolean isKeyIndustryUser; | |||||
private Integer unitStrip; | |||||
/** | /** | ||||
* 取最高的权限 | * 取最高的权限 | ||||
@@ -57,6 +57,28 @@ public class UserInfoDetails extends AbstractLoginUser implements UserDetails { | |||||
private String mobile; | private String mobile; | ||||
/** | |||||
* 是否是区县用户 | |||||
*/ | |||||
private Boolean isCountyUser; | |||||
/** | |||||
* 是否是市属国有企业 | |||||
*/ | |||||
private Boolean isCitySoeUser; | |||||
/** | |||||
* 是否是市级单位 | |||||
*/ | |||||
private Boolean isCityDistrictUser; | |||||
/** | |||||
* 是否是重点行业 | |||||
*/ | |||||
private Boolean isKeyIndustryUser; | |||||
private Integer unitStrip; | |||||
public String getUserIdStr() { | public String getUserIdStr() { | ||||
return String.valueOf(getUserId()); | return String.valueOf(getUserId()); | ||||
} | } | ||||
@@ -424,7 +424,7 @@ public class WorkbenchManage { | |||||
currStat.setTargetCount(systemReplaceCount.getValue()); | currStat.setTargetCount(systemReplaceCount.getValue()); | ||||
List<String> projectCodes = CollUtils.convert(projectIds, ProjectIdCodeCacheUtil::get); | List<String> projectCodes = CollUtils.convert(projectIds, ProjectIdCodeCacheUtil::get); | ||||
currStat.setStoppedCount(stoppedProjectCount(projectStatusChangeMap, projectCodes)); | currStat.setStoppedCount(stoppedProjectCount(projectStatusChangeMap, projectCodes)); | ||||
if (!purchases.isEmpty()) { | |||||
if (!projectIds.isEmpty()) { | |||||
Wrapper<PurchaseStatusChange> pQuery = Wrappers.lambdaQuery(PurchaseStatusChange.class) | Wrapper<PurchaseStatusChange> pQuery = Wrappers.lambdaQuery(PurchaseStatusChange.class) | ||||
.select(PurchaseStatusChange::getEvent, PurchaseStatusChange::getProjectId) | .select(PurchaseStatusChange::getEvent, PurchaseStatusChange::getProjectId) | ||||
.in(PurchaseStatusChange::getProjectId, projectIds) | .in(PurchaseStatusChange::getProjectId, projectIds) | ||||
@@ -225,5 +225,7 @@ thread-pool-util: | |||||
scheduler: | scheduler: | ||||
core-pool-size: 2 | core-pool-size: 2 | ||||
thread-name-prefix: scheduler-executor- | thread-name-prefix: scheduler-executor- | ||||
early-warning-without-submit: | |||||
open: true | |||||
random-invite: | |||||
thread-pool-properties: | |||||
core-pool-size: 2 | |||||
thread-name-prefix: expert-invite-executor- |
@@ -248,5 +248,7 @@ wflow-thread-pool-util: | |||||
queue-capacity: 300 | queue-capacity: 300 | ||||
keep-alive-seconds: 120 | keep-alive-seconds: 120 | ||||
max-pool-size: 8 | max-pool-size: 8 | ||||
early-warning-without-submit: | |||||
open: true | |||||
random-invite: | |||||
thread-pool-properties: | |||||
core-pool-size: 3 | |||||
thread-name-prefix: expert-invite-executor- |
@@ -0,0 +1,46 @@ | |||||
package com.hz.pm.api.common; | |||||
import com.hz.pm.api.AppTests; | |||||
import com.hz.pm.api.common.statemachine.util.TenderStateMachineUtil; | |||||
import com.hz.pm.api.common.statemachine.util.XcfhxStateMachineUtil; | |||||
import com.hz.pm.api.common.util.ThreadPoolUtil; | |||||
import com.hz.pm.api.projectdeclared.model.entity.Purchase; | |||||
import org.junit.Test; | |||||
import org.springframework.beans.factory.annotation.Autowired; | |||||
import java.util.concurrent.CountDownLatch; | |||||
/** | |||||
* <p> | |||||
* StateMachineTest | |||||
* </p> | |||||
* | |||||
* @author WendyYang | |||||
* @since 19:43 2024/8/29 | |||||
*/ | |||||
public class StateMachineTest extends AppTests { | |||||
@Autowired | |||||
private TenderStateMachineUtil tenderStateMachineUtil; | |||||
@Autowired | |||||
private XcfhxStateMachineUtil xcfhxStateMachineUtil; | |||||
@Test | |||||
public void test() { | |||||
CountDownLatch count = new CountDownLatch(1000); | |||||
for (int j = 0; j < 100; j++) { | |||||
ThreadPoolUtil.REQUEST.execute(() -> { | |||||
Purchase purchase = new Purchase(); | |||||
purchase.setProjectId(3496L); | |||||
for (int i = 0; i < 5; i++) { | |||||
purchase.setBidType(i % 2 == 0 ? 2 : 1); | |||||
purchase.setStatus(101); | |||||
purchase.setXcfhxApplyStatus(301); | |||||
xcfhxStateMachineUtil.pass(purchase); | |||||
} | |||||
count.countDown(); | |||||
}); | |||||
} | |||||
} | |||||
} |
@@ -217,13 +217,11 @@ mh-system-replace-sync: | |||||
thread-pool-util: | thread-pool-util: | ||||
request: | request: | ||||
core-pool-size: 2 | |||||
max-pool-size: 4 | |||||
core-pool-size: 5 | |||||
max-pool-size: 10 | |||||
queue-capacity: 100 | queue-capacity: 100 | ||||
keep-alive-seconds: 120 | keep-alive-seconds: 120 | ||||
thread-name-prefix: request-executor- | thread-name-prefix: request-executor- | ||||
scheduler: | scheduler: | ||||
core-pool-size: 2 | core-pool-size: 2 | ||||
thread-name-prefix: scheduler-executor- | |||||
early-warning-without-submit: | |||||
open: true | |||||
thread-name-prefix: scheduler-executor- |
@@ -103,7 +103,7 @@ | |||||
<dependency> | <dependency> | ||||
<groupId>org.springframework.statemachine</groupId> | <groupId>org.springframework.statemachine</groupId> | ||||
<artifactId>spring-statemachine-core</artifactId> | <artifactId>spring-statemachine-core</artifactId> | ||||
<version>2.0.1.RELEASE</version> | |||||
<version>2.2.0.RELEASE</version> | |||||
</dependency> | </dependency> | ||||
<dependency> | <dependency> | ||||
<groupId>com.github.oshi</groupId> | <groupId>com.github.oshi</groupId> | ||||