nacos-remote的nacos接口模块
commit
7cc884d3f0
|
@ -0,0 +1,32 @@
|
||||||
|
package com.muyu.common.nacos.remote;
|
||||||
|
|
||||||
|
import com.dtflys.forest.annotation.*;
|
||||||
|
import com.muyu.common.core.constant.Constants;
|
||||||
|
import com.muyu.common.nacos.remote.interceptor.NacosNamespaceInterceptor;
|
||||||
|
import com.muyu.common.nacos.remote.req.ServiceListReq;
|
||||||
|
import com.muyu.common.nacos.remote.resp.ServiceListResp;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author:zhangchengzhi
|
||||||
|
* @Package:com.muyu.common.nacos.remote
|
||||||
|
* @Project:cloud-common-nacos-remote
|
||||||
|
* @name:NacosServiceRemote
|
||||||
|
* @Date:2024/8/4 16:21
|
||||||
|
*/
|
||||||
|
@BaseRequest(
|
||||||
|
baseURL = Constants.HTTP+"#{nacos.addr}/nacos/v1/ns/service",
|
||||||
|
interceptor = {NacosNamespaceInterceptor.class}
|
||||||
|
)
|
||||||
|
public interface NacosServiceRemote {
|
||||||
|
|
||||||
|
@GetRequest(
|
||||||
|
url = "/list"
|
||||||
|
)
|
||||||
|
public ServiceListResp serviceList(@Body ServiceListReq serviceListReq);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,41 @@
|
||||||
|
package com.muyu.common.nacos.remote.interceptor;
|
||||||
|
|
||||||
|
import com.dtflys.forest.http.ForestRequest;
|
||||||
|
import com.dtflys.forest.interceptor.Interceptor;
|
||||||
|
import com.muyu.common.core.text.Convert;
|
||||||
|
import com.muyu.common.core.utils.StringUtils;
|
||||||
|
import lombok.extern.log4j.Log4j2;
|
||||||
|
import org.springframework.beans.factory.annotation.Value;
|
||||||
|
|
||||||
|
@Log4j2
|
||||||
|
public class NacosNamespaceInterceptor<T> implements Interceptor<T> {
|
||||||
|
|
||||||
|
@Value("${nacos.namespace}")
|
||||||
|
private String namespaceId;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 该方法在请求发送之前被调用, 若返回false则不会继续发送请求
|
||||||
|
*
|
||||||
|
* @Param request Forest请求对象
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public boolean beforeExecute(ForestRequest req) {
|
||||||
|
if (StringUtils.isNotEmpty(namespaceId)){
|
||||||
|
String reqNamespaceId = Convert.str(req.getQuery("namespaceId"), "");
|
||||||
|
if (reqNamespaceId ==null){
|
||||||
|
log.warn("本次请求nacos的namespace未携带,已添加[{}]",namespaceId);
|
||||||
|
req.addQuery("namespaceId",namespaceId);
|
||||||
|
}else {
|
||||||
|
if (StringUtils.equals(reqNamespaceId,namespaceId)){
|
||||||
|
log.warn("本次请求nacos的namespaceId和项目ID不相符,现在已更改:[{}->{}]",reqNamespaceId);
|
||||||
|
req.addQuery("namespaceId",namespaceId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true; // 继续执行请求返回true
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
package com.muyu.common.nacos.remote.req;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.SuperBuilder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author:zhangchengzhi
|
||||||
|
* @Package:com.muyu.common.nacos.remote.req
|
||||||
|
* @Project:cloud-common-nacos-remote
|
||||||
|
* @name:BaseReq
|
||||||
|
* @Date:2024/8/4 16:50
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@SuperBuilder
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BaseReq {
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 命名空间
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
private String namespaceId;
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
package com.muyu.common.nacos.remote.req;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.EqualsAndHashCode;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
import lombok.experimental.SuperBuilder;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author:zhangchengzhi
|
||||||
|
* @Package:com.muyu.common.nacos.remote.req
|
||||||
|
* @Project:cloud-common-nacos-remote
|
||||||
|
* @name:ServiceListReq
|
||||||
|
* @Date:2024/8/4 16:52
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@SuperBuilder
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
@EqualsAndHashCode(callSuper = true)
|
||||||
|
public class ServiceListReq extends BaseReq{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 当前页码
|
||||||
|
*/
|
||||||
|
|
||||||
|
private int pageNo=1;
|
||||||
|
/**
|
||||||
|
* 分页大小
|
||||||
|
*/
|
||||||
|
|
||||||
|
private int pageSize=10;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 分组名
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
private String groupName;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,36 @@
|
||||||
|
package com.muyu.common.nacos.remote.resp;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Builder;
|
||||||
|
import lombok.Data;
|
||||||
|
import lombok.NoArgsConstructor;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @Author:zhangchengzhi
|
||||||
|
* @Package:com.muyu.common.nacos.remote.resp
|
||||||
|
* @Project:cloud-common-nacos-remote
|
||||||
|
* @name:ServiceListResp
|
||||||
|
* @Date:2024/8/4 16:57
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@Builder
|
||||||
|
@NoArgsConstructor
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ServiceListResp {
|
||||||
|
/**
|
||||||
|
* 总条数
|
||||||
|
*/
|
||||||
|
private int count;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 服务列表
|
||||||
|
*/
|
||||||
|
private List<String> doms;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1 @@
|
||||||
|
com.muyu.common.nacos.remote.interceptor.NacosNamespaceInterceptor
|
Loading…
Reference in New Issue