From d711c899e42e8cacee3ed6408f4c57e91c962dc8 Mon Sep 17 00:00:00 2001
From: zhubaomin <zhubaomin>
Date: 星期四, 17 四月 2025 17:03:10 +0800
Subject: [PATCH] 改正发布判断bug

---
 pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/aop/SsoPowerAspect.java |  144 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 144 insertions(+), 0 deletions(-)

diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/aop/SsoPowerAspect.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/aop/SsoPowerAspect.java
new file mode 100644
index 0000000..0458c3f
--- /dev/null
+++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/aop/SsoPowerAspect.java
@@ -0,0 +1,144 @@
+package com.dy.common.aop;
+
+import com.dy.common.contant.Constant;
+import com.dy.common.multiDataSource.DataSourceContext;
+import com.dy.common.webFilter.UserTokenContext;
+import com.dy.common.webUtil.BaseResponseUtils;
+import com.mysql.cj.util.StringUtils;
+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.aspectj.lang.reflect.MethodSignature;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.core.annotation.Order;
+import org.springframework.http.HttpEntity;
+import org.springframework.http.HttpHeaders;
+import org.springframework.http.HttpMethod;
+import org.springframework.http.ResponseEntity;
+import org.springframework.stereotype.Component;
+import org.springframework.web.client.RestTemplate;
+import org.springframework.web.util.UriComponentsBuilder;
+
+import java.lang.reflect.Method;
+import java.util.Objects;
+
+@Slf4j
+@Aspect
+@Order(Constant.AspectOrderSsoAutho)
+@Component
+public class SsoPowerAspect {
+
+    @Value("${pipIrr.global.dev}")
+    public String isDevStage ;//鏄惁涓哄紑鍙戦樁娈�
+
+    @Value("${pipIrr.sso.checkUrl}")
+    public String SsoCheckUrl ;
+
+    private RestTemplate restTemplate;
+
+    @Autowired
+    public void setRestTemplate(RestTemplate restTemplate){
+        this.restTemplate = restTemplate ;
+    }
+
+    @Pointcut("@annotation(com.dy.common.aop.SsoPowerAop)")
+    public void ssoPowerPointCut() {
+    }
+
+    @Around("ssoPowerPointCut()")
+    public Object execute(ProceedingJoinPoint point) throws Throwable {
+        if(isDevStage != null && !isDevStage.trim().equals("") && isDevStage.trim().equalsIgnoreCase("true")){
+            return point.proceed();
+        }else{
+            MethodSignature signature = (MethodSignature) point.getSignature();
+            Method method = signature.getMethod();
+            SsoPowerAop aop = method.getAnnotation(SsoPowerAop.class) ;
+            if (Objects.nonNull(aop)){
+                String power = aop.value() ;
+                if(power.trim().equals("")){
+                    power = aop.power() ;
+                }
+                if(power.trim().equals("-1")){
+                    //涓嶈繘琛岀櫥褰曞強鏉冮檺楠岃瘉
+                    return point.proceed();
+                }else{
+                    String[] allPower = aop.ifAllPower() ;
+                    String[] anyPower = aop.ifAnyPower() ;
+                    String token = UserTokenContext.get() ;
+                    Object rObj = this.check(token, power, allPower, anyPower);
+                    if(rObj != null){
+                        if(rObj instanceof SsoVo ssoVo){
+                            if(ssoVo.logined){
+                                if(ssoVo.hasPower){
+                                    if(!StringUtils.isNullOrEmpty(ssoVo.dataSourceName)){
+                                        DataSourceContext.set(ssoVo.dataSourceName);
+                                        Object obj = point.proceed();
+                                        DataSourceContext.remove();
+                                        return obj ;
+                                    }else{
+                                        //鏃犳暟鎹簮
+                                        return BaseResponseUtils.buildError("鍚庣绯荤粺鍑洪敊锛屾湭寰楀埌褰撳墠鐧诲綍鐢ㄦ埛鎵�灞炴満鏋勬爣绛撅紙鏁版嵁婧愬悕锛�") ;
+                                    }
+                                }else{
+                                    //鏃犳潈闄�
+                                    return BaseResponseUtils.buildNoPower() ;
+                                }
+                            }else{
+                                //鏈櫥褰�
+                                return BaseResponseUtils.buildToLogin() ;
+                            }
+                        }else{
+                            return rObj ;
+                        }
+                    }else{
+                        return BaseResponseUtils.buildError("鍚庣绯荤粺鍑洪敊锛宑heck鏂规硶杩斿洖null") ;
+                    }
+                }
+            }else{
+                //宸茬粡杩涘叆娉ㄨВ澶勭悊浜嗭紝杩樺緱涓嶅埌娉ㄨВ锛岃繖绉嶆儏鍐垫槸涓嶅彲鑳界殑銆�
+                return BaseResponseUtils.buildError("鍚庣绯荤粺鍑洪敊锛孌yAop娉ㄨВ涓簄ull") ;
+            }
+        }
+    }
+
+    /**
+     * 璋冪敤SSO绯荤粺杩涜楠岃瘉
+     * @param token Header涓殑鐢ㄦ埛token
+     * @param power 涓�涓潈闄�
+     * @param allPower 澶氫釜鏉冮檺
+     * @param anyPower 澶氫釜鏉冮檺
+     * @return 杩斿洖瀵硅薄
+     */
+    private Object check(String token, String power, String[] allPower, String[] anyPower){
+        if(!StringUtils.isNullOrEmpty(SsoCheckUrl)){
+            String url = UriComponentsBuilder.fromUriString(SsoCheckUrl)
+                    .queryParam("token", token)
+                    .queryParam("power", power)
+                    .queryParam("allPower", (Object) allPower)
+                    .queryParam("anyPower", (Object) anyPower)
+                    .build()
+                    .toUriString();
+            HttpHeaders headers = new HttpHeaders();
+            HttpEntity<?> httpEntity = new HttpEntity<>(headers);
+            ResponseEntity<SsoVo> response = null;
+            try {
+                // 閫氳繃Get鏂瑰紡璋冪敤鎺ュ彛
+                response = restTemplate.exchange(url, HttpMethod.GET, httpEntity, SsoVo.class);
+            } catch (Exception e) {
+                e.printStackTrace();
+                return BaseResponseUtils.buildError("鍚庣绯荤粺鍑洪敊锛岃闂崟鐐圭櫥褰曠郴缁熷紓甯�");
+            }
+            if(response == null){
+                return BaseResponseUtils.buildError("鍚庣绯荤粺鍑洪敊锛岃闂崟鐐圭櫥褰曠郴缁熷紓甯�");
+            }else{
+                return response.getBody();
+            }
+        }else {
+            return BaseResponseUtils.buildError("鍚庣绯荤粺鍑洪敊锛屾湭寰楀埌SsoCheckUrl");
+        }
+    }
+
+}

--
Gitblit v1.8.0