From 6345b8cc443017bedf11d7a682babb89519cbab0 Mon Sep 17 00:00:00 2001
From: Yueng <14617246+YuengMeYuuer@user.noreply.gitee.com>
Date: Fri, 9 Aug 2024 19:38:41 +0800
Subject: [PATCH] =?UTF-8?q?=E5=88=9D=E5=A7=8B=E5=8C=96?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.gitignore | 35 +++++++++++++
pom.xml | 29 +++++++++++
.../nacos/remote/NacosServiceRemote.java | 27 ++++++++++
.../NacosNamespaceInterceptor.java | 50 +++++++++++++++++++
.../muyu/common/nacos/remote/req/BaseReq.java | 26 ++++++++++
.../nacos/remote/req/ServiceListReq.java | 38 ++++++++++++++
.../nacos/remote/resp/ServiceListResp.java | 34 +++++++++++++
...ot.autoconfigure.AutoConfiguration.imports | 1 +
8 files changed, 240 insertions(+)
create mode 100644 .gitignore
create mode 100644 pom.xml
create mode 100644 src/main/java/com/muyu/common/nacos/remote/NacosServiceRemote.java
create mode 100644 src/main/java/com/muyu/common/nacos/remote/interceptor/NacosNamespaceInterceptor.java
create mode 100644 src/main/java/com/muyu/common/nacos/remote/req/BaseReq.java
create mode 100644 src/main/java/com/muyu/common/nacos/remote/req/ServiceListReq.java
create mode 100644 src/main/java/com/muyu/common/nacos/remote/resp/ServiceListResp.java
create mode 100644 src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..3e403e3
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,35 @@
+target/
+!.mvn/wrapper/maven-wrapper.jar
+!**/src/main/**/target/
+!**/src/test/**/target/
+
+### IntelliJ IDEA ###
+.idea
+*.iws
+*.iml
+*.ipr
+
+### Eclipse ###
+.apt_generated
+.classpath
+.factorypath
+.project
+.settings
+.springBeans
+.sts4-cache
+
+### NetBeans ###
+/nbproject/private/
+/nbbuild/
+/dist/
+/nbdist/
+/.nb-gradle/
+build/
+!**/src/main/**/build/
+!**/src/test/**/build/
+
+### VS Code ###
+.vscode/
+
+### Mac OS ###
+.DS_Store
diff --git a/pom.xml b/pom.xml
new file mode 100644
index 0000000..cad9209
--- /dev/null
+++ b/pom.xml
@@ -0,0 +1,29 @@
+
+
+ 4.0.0
+
+
+ com.muyu
+ cloud-common
+ 3.6.3
+
+ com.moyu
+ cloud-common-nacos-remote
+ 1.0.0
+
+
+ 17
+ 17
+ UTF-8
+
+
+
+
+
+ com.muyu
+ cloud-common-core
+
+
+
diff --git a/src/main/java/com/muyu/common/nacos/remote/NacosServiceRemote.java b/src/main/java/com/muyu/common/nacos/remote/NacosServiceRemote.java
new file mode 100644
index 0000000..1a6fa93
--- /dev/null
+++ b/src/main/java/com/muyu/common/nacos/remote/NacosServiceRemote.java
@@ -0,0 +1,27 @@
+package com.muyu.common.nacos.remote;
+
+import com.dtflys.forest.annotation.BaseRequest;
+import com.dtflys.forest.annotation.Body;
+import com.dtflys.forest.annotation.GetRequest;
+import com.muyu.common.core.constant.Constants;
+import com.muyu.common.nacos.remote.interceptor.NacosNamespaceInterceptor;
+import com.muyu.common.nacos.remote.req.ServiceListReq;
+
+/**
+ * @Author:yang
+ * @Package:com.muyu.common.nacos.remote
+ * @Project:cloud-common-nacos-remote
+ * @name:NacosServiceApi
+ * @Date:2024/8/9 16:59
+ */
+@BaseRequest(
+ baseURL = Constants.HTTP+"#={nacos.addr}/nacos/v1/ns/service",
+ interceptor = {NacosNamespaceInterceptor.class}
+)
+public interface NacosServiceApi {
+
+ @GetRequest(
+ url = "/list"
+ )
+ public void serviceList(@Body ServiceListReq serviceListReq);
+}
diff --git a/src/main/java/com/muyu/common/nacos/remote/interceptor/NacosNamespaceInterceptor.java b/src/main/java/com/muyu/common/nacos/remote/interceptor/NacosNamespaceInterceptor.java
new file mode 100644
index 0000000..59f28ae
--- /dev/null
+++ b/src/main/java/com/muyu/common/nacos/remote/interceptor/NacosNamespaceInterceptor.java
@@ -0,0 +1,50 @@
+package com.muyu.common.nacos.api.interceptor;
+
+
+import com.dtflys.forest.http.ForestRequest;
+import com.dtflys.forest.interceptor.Interceptor;
+import com.muyu.common.core.text.Convert;
+import lombok.extern.log4j.Log4j2;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Value;
+
+/**
+ * @Author:yang
+ * @Package:com.muyu.common.nacos.remote.req
+ * @Project:cloud-common-nacos-remote
+ * @name:BaseReq
+ * @Date:2024/8/9 18:10
+ */
+
+@Log4j2
+public class NacosNamespaceInterceptor implements Interceptor {
+
+ @Value("${nacos.namespace}")
+ private String namespaceId;
+
+ /**
+ * 该方法在请求发送之前被调用, 若返回false则不会继续发送请求
+ * @Param request Forest请求对象
+ */
+ @Override
+ public boolean beforeExecute(ForestRequest req) {
+ if (StringUtils.isNotBlank(namespaceId)){
+ String reqNamespaceId = Convert.str(req.getQuery("namespaceId"), "");
+ if (reqNamespaceId == null){
+ log.warn("本次请求nacos的namespaceId未携带,已添加[{}]",namespaceId);
+ req.addQuery("namespaceId",namespaceId);
+
+ }else{
+ if (StringUtils.equals(reqNamespaceId,namespaceId)){
+ log.warn("本次请求nacos的namespaceId和项目ID不相符,现已更改:[{}->{}]",reqNamespaceId,namespaceId);
+ req.addQuery("namespaceId",namespaceId);
+ }
+ }
+ }
+ log.info("invoke Simple beforeExecute"); // 添加Header
+ req.addQuery("namespaceId", namespaceId); // 添加URL的Query参数
+ return true; // 继续执行请求返回true
+ }
+
+}
+
diff --git a/src/main/java/com/muyu/common/nacos/remote/req/BaseReq.java b/src/main/java/com/muyu/common/nacos/remote/req/BaseReq.java
new file mode 100644
index 0000000..23b5b14
--- /dev/null
+++ b/src/main/java/com/muyu/common/nacos/remote/req/BaseReq.java
@@ -0,0 +1,26 @@
+package com.muyu.common.nacos.api.req;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+/**
+ * @Author:yang
+ * @Package:com.muyu.common.nacos.remote.req
+ * @Project:cloud-common-nacos-remote
+ * @name:BaseReq
+ * @Date:2024/8/9 18:10
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class BaseReq {
+
+ /**
+ * 命名空间
+ */
+ private String namespaceId;
+
+}
diff --git a/src/main/java/com/muyu/common/nacos/remote/req/ServiceListReq.java b/src/main/java/com/muyu/common/nacos/remote/req/ServiceListReq.java
new file mode 100644
index 0000000..83dc894
--- /dev/null
+++ b/src/main/java/com/muyu/common/nacos/remote/req/ServiceListReq.java
@@ -0,0 +1,38 @@
+package com.muyu.common.nacos.api.req;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+/**
+ * @Author:yang
+ * @Package:com.muyu.common.nacos.remote.req
+ * @Project:cloud-common-nacos-remote
+ * @name:ServiceListReq
+ * @Date:2024/8/9 18:11
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+@EqualsAndHashCode(callSuper = true)
+public class ServiceListReq extends BaseReq{
+
+ /**
+ * 当前页码
+ */
+ private int pageNo;
+
+ /**
+ * 分页大小
+ */
+ private int pageSize = 10;
+
+ /**
+ * 分组名
+ */
+ private int groupName;
+
+}
diff --git a/src/main/java/com/muyu/common/nacos/remote/resp/ServiceListResp.java b/src/main/java/com/muyu/common/nacos/remote/resp/ServiceListResp.java
new file mode 100644
index 0000000..7e4bd46
--- /dev/null
+++ b/src/main/java/com/muyu/common/nacos/remote/resp/ServiceListResp.java
@@ -0,0 +1,34 @@
+package com.muyu.common.nacos.api.resp;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+import lombok.experimental.SuperBuilder;
+
+import java.util.List;
+
+/**
+ * @Author:yang
+ * @Package:com.muyu.common.nacos.remote.resp
+ * @Project:cloud-common-nacos-remote
+ * @name:ServiceListResp
+ * @Date:2024/8/9 18:15
+ */
+@Data
+@SuperBuilder
+@NoArgsConstructor
+@AllArgsConstructor
+public class ServiceListResp {
+
+ /**
+ * 总页数
+ */
+ private int count;
+
+ /**
+ * 服务列表
+ */
+ private List doms;
+
+
+}
diff --git a/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports b/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
new file mode 100644
index 0000000..061f0cb
--- /dev/null
+++ b/src/main/resources/META-INF/spring/org.springframework.boot.autoconfigure.AutoConfiguration.imports
@@ -0,0 +1 @@
+com.muyu.common.nacos.api.interceptor.NacosNamespaceInterceptor