| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119 |
- package jnpf.aop;
- import jnpf.constant.PermissionConstant;
- import jnpf.permission.entity.OrganizeEntity;
- import jnpf.permission.model.organize.OrganizeCrForm;
- import jnpf.permission.model.organize.OrganizeDepartCrForm;
- import jnpf.permission.model.organize.OrganizeDepartUpForm;
- import jnpf.permission.model.organize.OrganizeUpForm;
- import jnpf.permission.service.OrganizeService;
- import jnpf.util.PermissionAspectUtil;
- import jnpf.util.UserProvider;
- import lombok.extern.slf4j.Slf4j;
- import org.aspectj.lang.ProceedingJoinPoint;
- import org.aspectj.lang.annotation.Around;
- import org.aspectj.lang.annotation.Aspect;
- import org.aspectj.lang.annotation.Pointcut;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Component;
- import java.util.StringJoiner;
- /**
- * @author JNPF开发平台组
- * @version V3.1.0
- * @copyright 引迈信息技术有限公司
- * @date 2021/3/15 17:12
- */
- @Slf4j
- @Aspect
- @Component
- public class PermissionOrgAspect implements PermissionAdminBase {
- @Autowired
- private OrganizeService organizeService;
- /**
- * 分级管理切点
- */
- @Pointcut("within(jnpf.*.controller.*) && @annotation(jnpf.annotation.OrganizePermission)")
- public void pointcut() {
- }
- /**
- * 分级管理切点
- *
- * @param pjp
- * @return
- * @throws Throwable
- */
- @Around("pointcut()")
- public Object around(ProceedingJoinPoint pjp) throws Throwable {
- return PermissionAdminBase.permissionCommon(pjp, this);
- }
- @Override
- public Boolean detailPermission(ProceedingJoinPoint pjp, String operatorUserId, String methodName) {
- switch (methodName) {
- case PermissionConstant.METHOD_CREATE:
- return PermissionAspectUtil.getPermitByOrgIds(
- // 操作目标对象表单对象
- ((OrganizeCrForm) pjp.getArgs()[0]).getParentId(),
- operatorUserId,
- PermissionConstant.METHOD_CREATE);
- case PermissionConstant.METHOD_CREATE_DEPARTMENT:
- return PermissionAspectUtil.getPermitByOrgIds(
- // 操作目标对象表单对象
- ((OrganizeDepartCrForm) pjp.getArgs()[0]).getParentId(),
- operatorUserId,
- PermissionConstant.METHOD_CREATE);
- case PermissionConstant.METHOD_UPDATE:
- // 当前组织id
- String orgId = (String) pjp.getArgs()[0];
- // 当前组织父级id
- OrganizeEntity info = organizeService.getInfo(orgId);
- // 修改后的id
- OrganizeUpForm organizeUpForm = (OrganizeUpForm) pjp.getArgs()[1];
- StringJoiner stringJoiner = new StringJoiner(",");
- stringJoiner.add(orgId);
- if (!organizeUpForm.getParentId().equals(info.getParentId()) && !"-1".equals(info.getParentId())) {
- stringJoiner.add(info.getParentId());
- }
- if (!organizeUpForm.getParentId().equals(info.getParentId()) && !"-1".equals(organizeUpForm.getParentId())) {
- stringJoiner.add(organizeUpForm.getParentId());
- }
- return PermissionAspectUtil.getPermitByOrgIds(
- // 操作目标对象ID
- stringJoiner.toString(),
- operatorUserId,
- PermissionConstant.METHOD_UPDATE);
- case PermissionConstant.METHOD_UPDATE_DEPARTMENT:
- // 当前组织id
- String orgIds = (String) pjp.getArgs()[0];
- // 当前组织父级id
- OrganizeEntity infos = organizeService.getInfo(orgIds);
- // 修改后的id
- OrganizeDepartUpForm organizeDepartUpForm = (OrganizeDepartUpForm) pjp.getArgs()[1];
- StringJoiner stringJoiners = new StringJoiner(",");
- stringJoiners.add(orgIds);
- if (!organizeDepartUpForm.getParentId().equals(infos.getParentId())) {
- stringJoiners.add(infos.getParentId());
- stringJoiners.add(organizeDepartUpForm.getParentId());
- }
- return PermissionAspectUtil.getPermitByOrgIds(
- // 操作目标对象ID
- stringJoiners.toString(),
- operatorUserId,
- PermissionConstant.METHOD_UPDATE);
- case PermissionConstant.METHOD_DELETE:
- case PermissionConstant.METHOD_DELETE_DEPARTMENT:
- return PermissionAspectUtil.getPermitByOrgIds(
- // 操作目标对象ID
- pjp.getArgs()[0].toString(),
- operatorUserId,
- PermissionConstant.METHOD_DELETE);
- default:
- return false;
- }
- }
- }
|