Skip to content

Commit

Permalink
Merge branch 'master' into issue_789
Browse files Browse the repository at this point in the history
  • Loading branch information
wtt40122 authored Feb 27, 2024
2 parents 5d7796e + 97e2c07 commit d8a1c07
Show file tree
Hide file tree
Showing 6 changed files with 138 additions and 8 deletions.
16 changes: 10 additions & 6 deletions jcommon/docean/src/main/java/com/xiaomi/youpin/docean/Mvc.java
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@
import com.xiaomi.youpin.docean.common.MethodInvoker;
import com.xiaomi.youpin.docean.common.NamedThreadFactory;
import com.xiaomi.youpin.docean.common.Safe;
import com.xiaomi.youpin.docean.common.StringUtils;
import com.xiaomi.youpin.docean.config.HttpServerConfig;
import com.xiaomi.youpin.docean.exception.DoceanException;
import com.xiaomi.youpin.docean.listener.event.Event;
Expand Down Expand Up @@ -85,6 +86,7 @@ private void setConfig(Ioc ioc) {
this.mvcConfig.setResponseOriginalValue(Boolean.valueOf(ioc.getBean(MvcConst.RESPONSE_ORIGINAL_VALUE, MvcConst.FALSE)));
this.mvcConfig.setPoolSize(Integer.valueOf(ioc.getBean(MvcConst.MVC_POOL_SIZE, String.valueOf(MvcConst.DEFAULT_MVC_POOL_SIZE))));
this.mvcConfig.setVirtualThread(Boolean.valueOf(ioc.getBean(MvcConst.VIRTUAL_THREAD, MvcConst.TRUE)));
this.mvcConfig.setResponseOriginalPath(ioc.getBean(MvcConst.RESPONSE_ORIGINAL_PATH, ""));
ioc.publishEvent(new Event(EventType.mvcBegin, this.mvcConfig));
}

Expand Down Expand Up @@ -212,12 +214,14 @@ public void callMethod(MvcContext context, MvcRequest request, MvcResponse respo
return;
}
// get whether the configuration returns an unwrapped value
if (this.mvcConfig.isResponseOriginalValue()) {
if (data instanceof String) {
response.writeAndFlush(context, (String) data);
} else {
response.writeAndFlush(context, gson.toJson(data));
}
boolean needOriginalValue = this.mvcConfig.isResponseOriginalValue();
if (!needOriginalValue && StringUtils.isNotBlank(this.mvcConfig.getResponseOriginalPath())) {
needOriginalValue = Arrays.stream(mvcConfig.getResponseOriginalPath().split(","))
.anyMatch(i -> i.equals(method.getPath()));
}
if (needOriginalValue) {
String responseData = data instanceof String ? (String) data : gson.toJson(data);
response.writeAndFlush(context, responseData);
} else {
result.setData(data);
response.writeAndFlush(context, gson.toJson(result));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -42,4 +42,9 @@ public class MvcConfig implements Serializable {

private boolean openStaticFile;

/**
* url that need to return original data like"/test1,/test2"
*/
private String responseOriginalPath;

}
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,8 @@ public abstract class MvcConst {

public static final String VIRTUAL_THREAD = "$virtual-threaad";

public static final String RESPONSE_ORIGINAL_PATH = "$response-original-path";

public static final int DEFAULT_MVC_POOL_SIZE = 200;

public static ScopedValue<MvcContext> MVC_CONTEXT = ScopedValue.newInstance();
Expand Down
4 changes: 2 additions & 2 deletions jcommon/gitlab/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@
<version>1.4-jdk20-SNAPSHOT</version>
</parent>
<artifactId>gitlab</artifactId>
<version>1.6-jdk21</version>
<version>1.6.1-jdk21-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>com.github.odiszapc</groupId>
Expand All @@ -34,7 +34,7 @@
<dependency>
<groupId>org.gitlab4j</groupId>
<artifactId>gitlab4j-api</artifactId>
<version>4.12.2</version>
<version>5.5.0</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
Expand Down
111 changes: 111 additions & 0 deletions jcommon/gitlab/src/main/java/com/xiaomi/youpin/gitlab/Gitlab.java
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
package com.xiaomi.youpin.gitlab;

import com.github.odiszapc.nginxparser.*;
import com.google.common.base.Preconditions;
import com.google.gson.Gson;
import com.google.common.collect.Maps;
import com.google.gson.JsonSyntaxException;
Expand All @@ -36,15 +37,22 @@
import org.eclipse.jgit.transport.CredentialsProvider;
import org.eclipse.jgit.transport.PushResult;
import org.eclipse.jgit.transport.UsernamePasswordCredentialsProvider;
import org.gitlab4j.api.GitLabApi;
import org.gitlab4j.api.GitLabApiException;
import org.gitlab4j.api.models.RepositoryFile;
import org.gitlab4j.api.models.TreeItem;
import org.springframework.beans.BeanUtils;

import java.io.*;
import java.net.URL;
import java.net.URLEncoder;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;
import java.text.DateFormat;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.*;
import java.util.concurrent.ConcurrentHashMap;
import java.util.regex.Matcher;
import java.util.zip.ZipEntry;
import java.util.zip.ZipFile;
Expand All @@ -64,6 +72,25 @@ public class Gitlab {

private static Gson gson = new Gson();

//帮我生成一个org.gitlab4j.api.GitLabApi类的缓存方法,避免每次都new一个对象,新建方式如下GitLabApi gitLabApi = new GitLabApi(baseUrl, gitToken); (method)
private static final ConcurrentHashMap<String, GitLabApi> gitLabApiCache = new ConcurrentHashMap<>();

public static GitLabApi getGitLabApi(String baseUrl, String gitToken) {
String key = baseUrl + "#" + gitToken;
return gitLabApiCache.computeIfAbsent(key, k -> new GitLabApi(baseUrl, gitToken));
}

private static List<String> SUPPORT_FILE_TYPES = Arrays.asList(
".java", ".xml", ".html", ".css", ".js", ".json", ".md",
".yml", ".yaml", ".properties", ".sql", ".txt", ".sh", ".bat", ".py", ".c", ".cpp",
".h", ".rb", ".php", ".cs", ".swift", ".go", ".rs"
);

//给一个文件名,判断后缀是否在SUPPORT_FILE_TYPES 结合中 (class)
public boolean isSupportedFileType(String fileName) {
return SUPPORT_FILE_TYPES.stream().anyMatch(fileName::endsWith);
}

public Gitlab(String gitlabBaseUrl) {
if (StringUtils.isBlank(gitlabBaseUrl)) {
this.gitlabApiUrl = GIT_API_URL;
Expand Down Expand Up @@ -1348,4 +1375,88 @@ private boolean getServers(String config, String name) {
}
return res;
}

/**
* 获取指定远程git文件的raw内容
* @param branch
* @param gitDomain
* @param gitToken
* @param projectId
* @param filePath
* @return
*/
public String getFileContent(String branch, String gitDomain, String gitToken, String projectId, String filePath) {
try {
Preconditions.checkArgument(null != gitDomain, "gitDomain can not be null");
Preconditions.checkArgument(null != gitToken, "gitToken can not be null");
Preconditions.checkArgument(null != projectId, "projectId can not be null");
Preconditions.checkArgument(null != filePath, "filePath can not be null");
Preconditions.checkArgument(isSupportedFileType(filePath), "not support this file type");

String baseUrl = "https://" + gitDomain;
GitLabApi gitLabApi = getGitLabApi(baseUrl, gitToken);

RepositoryFile file = gitLabApi.getRepositoryFileApi().getFile(projectId, filePath, branch);
String encodedContent = file.getContent();
byte[] decodedBytes = Base64.getDecoder().decode(encodedContent);

return new String(decodedBytes, StandardCharsets.UTF_8);
} catch (GitLabApiException e) {
throw new RuntimeException("Error retrieving file content from GitLab", e);
}
}


/**
* 获取git工程树结构
*
* @param branch
* @param gitDomain
* @param gitToken
* @param projectId
* @return
*/
public List<GitTreeItem> getProjectStructureTree(String branch, String gitDomain, String gitToken, String projectId) {
try {
Preconditions.checkArgument(null != gitDomain, "gitDomain can not be null");
Preconditions.checkArgument(null != gitToken, "gitToken can not be null");
Preconditions.checkArgument(null != projectId, "projectId can not be null");

String baseUrl = "https://" + gitDomain;
GitLabApi gitLabApi = getGitLabApi(baseUrl, gitToken);
List<TreeItem> treeItems = gitLabApi.getRepositoryApi().getTree(projectId, null, branch, true);

List<GitTreeItem> treeItemList = transformProjectStructureTree(treeItems);

return treeItemList;
} catch (GitLabApiException e) {
throw new RuntimeException("Error retrieving project structure from GitLab", e);
}
}

//将调用getProjectStructureTree获取到的List<TreeItem>进行结构改造,新结构TreeItem2较TreeItem新增属性parentId,父子关系的判定基于TreeItem的path和type (class)
private List<GitTreeItem> transformProjectStructureTree(List<TreeItem> treeItems) {
Map<String, GitTreeItem> itemMap = new HashMap<>();
List<GitTreeItem> result = new ArrayList<>();

// First, convert all TreeItems to TreeItem2 and store them in a map for easy lookup
for (TreeItem item : treeItems) {
GitTreeItem gitTreeItem = new GitTreeItem();
BeanUtils.copyProperties(item, gitTreeItem);
gitTreeItem.setType(item.getType().name());
itemMap.put(item.getPath(), gitTreeItem);
}

// Next, establish parent-child relationships
for (GitTreeItem gitTreeItem : itemMap.values()) {
String path = gitTreeItem.getPath();
String parentPath = path.contains("/") ? path.substring(0, path.lastIndexOf('/')) : null;
gitTreeItem.setParentId(parentPath != null ? itemMap.get(parentPath).getId() : null);

result.add(gitTreeItem);
}

return result;
}

}
Original file line number Diff line number Diff line change
Expand Up @@ -123,4 +123,12 @@ public void getDomainByIP() {
gitlab.getDomainByIP("https://xxx.com","xx","", Arrays.asList("127.0.0.1"),"token");
}


@Test
public void getProjectCode() {

gitlab.getDomainByIP("https://xxx.com","xx","", Arrays.asList("127.0.0.1"),"token");
}


}

0 comments on commit d8a1c07

Please sign in to comment.