376f9e658c3f1d5e03fda1d7ad97ff09cc2c2d24.svn-base 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package org.jeecg.modules.system.service.impl;
  2. import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
  3. import org.jeecg.common.util.IPUtils;
  4. import org.jeecg.common.util.SpringContextUtils;
  5. import org.jeecg.common.util.oConvertUtils;
  6. import org.jeecg.modules.system.entity.SysDepartRolePermission;
  7. import org.jeecg.modules.system.mapper.SysDepartRolePermissionMapper;
  8. import org.jeecg.modules.system.service.ISysDepartRolePermissionService;
  9. import org.springframework.stereotype.Service;
  10. import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
  11. import javax.servlet.http.HttpServletRequest;
  12. import java.util.*;
  13. /**
  14. * @Description: 部门角色权限
  15. * @Author: jeecg-boot
  16. * @Date: 2020-02-12
  17. * @Version: V1.0
  18. */
  19. @Service
  20. public class SysDepartRolePermissionServiceImpl extends ServiceImpl<SysDepartRolePermissionMapper, SysDepartRolePermission> implements ISysDepartRolePermissionService {
  21. @Override
  22. public void saveDeptRolePermission(String roleId, String permissionIds, String lastPermissionIds) {
  23. String ip = "";
  24. try {
  25. //获取request
  26. HttpServletRequest request = SpringContextUtils.getHttpServletRequest();
  27. //获取IP地址
  28. ip = IPUtils.getIpAddr(request);
  29. } catch (Exception e) {
  30. ip = "127.0.0.1";
  31. }
  32. List<String> add = getDiff(lastPermissionIds,permissionIds);
  33. if(add!=null && add.size()>0) {
  34. List<SysDepartRolePermission> list = new ArrayList<SysDepartRolePermission>();
  35. for (String p : add) {
  36. if(oConvertUtils.isNotEmpty(p)) {
  37. SysDepartRolePermission rolepms = new SysDepartRolePermission(roleId, p);
  38. rolepms.setOperateDate(new Date());
  39. rolepms.setOperateIp(ip);
  40. list.add(rolepms);
  41. }
  42. }
  43. this.saveBatch(list);
  44. }
  45. List<String> delete = getDiff(permissionIds,lastPermissionIds);
  46. if(delete!=null && delete.size()>0) {
  47. for (String permissionId : delete) {
  48. this.remove(new QueryWrapper<SysDepartRolePermission>().lambda().eq(SysDepartRolePermission::getRoleId, roleId).eq(SysDepartRolePermission::getPermissionId, permissionId));
  49. }
  50. }
  51. }
  52. /**
  53. * 从diff中找出main中没有的元素
  54. * @param main
  55. * @param diff
  56. * @return
  57. */
  58. private List<String> getDiff(String main, String diff){
  59. if(oConvertUtils.isEmpty(diff)) {
  60. return null;
  61. }
  62. if(oConvertUtils.isEmpty(main)) {
  63. return Arrays.asList(diff.split(","));
  64. }
  65. String[] mainArr = main.split(",");
  66. String[] diffArr = diff.split(",");
  67. Map<String, Integer> map = new HashMap<>();
  68. for (String string : mainArr) {
  69. map.put(string, 1);
  70. }
  71. List<String> res = new ArrayList<String>();
  72. for (String key : diffArr) {
  73. if(oConvertUtils.isNotEmpty(key) && !map.containsKey(key)) {
  74. res.add(key);
  75. }
  76. }
  77. return res;
  78. }
  79. }