This is an automated email from the ASF dual-hosted git repository.

dockerzhang pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/inlong.git


The following commit(s) were added to refs/heads/master by this push:
     new 1001f66fed [INLONG-10388][Manager] Provide an interface to obtain the 
audit proxy address (#10389)
1001f66fed is described below

commit 1001f66fed79eec4f9a84b6d34da6a707985d9e5
Author: fuweng11 <[email protected]>
AuthorDate: Wed Jun 12 16:24:04 2024 +0800

    [INLONG-10388][Manager] Provide an interface to obtain the audit proxy 
address (#10389)
---
 .../manager/pojo/audit/AuditProxyResponse.java     | 41 ++++++++++++++++++++++
 .../inlong/manager/service/core/AuditService.java  |  8 +++++
 .../service/core/impl/AuditServiceImpl.java        | 28 +++++++++++++++
 .../manager/web/controller/AuditController.java    | 10 ++++++
 .../web/controller/openapi/AuditController.java    | 11 ++++++
 5 files changed, 98 insertions(+)

diff --git 
a/inlong-manager/manager-pojo/src/main/java/org/apache/inlong/manager/pojo/audit/AuditProxyResponse.java
 
b/inlong-manager/manager-pojo/src/main/java/org/apache/inlong/manager/pojo/audit/AuditProxyResponse.java
new file mode 100644
index 0000000000..50b4a5534b
--- /dev/null
+++ 
b/inlong-manager/manager-pojo/src/main/java/org/apache/inlong/manager/pojo/audit/AuditProxyResponse.java
@@ -0,0 +1,41 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements. See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You under the Apache License, Version 2.0
+ * (the "License"); you may not use this file except in compliance with
+ * the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+
+package org.apache.inlong.manager.pojo.audit;
+
+import lombok.AllArgsConstructor;
+import lombok.Data;
+import lombok.NoArgsConstructor;
+
+import java.util.List;
+
+@Data
+public class AuditProxyResponse {
+
+    private Boolean success;
+    private String errMsg;
+    private List<AuditProxy> data;
+
+    @Data
+    @NoArgsConstructor
+    @AllArgsConstructor
+    public static class AuditProxy {
+
+        private String host;
+        private int port;
+    }
+}
diff --git 
a/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/AuditService.java
 
b/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/AuditService.java
index c4b5844892..c97d74f7f9 100644
--- 
a/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/AuditService.java
+++ 
b/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/AuditService.java
@@ -19,6 +19,7 @@ package org.apache.inlong.manager.service.core;
 
 import org.apache.inlong.audit.entity.AuditInformation;
 import org.apache.inlong.common.enums.IndicatorType;
+import org.apache.inlong.manager.pojo.audit.AuditProxyResponse.AuditProxy;
 import org.apache.inlong.manager.pojo.audit.AuditRequest;
 import org.apache.inlong.manager.pojo.audit.AuditVO;
 
@@ -63,4 +64,11 @@ public interface AuditService {
      */
     Boolean refreshBaseItemCache();
 
+    /**
+     * Get audit proxy url by component
+     *
+     * @return audit proxy list
+     */
+    List<AuditProxy> getAuditProxy(String component) throws Exception;
+
 }
diff --git 
a/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/impl/AuditServiceImpl.java
 
b/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/impl/AuditServiceImpl.java
index 9e7ab49476..b89a2a6086 100644
--- 
a/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/impl/AuditServiceImpl.java
+++ 
b/inlong-manager/manager-service/src/main/java/org/apache/inlong/manager/service/core/impl/AuditServiceImpl.java
@@ -28,6 +28,7 @@ import org.apache.inlong.manager.common.enums.ClusterType;
 import org.apache.inlong.manager.common.enums.ErrorCodeEnum;
 import org.apache.inlong.manager.common.enums.TimeStaticsDim;
 import org.apache.inlong.manager.common.exceptions.BusinessException;
+import org.apache.inlong.manager.common.util.HttpUtils;
 import org.apache.inlong.manager.common.util.Preconditions;
 import org.apache.inlong.manager.dao.entity.InlongGroupEntity;
 import org.apache.inlong.manager.dao.entity.StreamSinkEntity;
@@ -37,6 +38,8 @@ import 
org.apache.inlong.manager.dao.mapper.InlongGroupEntityMapper;
 import org.apache.inlong.manager.dao.mapper.StreamSinkEntityMapper;
 import org.apache.inlong.manager.dao.mapper.StreamSourceEntityMapper;
 import org.apache.inlong.manager.pojo.audit.AuditInfo;
+import org.apache.inlong.manager.pojo.audit.AuditProxyResponse;
+import org.apache.inlong.manager.pojo.audit.AuditProxyResponse.AuditProxy;
 import org.apache.inlong.manager.pojo.audit.AuditRequest;
 import org.apache.inlong.manager.pojo.audit.AuditVO;
 import org.apache.inlong.manager.pojo.user.LoginUserUtils;
@@ -56,6 +59,7 @@ import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.context.annotation.Lazy;
+import org.springframework.http.HttpMethod;
 import org.springframework.stereotype.Service;
 import org.springframework.web.client.RestTemplate;
 
@@ -395,6 +399,30 @@ public class AuditServiceImpl implements AuditService {
         return result;
     }
 
+    @Override
+    public List<AuditProxy> getAuditProxy(String component) throws Exception {
+        try {
+            StringBuilder builder = new StringBuilder();
+            builder.append(auditQueryUrl)
+                    .append("/audit/query/getAuditProxy?")
+                    .append("component=")
+                    .append(component);
+            String url = builder.toString();
+            LOGGER.info("query audit url ={}", url);
+            AuditProxyResponse result = HttpUtils.request(restTemplate,
+                    url,
+                    HttpMethod.GET, null,
+                    null,
+                    AuditProxyResponse.class);
+            LOGGER.info("success to query audit proxy url list for request url 
={}", url);
+            return result.getData();
+        } catch (Exception e) {
+            String errMsg = String.format("get audit proxy url failed for %s", 
component);
+            LOGGER.info(errMsg, e);
+            throw new BusinessException(errMsg);
+        }
+    }
+
     /**
      * Format the log time
      */
diff --git 
a/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/AuditController.java
 
b/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/AuditController.java
index 8291ad1ff1..8d6868ea3e 100644
--- 
a/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/AuditController.java
+++ 
b/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/AuditController.java
@@ -18,12 +18,14 @@
 package org.apache.inlong.manager.web.controller;
 
 import org.apache.inlong.audit.entity.AuditInformation;
+import org.apache.inlong.manager.pojo.audit.AuditProxyResponse.AuditProxy;
 import org.apache.inlong.manager.pojo.audit.AuditRequest;
 import org.apache.inlong.manager.pojo.audit.AuditVO;
 import org.apache.inlong.manager.pojo.common.Response;
 import org.apache.inlong.manager.service.core.AuditService;
 
 import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiOperation;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.context.annotation.Lazy;
@@ -31,6 +33,7 @@ import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
 import org.springframework.web.bind.annotation.RestController;
 
 import javax.validation.Valid;
@@ -73,4 +76,11 @@ public class AuditController {
         return Response.success(auditService.getAuditBases());
     }
 
+    @GetMapping(value = "/audit/getAuditProxy")
+    @ApiOperation(value = "Get audit proxy url")
+    @ApiImplicitParam(name = "component", dataTypeClass = String.class, 
required = true)
+    public Response<List<AuditProxy>> getAuditProxy(@RequestParam String 
component) throws Exception {
+        return Response.success(auditService.getAuditProxy(component));
+    }
+
 }
diff --git 
a/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/openapi/AuditController.java
 
b/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/openapi/AuditController.java
index c874c37bbe..46c16736a1 100644
--- 
a/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/openapi/AuditController.java
+++ 
b/inlong-manager/manager-web/src/main/java/org/apache/inlong/manager/web/controller/openapi/AuditController.java
@@ -19,6 +19,7 @@ package org.apache.inlong.manager.web.controller.openapi;
 
 import org.apache.inlong.common.pojo.audit.AuditConfig;
 import org.apache.inlong.common.pojo.audit.AuditConfigRequest;
+import org.apache.inlong.manager.pojo.audit.AuditProxyResponse.AuditProxy;
 import org.apache.inlong.manager.pojo.audit.AuditRequest;
 import org.apache.inlong.manager.pojo.audit.AuditVO;
 import org.apache.inlong.manager.pojo.common.Response;
@@ -26,12 +27,15 @@ import 
org.apache.inlong.manager.service.cluster.InlongClusterService;
 import org.apache.inlong.manager.service.core.AuditService;
 
 import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiImplicitParam;
 import io.swagger.annotations.ApiOperation;
 import org.apache.commons.collections.CollectionUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestBody;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
 import org.springframework.web.bind.annotation.RestController;
 
 import javax.validation.Valid;
@@ -72,4 +76,11 @@ public class AuditController {
     public Response<List<AuditVO>> listAll(@Valid @RequestBody AuditRequest 
request) throws Exception {
         return Response.success(auditService.listAll(request));
     }
+
+    @GetMapping(value = "/audit/getAuditProxy")
+    @ApiOperation(value = "Get audit proxy url")
+    @ApiImplicitParam(name = "component", dataTypeClass = String.class, 
required = true)
+    public Response<List<AuditProxy>> getAuditProxy(@RequestParam String 
component) throws Exception {
+        return Response.success(auditService.getAuditProxy(component));
+    }
 }

Reply via email to