|  | @ -9,7 +9,9 @@ import com.epmet.commons.rocketmq.messages.GroupAchievementMQMsg; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.constant.AppClientConstant; |  |  | import com.epmet.commons.tools.constant.AppClientConstant; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.constant.FieldConstant; |  |  | import com.epmet.commons.tools.constant.FieldConstant; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.constant.NumConstant; |  |  | import com.epmet.commons.tools.constant.NumConstant; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | import com.epmet.commons.tools.distributedlock.DistributedLock; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.dto.result.CustomerStaffInfoCacheResult; |  |  | import com.epmet.commons.tools.dto.result.CustomerStaffInfoCacheResult; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | import com.epmet.commons.tools.enums.AchievementTypeEnum; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.enums.EventEnum; |  |  | import com.epmet.commons.tools.enums.EventEnum; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.exception.EpmetErrorCode; |  |  | import com.epmet.commons.tools.exception.EpmetErrorCode; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.exception.EpmetException; |  |  | import com.epmet.commons.tools.exception.EpmetException; | 
			
		
	
	
		
		
			
				
					|  | @ -41,7 +43,6 @@ import com.epmet.entity.IssueEntity; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.entity.IssueProcessEntity; |  |  | import com.epmet.entity.IssueProcessEntity; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.entity.IssueProjectRelationEntity; |  |  | import com.epmet.entity.IssueProjectRelationEntity; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.feign.*; |  |  | import com.epmet.feign.*; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.commons.tools.enums.AchievementTypeEnum; |  |  |  | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.redis.GovIssueRedis; |  |  | import com.epmet.redis.GovIssueRedis; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.redis.IssueVoteDetailRedis; |  |  | import com.epmet.redis.IssueVoteDetailRedis; | 
			
		
	
		
		
			
				
					|  |  | import com.epmet.resi.group.dto.group.form.AllIssueFormDTO; |  |  | import com.epmet.resi.group.dto.group.form.AllIssueFormDTO; | 
			
		
	
	
		
		
			
				
					|  | @ -62,6 +63,7 @@ import com.epmet.utils.ModuleConstants; | 
			
		
	
		
		
			
				
					|  |  | import com.github.pagehelper.PageHelper; |  |  | import com.github.pagehelper.PageHelper; | 
			
		
	
		
		
			
				
					|  |  | import com.github.pagehelper.PageInfo; |  |  | import com.github.pagehelper.PageInfo; | 
			
		
	
		
		
			
				
					|  |  | import org.apache.commons.collections4.CollectionUtils; |  |  | import org.apache.commons.collections4.CollectionUtils; | 
			
		
	
		
		
			
				
					|  |  |  |  |  | import org.redisson.api.RLock; | 
			
		
	
		
		
			
				
					|  |  | import org.slf4j.Logger; |  |  | import org.slf4j.Logger; | 
			
		
	
		
		
			
				
					|  |  | import org.slf4j.LoggerFactory; |  |  | import org.slf4j.LoggerFactory; | 
			
		
	
		
		
			
				
					|  |  | import org.springframework.beans.factory.annotation.Autowired; |  |  | import org.springframework.beans.factory.annotation.Autowired; | 
			
		
	
	
		
		
			
				
					|  | @ -136,6 +138,8 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  |     private GovProjectOpenFeignClient govProjectOpenFeignClient; |  |  |     private GovProjectOpenFeignClient govProjectOpenFeignClient; | 
			
		
	
		
		
			
				
					|  |  |     @Autowired |  |  |     @Autowired | 
			
		
	
		
		
			
				
					|  |  |     private IssueVoteDetailService issueVoteDetailService; |  |  |     private IssueVoteDetailService issueVoteDetailService; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     @Autowired | 
			
		
	
		
		
			
				
					|  |  |  |  |  |     private DistributedLock distributedLock; | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  | 	@Value("${openapi.scan.server.url}") |  |  | 	@Value("${openapi.scan.server.url}") | 
			
		
	
	
		
		
			
				
					|  | @ -957,24 +961,28 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  |      * @date 2020/12/9 10:01 |  |  |      * @date 2020/12/9 10:01 | 
			
		
	
		
		
			
				
					|  |  |      */ |  |  |      */ | 
			
		
	
		
		
			
				
					|  |  |     @Override |  |  |     @Override | 
			
		
	
		
		
			
				
					
					|  |  |     public void shiftProjectV2(ShiftProjectFormDTO formDTO) { |  |  |     public Result shiftProjectV2(ShiftProjectFormDTO formDTO) { | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |  |  |  |         RLock lock = null; | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         try { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             //获取锁,判断当前议题是否已处理
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             lock = distributedLock.tryLock(formDTO.getCustomerId() + formDTO.getIssueId()); | 
			
		
	
		
		
			
				
					|  |  |             //1:查询议题数据
 |  |  |             //1:查询议题数据
 | 
			
		
	
		
		
			
				
					|  |  |             IssueEntity entity = baseDao.selectById(formDTO.getIssueId()); |  |  |             IssueEntity entity = baseDao.selectById(formDTO.getIssueId()); | 
			
		
	
		
		
			
				
					|  |  |             if (null == entity) { |  |  |             if (null == entity) { | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(IssueConstant.SELECT_EXCEPTION); |  |  |                 throw new EpmetException(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(),IssueConstant.SELECT_EXCEPTION,IssueConstant.SELECT_EXCEPTION); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             if (IssueConstant.ISSUE_SHIFT_PROJECT.equals(entity.getIssueStatus())) { |  |  |             if (IssueConstant.ISSUE_SHIFT_PROJECT.equals(entity.getIssueStatus())) { | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(IssueConstant.ISSUE_SHIFT_PROJECT_EXCEPTION); |  |  |                 throw new EpmetException(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(),IssueConstant.ISSUE_SHIFT_PROJECT_EXCEPTION,IssueConstant.ISSUE_SHIFT_PROJECT_EXCEPTION); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             if (!IssueConstant.ISSUE_VOTING.equals(entity.getIssueStatus())) { |  |  |             if (!IssueConstant.ISSUE_VOTING.equals(entity.getIssueStatus())) { | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(IssueConstant.ISSUE_VOTING_EXCEPTION); |  |  |                 throw new EpmetException(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(),IssueConstant.ISSUE_VOTING_EXCEPTION,IssueConstant.ISSUE_VOTING_EXCEPTION); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             formDTO.setIssueDTO(ConvertUtils.sourceToTarget(entity, IssueDTO.class)); |  |  |             formDTO.setIssueDTO(ConvertUtils.sourceToTarget(entity, IssueDTO.class)); | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             //获取议题分类
 |  |  |             //获取议题分类
 | 
			
		
	
		
		
			
				
					|  |  |             List<IssueCategoryDTO> categoryList = issueCategoryService.getCategoryByIssue(formDTO.getIssueId()); |  |  |             List<IssueCategoryDTO> categoryList = issueCategoryService.getCategoryByIssue(formDTO.getIssueId()); | 
			
		
	
		
		
			
				
					|  |  |             if (CollectionUtils.isEmpty(categoryList)) { |  |  |             if (CollectionUtils.isEmpty(categoryList)) { | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(EpmetErrorCode.CATEGORY_IS_NULL.getCode()); |  |  |                 throw new EpmetException(EpmetErrorCode.CATEGORY_IS_NULL.getCode(),EpmetErrorCode.CATEGORY_IS_NULL.getMsg(),EpmetErrorCode.CATEGORY_IS_NULL.getMsg()); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             //公开回复内容审核
 |  |  |             //公开回复内容审核
 | 
			
		
	
	
		
		
			
				
					|  | @ -986,10 +994,10 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  |                 textScanParamDTO.getTasks().add(taskDTO); |  |  |                 textScanParamDTO.getTasks().add(taskDTO); | 
			
		
	
		
		
			
				
					|  |  |                 Result<SyncScanResult> textSyncScanResult = ScanContentUtils.textSyncScan(scanApiUrl.concat(textSyncScanMethod), textScanParamDTO); |  |  |                 Result<SyncScanResult> textSyncScanResult = ScanContentUtils.textSyncScan(scanApiUrl.concat(textSyncScanMethod), textScanParamDTO); | 
			
		
	
		
		
			
				
					|  |  |                 if (!textSyncScanResult.success()) { |  |  |                 if (!textSyncScanResult.success()) { | 
			
		
	
		
		
			
				
					
					|  |  |                 throw new RenException(EpmetErrorCode.SERVER_ERROR.getCode()); |  |  |                     throw new EpmetException(EpmetErrorCode.SERVER_ERROR.getCode(),EpmetErrorCode.SERVER_ERROR.getMsg(),EpmetErrorCode.SERVER_ERROR.getMsg()); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                 } else { |  |  |                 } else { | 
			
		
	
		
		
			
				
					|  |  |                     if (!textSyncScanResult.getData().isAllPass()) { |  |  |                     if (!textSyncScanResult.getData().isAllPass()) { | 
			
		
	
		
		
			
				
					
					|  |  |                     throw new RenException(EpmetErrorCode.TEXT_SCAN_FAILED.getCode()); |  |  |                         throw new EpmetException(EpmetErrorCode.TEXT_SCAN_FAILED.getCode(),EpmetErrorCode.TEXT_SCAN_FAILED.getMsg(),EpmetErrorCode.TEXT_SCAN_FAILED.getMsg()); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |                     } |  |  |                     } | 
			
		
	
		
		
			
				
					|  |  |                 } |  |  |                 } | 
			
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
	
		
		
			
				
					|  | @ -999,7 +1007,7 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  |             //2:调用resi-group查询话题创建人数据(目前议题来源只有来自话题),为了到项目服务初始数据以及发送消息使用
 |  |  |             //2:调用resi-group查询话题创建人数据(目前议题来源只有来自话题),为了到项目服务初始数据以及发送消息使用
 | 
			
		
	
		
		
			
				
					|  |  |             Result<ResiTopicDTO> resultTopicDTO = resiGroupFeignClient.getTopicById(entity.getSourceId()); |  |  |             Result<ResiTopicDTO> resultTopicDTO = resiGroupFeignClient.getTopicById(entity.getSourceId()); | 
			
		
	
		
		
			
				
					|  |  |             if (!resultTopicDTO.success() || null == resultTopicDTO.getData()) { |  |  |             if (!resultTopicDTO.success() || null == resultTopicDTO.getData()) { | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(IssueConstant.SELECT_TOPIC_EXCEPTION); |  |  |                 throw new EpmetException(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(),IssueConstant.SELECT_TOPIC_EXCEPTION,IssueConstant.SELECT_TOPIC_EXCEPTION); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             ResiTopicDTO topicDTO = resultTopicDTO.getData(); |  |  |             ResiTopicDTO topicDTO = resultTopicDTO.getData(); | 
			
		
	
		
		
			
				
					|  |  |             formDTO.setTopicDTO(topicDTO); |  |  |             formDTO.setTopicDTO(topicDTO); | 
			
		
	
	
		
		
			
				
					|  | @ -1011,7 +1019,7 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  |             Result<IssueProjectResultDTO> resultDTO = govProjectFeignClient.issueShiftProject(formDTO); |  |  |             Result<IssueProjectResultDTO> resultDTO = govProjectFeignClient.issueShiftProject(formDTO); | 
			
		
	
		
		
			
				
					|  |  |             if (!resultDTO.success() || null == resultDTO.getData()) { |  |  |             if (!resultDTO.success() || null == resultDTO.getData()) { | 
			
		
	
		
		
			
				
					|  |  |                 logger.error(resultDTO.getInternalMsg()); |  |  |                 logger.error(resultDTO.getInternalMsg()); | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(IssueConstant.GOV_PRJECT_EXCEPTION); |  |  |                 throw new EpmetException(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(),IssueConstant.GOV_PRJECT_EXCEPTION,IssueConstant.GOV_PRJECT_EXCEPTION); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             IssueProjectResultDTO issueProjectResultDTO = resultDTO.getData(); |  |  |             IssueProjectResultDTO issueProjectResultDTO = resultDTO.getData(); | 
			
		
	
		
		
			
				
					|  |  |             //更新项目对标签的引用次数
 |  |  |             //更新项目对标签的引用次数
 | 
			
		
	
	
		
		
			
				
					|  | @ -1046,7 +1054,7 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             //5:调用epmet-message服务,给居民端话题创建人、议题发起人以及政府端工作人员发送消息
 |  |  |             //5:调用epmet-message服务,给居民端话题创建人、议题发起人以及政府端工作人员发送消息
 | 
			
		
	
		
		
			
				
					|  |  |             if (!shiftProjectMessage(issueProjectResultDTO, formDTO, entity).success()) { |  |  |             if (!shiftProjectMessage(issueProjectResultDTO, formDTO, entity).success()) { | 
			
		
	
		
		
			
				
					
					|  |  |             throw new RenException(IssueConstant.SAVE_MSG_EXCEPTION); |  |  |                 throw new EpmetException(EpmetErrorCode.EPMET_COMMON_OPERATION_FAIL.getCode(),IssueConstant.SAVE_MSG_EXCEPTION,IssueConstant.SAVE_MSG_EXCEPTION); | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					|  |  |             } |  |  |             } | 
			
		
	
		
		
			
				
					|  |  |             //5-1:2020.10.26  添加给居民端话题创建人、议题发起人以及政府端工作人员推送微信订阅消息功能  sun
 |  |  |             //5-1:2020.10.26  添加给居民端话题创建人、议题发起人以及政府端工作人员推送微信订阅消息功能  sun
 | 
			
		
	
		
		
			
				
					|  |  |             if (!wxmpShiftProjectMessage(issueProjectResultDTO, formDTO, entity).success()) { |  |  |             if (!wxmpShiftProjectMessage(issueProjectResultDTO, formDTO, entity).success()) { | 
			
		
	
	
		
		
			
				
					|  | @ -1078,6 +1086,13 @@ public class IssueServiceImpl extends BaseServiceImpl<IssueDao, IssueEntity> imp | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |             //8.记录日志
 |  |  |             //8.记录日志
 | 
			
		
	
		
		
			
				
					|  |  |             //SendMqMsgUtil.build().openFeignClient(messageOpenFeignClient).sendProjectChangedMqMsg();
 |  |  |             //SendMqMsgUtil.build().openFeignClient(messageOpenFeignClient).sendProjectChangedMqMsg();
 | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             return new Result(); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         } catch (Exception e) { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             return new Result().error(e.getMessage()); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         } finally { | 
			
		
	
		
		
			
				
					|  |  |  |  |  |             distributedLock.unLock(lock); | 
			
		
	
		
		
			
				
					|  |  |  |  |  |         } | 
			
		
	
		
		
			
				
					|  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     } |  |  |     } | 
			
		
	
		
		
			
				
					|  |  | 
 |  |  | 
 | 
			
		
	
		
		
			
				
					|  |  |     /** |  |  |     /** | 
			
		
	
	
		
		
			
				
					|  | 
 |