Commit 1a19b06c authored by hcing's avatar hcing

fix(tcm): 绑定系统账号,按照人员类型,添加风险报送员的角色

parent 9564c118
...@@ -12,6 +12,7 @@ public enum PersonManageRoleEnum { ...@@ -12,6 +12,7 @@ public enum PersonManageRoleEnum {
/** /**
* 人员管理角色枚举 * 人员管理角色枚举
*/ */
// 业务办理人员 -> 6616
code("人员管理角色字典code", 6616L), code("人员管理角色字典code", 6616L),
use("使用单位", 1735591519093547010L), use("使用单位", 1735591519093547010L),
...@@ -23,7 +24,13 @@ public enum PersonManageRoleEnum { ...@@ -23,7 +24,13 @@ public enum PersonManageRoleEnum {
// jyjc("检验检测机构", 1735590873120399362L); // jyjc("检验检测机构", 1735590873120399362L);
jyjg("检验机构", 1947231335688990722L), jyjg("检验机构", 1947231335688990722L),
jcjg("检测机构", 1947231362847109122L); jcjg("检测机构", 1947231362847109122L),
/**
* 风险报送员
*/
risk_code("风险报送员", 6766L),
fxbsy("风险报送员", 1953650773397106689L);
String name; String name;
Long id; Long id;
......
...@@ -530,11 +530,17 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -530,11 +530,17 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
// 添加人员管理角色 // 添加人员管理角色
String post = tzsUserInfo.getPost(); String newPostStr = tzsUserInfo.getNewPost();
if (post.contains(PersonManageRoleEnum.code.getId().toString())) { if (newPostStr != null) {
JSONArray newPost = JSON.parseArray(newPostStr);
if (newPost.contains(PersonManageRoleEnum.code.getId().toString())) {
String companyType = tzsUserInfoMapper.selectCompanyTypeById(companySeq); String companyType = tzsUserInfoMapper.selectCompanyTypeById(companySeq);
setBizOperateUserRole(companyType, roleIds); setBizOperateUserRole(companyType, roleIds);
} }
if (newPost.contains(PersonManageRoleEnum.risk_code.getId().toString())) {
setBizOperateUserRoleWithPost(newPost, roleIds);
}
}
Map<Long, List<Long>> roleSeqMap = new HashMap<>(); Map<Long, List<Long>> roleSeqMap = new HashMap<>();
Map<Long, List<RoleModel>> orgRoles = new HashMap<>(); Map<Long, List<RoleModel>> orgRoles = new HashMap<>();
...@@ -558,8 +564,8 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -558,8 +564,8 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
Privilege.groupUserClient.create(Long.valueOf(roleGroup.getExtend()), userIds); Privilege.groupUserClient.create(Long.valueOf(roleGroup.getExtend()), userIds);
} }
// 绑定两个规定用户组 // 绑定两个规定用户组
post = post.replace("[", "").replace("]", "").replace("\"", ""); newPostStr = newPostStr.replace("[", "").replace("]", "").replace("\"", "");
for (String code : post.split(",")) { for (String code : newPostStr.split(",")) {
bind2PermissionGroup(userIds, code); bind2PermissionGroup(userIds, code);
} }
tzsUserInfoMapper.updateById(tzsUserInfo); tzsUserInfoMapper.updateById(tzsUserInfo);
...@@ -2098,10 +2104,16 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -2098,10 +2104,16 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
agencyUserModel.setMobile(tzsUserInfo.getPhone()); agencyUserModel.setMobile(tzsUserInfo.getPhone());
agencyUserModel.setEmail(tzsUserInfo.getEmail()); agencyUserModel.setEmail(tzsUserInfo.getEmail());
// 添加业务办理人员角色 // 添加业务办理人员角色
String post = tzsUserInfo.getPost(); String newPostStr = tzsUserInfo.getNewPost();
if (post.contains(PersonManageRoleEnum.code.getId().toString())) { if (newPostStr != null) {
JSONArray newPost = JSON.parseArray(newPostStr);
if (newPost.contains(PersonManageRoleEnum.code.getId().toString())) {
setBizOperateUserRole(companyType, roleIds); setBizOperateUserRole(companyType, roleIds);
} }
if (newPost.contains(PersonManageRoleEnum.risk_code.getId().toString())) {
setBizOperateUserRoleWithPost(newPost, roleIds);
}
}
Map<Long, List<Long>> roleSeqMap = new HashMap<>(); Map<Long, List<Long>> roleSeqMap = new HashMap<>();
Map<Long, List<RoleModel>> orgRoles = new HashMap<>(); Map<Long, List<RoleModel>> orgRoles = new HashMap<>();
roleSeqMap.put(companyModel.getSequenceNbr(), roleIds); roleSeqMap.put(companyModel.getSequenceNbr(), roleIds);
...@@ -2455,14 +2467,20 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -2455,14 +2467,20 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
} }
}); });
// 添加人员管理角色 // 添加人员管理角色
String post = tzsUserInfoDto.getPost(); String newPostStr = tzsUserInfoDto.getNewPost();
if (post != null && post.contains(PersonManageRoleEnum.code.getId().toString())) { if (newPostStr != null) {
JSONArray newPost = JSON.parseArray(newPostStr);
if (newPost.contains(PersonManageRoleEnum.code.getId().toString())) {
CompanyModel companyModel = Optional.ofNullable(Privilege.companyClient.seleteOne(companySeq)).map(FeignClientResult::getResult).orElse(null); CompanyModel companyModel = Optional.ofNullable(Privilege.companyClient.seleteOne(companySeq)).map(FeignClientResult::getResult).orElse(null);
if (!ValidationUtil.isEmpty(companyModel)) { if (!ValidationUtil.isEmpty(companyModel)) {
String companyType = companyModel.getCompanyType(); String companyType = companyModel.getCompanyType();
setBizOperateUserRole(companyType, roleIds); setBizOperateUserRole(companyType, roleIds);
} }
} }
if (newPost.contains(PersonManageRoleEnum.risk_code.getId().toString())) {
setBizOperateUserRoleWithPost(newPost, roleIds);
}
}
Map<Long, List<Long>> roleSeqMap = new HashMap<>(); Map<Long, List<Long>> roleSeqMap = new HashMap<>();
Map<Long, List<RoleModel>> orgRoles = new HashMap<>(); Map<Long, List<RoleModel>> orgRoles = new HashMap<>();
roleSeqMap.put(companySeq, roleIds); roleSeqMap.put(companySeq, roleIds);
...@@ -2482,10 +2500,10 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -2482,10 +2500,10 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
if (!ObjectUtils.isEmpty(roleGroup) && roleGroup.getExtend() != null) { if (!ObjectUtils.isEmpty(roleGroup) && roleGroup.getExtend() != null) {
Privilege.groupUserClient.create(Long.valueOf(roleGroup.getExtend()), userIds); Privilege.groupUserClient.create(Long.valueOf(roleGroup.getExtend()), userIds);
} }
if (post != null) { if (newPostStr != null) {
// 绑定两个规定用户组 // 绑定两个规定用户组
post = post.replace("[", "").replace("]", "").replace("\"", ""); newPostStr = newPostStr.replace("[", "").replace("]", "").replace("\"", "");
for (String code : post.split(",")) { for (String code : newPostStr.split(",")) {
DataDictionary groupId = iDataDictionaryService.getOne(new LambdaQueryWrapper<DataDictionary>().eq(DataDictionary::getCode, code).likeRight(DataDictionary::getType, QYRYGW)); DataDictionary groupId = iDataDictionaryService.getOne(new LambdaQueryWrapper<DataDictionary>().eq(DataDictionary::getCode, code).likeRight(DataDictionary::getType, QYRYGW));
if (!ObjectUtils.isEmpty(groupId) && groupId.getExtend() != null) { if (!ObjectUtils.isEmpty(groupId) && groupId.getExtend() != null) {
Privilege.groupUserClient.deleteGroupUser(Long.valueOf(groupId.getExtend()), userResult.getResult().getUserId()); Privilege.groupUserClient.deleteGroupUser(Long.valueOf(groupId.getExtend()), userResult.getResult().getUserId());
...@@ -2496,6 +2514,12 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -2496,6 +2514,12 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
} }
} }
private void setBizOperateUserRoleWithPost(JSONArray newPost, List<Long> roleIds) {
if (newPost.contains(PersonManageRoleEnum.risk_code.getId().toString())) {
roleIds.add(PersonManageRoleEnum.fxbsy.getId());
}
}
public void refreshAdminUserRole(List<TzsUserInfo> userInfos, List<String> userId) { public void refreshAdminUserRole(List<TzsUserInfo> userInfos, List<String> userId) {
List<String> adminUserIdList; List<String> adminUserIdList;
if (ValidationUtil.isEmpty(userInfos)) { if (ValidationUtil.isEmpty(userInfos)) {
...@@ -2628,10 +2652,11 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI ...@@ -2628,10 +2652,11 @@ public class TzsUserInfoServiceImpl extends BaseService<TzsUserInfoDto, TzsUserI
// 监管查询自己单位下 + 管辖辖区下的数据 // 监管查询自己单位下 + 管辖辖区下的数据
if (companyType.equals(BaseController.COMPANY_TYPE_SUPERVISION)) { if (companyType.equals(BaseController.COMPANY_TYPE_SUPERVISION)) {
// 和综合统计处查询逻辑保持一致
BoolQueryBuilder meBuilder = QueryBuilders.boolQuery(); BoolQueryBuilder meBuilder = QueryBuilders.boolQuery();
meBuilder.should(QueryBuilders.termQuery("unitCode", company.getCompanyCode())); // meBuilder.should(QueryBuilders.termQuery("unitCode", company.getCompanyCode()));
meBuilder.should(QueryBuilders.prefixQuery("superviseOrgCode", company.getOrgCode())); meBuilder.must(QueryBuilders.prefixQuery("superviseOrgCode", company.getOrgCode()));
meBuilder.minimumShouldMatch(1); // meBuilder.minimumShouldMatch(1);
boolMust.must(meBuilder); boolMust.must(meBuilder);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment