|
|
@@ -0,0 +1,89 @@
|
|
|
+package com.lc.ibps.platform.service;
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+import com.lc.ibps.platform.dao.PartyRoleProviderDao;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
+
|
|
|
+import java.util.Arrays;
|
|
|
+import java.util.List;
|
|
|
+import java.util.stream.Collectors;
|
|
|
+import java.util.stream.Stream;
|
|
|
+
|
|
|
+@Service
|
|
|
+public class PartyRoleProviderService {
|
|
|
+
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ PartyRoleProviderDao partyRoleProviderDao;
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 增加用户角色
|
|
|
+ * 仅限于更新IBPS_PARTY_EMPLOYEE表的JOB_字段内容
|
|
|
+ * @param roleId 角色编号
|
|
|
+ * @param userIds 用户编号
|
|
|
+ */
|
|
|
+ public void addUserRoleForJob(String roleId, String[] userIds){
|
|
|
+ /*
|
|
|
+ 传入用户id,通过查询IBPS_PARTY_EMPLOYEE表的ID_字段,查询出该用户的JOB_字段内容。
|
|
|
+ JOB_字段内容为多个角色id(roleId)用逗号拼接而成。
|
|
|
+ 判断JOB_字段是否包含该roleId,如果不包含,则拼接上新的roleId,并更IBPS_PARTY_EMPLOYEE表的该用户的JOB_字段
|
|
|
+ */
|
|
|
+ for (String userId : userIds) {
|
|
|
+ String jobs = new String();
|
|
|
+ //通过用户id,查询出JOB_字段内容(即该用户所属角色)
|
|
|
+ List<String> jobList = partyRoleProviderDao.getUserRoleJobByUserId(userId);
|
|
|
+ //如果该用户已有角色,则拼接上新的角色编号
|
|
|
+ if(null != jobList && !jobList.isEmpty()){
|
|
|
+ //JOB_字段内容为多个角色id(roleId)用逗号拼接而成,转成list
|
|
|
+ List<String> list = Stream.of(jobList.get(0).split(",")).collect(Collectors.toList());
|
|
|
+ //判断新增的角色编号是否已经有重复,避免重复拼接
|
|
|
+ if(!list.contains(roleId)){
|
|
|
+ list.add(roleId);
|
|
|
+ }
|
|
|
+ jobs = String.join(",",list);
|
|
|
+
|
|
|
+ }else {
|
|
|
+ //如果该用户还没有任何角色,则直接更新为JOB_字段内容
|
|
|
+ jobs = roleId;
|
|
|
+ }
|
|
|
+
|
|
|
+ //更新IBPS_PARTY_EMPLOYEE表的JOB_字段
|
|
|
+ partyRoleProviderDao.updateUserRoleJobByUserId(userId,jobs);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 删除用户角色
|
|
|
+ * 仅限于更新IBPS_PARTY_EMPLOYEE表的JOB_字段内容
|
|
|
+ * @param roleId 角色编号
|
|
|
+ * @param userIds 用户编号
|
|
|
+ */
|
|
|
+ public void deleteUserRoleForJob(String roleId, String[] userIds){
|
|
|
+ /*
|
|
|
+ 传入用户id,通过查询IBPS_PARTY_EMPLOYEE表的ID_字段,查询出该用户的JOB_字段内容。
|
|
|
+ JOB_字段内容为多个角色id(roleId)用逗号拼接而成。
|
|
|
+ 判断JOB_字段是否包含该roleId,如果包含,则删除该roleId,并更IBPS_PARTY_EMPLOYEE表的该用户的JOB_字段
|
|
|
+ */
|
|
|
+ for (String userId : userIds) {
|
|
|
+ String jobs = new String();
|
|
|
+ //通过用户id,查询出JOB_字段内容(即该用户所属角色)
|
|
|
+ List<String> jobList = partyRoleProviderDao.getUserRoleJobByUserId(userId);
|
|
|
+ //如果该用户已有角色,则删除对应的角色
|
|
|
+ if(null != jobList && !jobList.isEmpty()){
|
|
|
+ //JOB_字段内容为多个角色id(roleId)用逗号拼接而成,转成list
|
|
|
+ List<String> list = Stream.of(jobList.get(0).split(",")).collect(Collectors.toList());
|
|
|
+ if(list.contains(roleId)){
|
|
|
+ list.remove(roleId);
|
|
|
+ }
|
|
|
+ jobs = String.join(",",list);
|
|
|
+ }
|
|
|
+
|
|
|
+ //更新IBPS_PARTY_EMPLOYEE表的JOB_字段
|
|
|
+ partyRoleProviderDao.updateUserRoleJobByUserId(userId,jobs);
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|