PermissionOrgAspect.java 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. package jnpf.aop;
  2. import jnpf.constant.PermissionConstant;
  3. import jnpf.permission.entity.OrganizeEntity;
  4. import jnpf.permission.model.organize.OrganizeCrForm;
  5. import jnpf.permission.model.organize.OrganizeDepartCrForm;
  6. import jnpf.permission.model.organize.OrganizeDepartUpForm;
  7. import jnpf.permission.model.organize.OrganizeUpForm;
  8. import jnpf.permission.service.OrganizeService;
  9. import jnpf.util.PermissionAspectUtil;
  10. import jnpf.util.UserProvider;
  11. import lombok.extern.slf4j.Slf4j;
  12. import org.aspectj.lang.ProceedingJoinPoint;
  13. import org.aspectj.lang.annotation.Around;
  14. import org.aspectj.lang.annotation.Aspect;
  15. import org.aspectj.lang.annotation.Pointcut;
  16. import org.springframework.beans.factory.annotation.Autowired;
  17. import org.springframework.stereotype.Component;
  18. import java.util.StringJoiner;
  19. /**
  20. * @author JNPF开发平台组
  21. * @version V3.1.0
  22. * @copyright 引迈信息技术有限公司
  23. * @date 2021/3/15 17:12
  24. */
  25. @Slf4j
  26. @Aspect
  27. @Component
  28. public class PermissionOrgAspect implements PermissionAdminBase {
  29. @Autowired
  30. private OrganizeService organizeService;
  31. /**
  32. * 分级管理切点
  33. */
  34. @Pointcut("within(jnpf.*.controller.*) && @annotation(jnpf.annotation.OrganizePermission)")
  35. public void pointcut() {
  36. }
  37. /**
  38. * 分级管理切点
  39. *
  40. * @param pjp
  41. * @return
  42. * @throws Throwable
  43. */
  44. @Around("pointcut()")
  45. public Object around(ProceedingJoinPoint pjp) throws Throwable {
  46. return PermissionAdminBase.permissionCommon(pjp, this);
  47. }
  48. @Override
  49. public Boolean detailPermission(ProceedingJoinPoint pjp, String operatorUserId, String methodName) {
  50. switch (methodName) {
  51. case PermissionConstant.METHOD_CREATE:
  52. return PermissionAspectUtil.getPermitByOrgIds(
  53. // 操作目标对象表单对象
  54. ((OrganizeCrForm) pjp.getArgs()[0]).getParentId(),
  55. operatorUserId,
  56. PermissionConstant.METHOD_CREATE);
  57. case PermissionConstant.METHOD_CREATE_DEPARTMENT:
  58. return PermissionAspectUtil.getPermitByOrgIds(
  59. // 操作目标对象表单对象
  60. ((OrganizeDepartCrForm) pjp.getArgs()[0]).getParentId(),
  61. operatorUserId,
  62. PermissionConstant.METHOD_CREATE);
  63. case PermissionConstant.METHOD_UPDATE:
  64. // 当前组织id
  65. String orgId = (String) pjp.getArgs()[0];
  66. // 当前组织父级id
  67. OrganizeEntity info = organizeService.getInfo(orgId);
  68. // 修改后的id
  69. OrganizeUpForm organizeUpForm = (OrganizeUpForm) pjp.getArgs()[1];
  70. StringJoiner stringJoiner = new StringJoiner(",");
  71. stringJoiner.add(orgId);
  72. if (!organizeUpForm.getParentId().equals(info.getParentId()) && !"-1".equals(info.getParentId())) {
  73. stringJoiner.add(info.getParentId());
  74. }
  75. if (!organizeUpForm.getParentId().equals(info.getParentId()) && !"-1".equals(organizeUpForm.getParentId())) {
  76. stringJoiner.add(organizeUpForm.getParentId());
  77. }
  78. return PermissionAspectUtil.getPermitByOrgIds(
  79. // 操作目标对象ID
  80. stringJoiner.toString(),
  81. operatorUserId,
  82. PermissionConstant.METHOD_UPDATE);
  83. case PermissionConstant.METHOD_UPDATE_DEPARTMENT:
  84. // 当前组织id
  85. String orgIds = (String) pjp.getArgs()[0];
  86. // 当前组织父级id
  87. OrganizeEntity infos = organizeService.getInfo(orgIds);
  88. // 修改后的id
  89. OrganizeDepartUpForm organizeDepartUpForm = (OrganizeDepartUpForm) pjp.getArgs()[1];
  90. StringJoiner stringJoiners = new StringJoiner(",");
  91. stringJoiners.add(orgIds);
  92. if (!organizeDepartUpForm.getParentId().equals(infos.getParentId())) {
  93. stringJoiners.add(infos.getParentId());
  94. stringJoiners.add(organizeDepartUpForm.getParentId());
  95. }
  96. return PermissionAspectUtil.getPermitByOrgIds(
  97. // 操作目标对象ID
  98. stringJoiners.toString(),
  99. operatorUserId,
  100. PermissionConstant.METHOD_UPDATE);
  101. case PermissionConstant.METHOD_DELETE:
  102. case PermissionConstant.METHOD_DELETE_DEPARTMENT:
  103. return PermissionAspectUtil.getPermitByOrgIds(
  104. // 操作目标对象ID
  105. pjp.getArgs()[0].toString(),
  106. operatorUserId,
  107. PermissionConstant.METHOD_DELETE);
  108. default:
  109. return false;
  110. }
  111. }
  112. }