feat:add module

This commit is contained in:
zzs01@yunemao.com 2024-09-23 11:14:54 +08:00
parent 32bfbaf60b
commit 1097502dc6
10 changed files with 126 additions and 135 deletions

View File

@ -0,0 +1,25 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.ensign</groupId>
<artifactId>ensign-module-crm</artifactId>
<version>${revision}</version>
</parent>
<artifactId>ensign-module-crm-api</artifactId>
<packaging>jar</packaging>
<name>${project.artifactId}</name>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-common</artifactId>
</dependency>
</dependencies>
</project>

View File

@ -0,0 +1,59 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.ensign</groupId>
<artifactId>ensign-module-crm</artifactId>
<version>${revision}</version>
</parent>
<artifactId>ensign-module-crm-biz</artifactId>
<packaging>jar</packaging>
<name>${project.artifactId}</name>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-module-crm-api</artifactId>
<version>${revision}</version>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-common</artifactId>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-spring-boot-starter-mybatis</artifactId>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-spring-boot-starter-websocket</artifactId>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-module-system-api</artifactId>
<version>${revision}</version>
</dependency>
</dependencies>
</project>

View File

@ -1,11 +1,15 @@
package com.ensign.crm.server.controller;
package com.ensign.crm.module.crm.controller.crm;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag;
import org.springframework.http.HttpMethod;
import org.springframework.http.MediaType;
import org.springframework.http.client.ClientHttpRequest;
import org.springframework.http.client.ClientHttpResponse;
import org.springframework.http.client.SimpleClientHttpRequestFactory;
import org.springframework.security.access.prepost.PreAuthorize;
import org.springframework.util.StreamUtils;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@ -14,30 +18,30 @@ import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URI;
import java.net.URISyntaxException;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.List;
import java.util.*;
/**
* @Description: TODO
* @Date: 2024/9/20 18:28
* @Date: 2024/9/23 9:39
* @Created: by ZZSLL
*/
@RestController
@RequestMapping("/ensign/crm")
@Tag(name = "CRM - Proxy")
@RequestMapping("/crm-api/proxy")
@Validated
public class ProxyController {
private String targetAddr = "http://10.64.112.152:8022";
private String targetAddr = "http://122.4.221.133:8022";
@RequestMapping(value = "/proxy/**", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@RequestMapping(value = "/do/**", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
@Operation(summary = "转发接口")
@PreAuthorize("@ss.hasPermission('crm:proxy:all')")
public void proxy(HttpServletRequest request, HttpServletResponse response) throws IOException, URISyntaxException {
URI uri = new URI(request.getRequestURI());
String path = uri.getPath();
String query = request.getQueryString();
String target = targetAddr + path.replace("/ensign/crm/proxy", "");
String target = targetAddr + path.replace("/crm-api/proxy/do", "");
if (query != null && !query.isEmpty() && !query.equals("null")) {
target = target + "?" + query;
}
@ -70,5 +74,4 @@ public class ProxyController {
}));
StreamUtils.copy(clientHttpResponse.getBody(), response.getOutputStream());
}
}

18
ensign-module-crm/pom.xml Normal file
View File

@ -0,0 +1,18 @@
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.ensign</groupId>
<artifactId>ensign</artifactId>
<version>${revision}</version>
</parent>
<artifactId>ensign-module-crm</artifactId>
<packaging>pom</packaging>
<name>${project.artifactId}</name>
<modules>
<module>ensign-module-crm-api</module>
<module>ensign-module-crm-biz</module>
</modules>
</project>

View File

@ -44,6 +44,11 @@
<artifactId>ensign-spring-boot-starter-protection</artifactId>
</dependency>
<dependency>
<groupId>com.ensign</groupId>
<artifactId>ensign-module-crm-biz</artifactId>
<version>${revision}</version>
</dependency>
</dependencies>
<build>

View File

@ -1,13 +0,0 @@
package com.ensign.crm.server.exception;
/**
* @Description: TODO
* @Date: 2024/9/20 18:33
* @Created: by ZZSLL
*/
public class AllKingdeeException extends Exception {
public AllKingdeeException(String message) {
super(message);
}
}

View File

@ -1,85 +0,0 @@
package com.ensign.crm.server.utils;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.ensign.crm.server.exception.AllKingdeeException;
import lombok.extern.slf4j.Slf4j;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.HttpClient;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.DefaultHttpClient;
import org.apache.http.util.EntityUtils;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
/**
* @Description: TODO
* @Date: 2024/9/20 18:33
* @Created: by ZZSLL
*/
@Slf4j
public class ProxyUtils {
public void initAppToken() throws IOException, AllKingdeeException
{
final String END_POINT = "/ierp/api/getAppToken.do";
HttpClient client = new DefaultHttpClient();
HttpPost post = new HttpPost(END_POINT);
Map<String, String> body = new HashMap<>();
body.put("appId", "");
body.put("appSecuret", "");
body.put("tenantid", "");
body.put("accountId", "");
body.put("language", "");
HttpEntity reqEntity = new StringEntity(JSONUtil.toJsonStr(body), "utf-8");
post.setEntity(reqEntity);
post.setConfig(RequestConf.initRequestConfig());
HttpResponse response = client.execute(post);
if (response.getStatusLine().getStatusCode() == 200) {
HttpEntity resEntity = response.getEntity();
String responseData = EntityUtils.toString(resEntity, "utf-8");
JSONObject jsonObject = JSONUtil.parseObj(responseData);
Boolean status = (Boolean) jsonObject.get("status");
String state = (String) jsonObject.get("state");
if (status && "success".equals(state)) {
JSONObject data = (JSONObject) jsonObject.get("data");
String appToken = (String) data.get("app_token");
if (appToken != null && !appToken.isEmpty()) {
Long expireTime = (Long) data.get("expire_time");
return;
}
}
log.error("获取appToken失败 {}", jsonObject);
throw new AllKingdeeException("获取appToken失败");
}
log.error("获取appToken失败 {}", EntityUtils.toString(response.getEntity(), "utf-8"));
throw new AllKingdeeException("获取appToken失败");
}
}

View File

@ -1,22 +0,0 @@
package com.ensign.crm.server.utils;
import org.apache.http.client.config.RequestConfig;
import org.springframework.stereotype.Component;
/**
* @Description: TODO
* @Date: 2024/9/20 18:32
* @Created: by ZZSLL
*/
@Component
public class RequestConf
{
public static RequestConfig initRequestConfig() {
return RequestConfig.custom()
.setConnectTimeout(5000)//连接超时connectionTimeout-->指的是连接一个url的连接等待时间
.setSocketTimeout(5000)// 读取数据超时SocketTimeout-->指的是连接上一个url获取response的返回等待时间
.setConnectionRequestTimeout(5000)
.build();
}
}

View File

@ -185,7 +185,7 @@ ensign:
db-schemas: ${spring.datasource.dynamic.datasource.master.name}
front-type: 10 # 前端模版的类型,参见 CodegenFrontTypeEnum 枚举类
tenant: # 多租户相关配置项
enable: true
enable: false
ignore-urls:
- /admin-api/system/tenant/get-id-by-name # 基于名字获取租户,不许带租户编号
- /admin-api/system/tenant/get-by-website # 基于域名获取租户,不许带租户编号
@ -196,7 +196,7 @@ ensign:
- /admin-api/pay/notify/** # 支付回调通知,不携带租户编号
- /jmreport/* # 积木报表,无法携带租户编号
- /admin-api/mp/open/** # 微信公众号开放平台,微信回调接口,无法携带租户编号
- /admin-api/crm/**
- /crm-api/**
ignore-tables:
- system_tenant
- system_tenant_package

View File

@ -15,7 +15,8 @@
<!-- 各种 module 拓展 -->
<module>ensign-module-system</module>
<module>ensign-module-infra</module>
<!-- <module>ensign-module-member</module>-->
<module>ensign-module-crm</module>
<!-- <module>ensign-module-member</module>-->
<!-- <module>ensign-module-bpm</module>-->
<!-- <module>ensign-module-report</module>-->
<!-- <module>ensign-module-mp</module>-->