mirror of
https://gitee.com/BDWare/agent-backend
synced 2025-01-10 01:44:14 +00:00
feat: support regx match
This commit is contained in:
parent
e9f7a9140b
commit
f61e2c970c
@ -41,8 +41,8 @@ dependencies {
|
|||||||
implementation 'io.grpc:grpc-all:1.43.1'
|
implementation 'io.grpc:grpc-all:1.43.1'
|
||||||
implementation 'org.apache.velocity:velocity-engine-core:2.3'
|
implementation 'org.apache.velocity:velocity-engine-core:2.3'
|
||||||
implementation 'com.nimbusds:nimbus-jose-jwt:9.10'
|
implementation 'com.nimbusds:nimbus-jose-jwt:9.10'
|
||||||
implementation 'org.bdware.doip:doip-sdk:1.5.1'
|
implementation 'org.bdware.doip:doip-sdk:1.5.5'
|
||||||
implementation 'org.bdware.doip:doip-audit-tool:1.4.3'
|
implementation 'org.bdware.doip:doip-audit-tool:1.5.1'
|
||||||
implementation 'org.bdware.doip:bdosclient:0.1.0'
|
implementation 'org.bdware.doip:bdosclient:0.1.0'
|
||||||
implementation fileTree(dir: 'lib', include: '*.jar')
|
implementation fileTree(dir: 'lib', include: '*.jar')
|
||||||
testImplementation 'junit:junit:4.13.2'
|
testImplementation 'junit:junit:4.13.2'
|
||||||
|
@ -49,10 +49,12 @@ import java.lang.reflect.Field;
|
|||||||
import java.net.MalformedURLException;
|
import java.net.MalformedURLException;
|
||||||
import java.net.URL;
|
import java.net.URL;
|
||||||
import java.net.URLClassLoader;
|
import java.net.URLClassLoader;
|
||||||
|
import java.util.Arrays;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.Objects;
|
import java.util.List;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
public class CMHttpServer {
|
public class CMHttpServer {
|
||||||
private static final Logger LOGGER = LogManager.getLogger(CMHttpServer.class);
|
private static final Logger LOGGER = LogManager.getLogger(CMHttpServer.class);
|
||||||
@ -167,21 +169,7 @@ public class CMHttpServer {
|
|||||||
|
|
||||||
private static void startByPath(JsonObject jo) {
|
private static void startByPath(JsonObject jo) {
|
||||||
String path = jo.get("path").getAsString();
|
String path = jo.get("path").getAsString();
|
||||||
if (path.indexOf('*') != -1) {
|
path = findNewestYPK(path);
|
||||||
int split = Math.max(path.lastIndexOf('/'), 0);
|
|
||||||
String dirPath = path.substring(0, split), filePath = path.substring(split);
|
|
||||||
String[] fileName =
|
|
||||||
(filePath.startsWith("/") ? filePath.substring(1) : filePath).split("\\*");
|
|
||||||
File dir = new File(dirPath);
|
|
||||||
for (File file : Objects.requireNonNull(dir.listFiles())) {
|
|
||||||
LOGGER.warn(file.getName());
|
|
||||||
if (file.getName().startsWith(fileName[0])
|
|
||||||
&& file.getName().endsWith(fileName[fileName.length - 1])) {
|
|
||||||
path = file.getAbsolutePath();
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
File f = new File(path);
|
File f = new File(path);
|
||||||
if (!f.getName().endsWith(".ypk") || !f.exists())
|
if (!f.getName().endsWith(".ypk") || !f.exists())
|
||||||
return;
|
return;
|
||||||
@ -197,6 +185,71 @@ public class CMHttpServer {
|
|||||||
ContractManager.instance.startContract(c);
|
ContractManager.instance.startContract(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static String findNewestYPK(String path) {
|
||||||
|
File toParse = new File(path);
|
||||||
|
if (!toParse.exists()) {
|
||||||
|
File dir = toParse.getParentFile();
|
||||||
|
String fileName = toParse.getName();
|
||||||
|
Pattern pattern = Pattern.compile(fileName);
|
||||||
|
if (dir.isDirectory() && dir.exists()) {
|
||||||
|
File[] available = dir.listFiles((f) -> {
|
||||||
|
String name = f.getName();
|
||||||
|
return pattern.matcher(name).matches();
|
||||||
|
});
|
||||||
|
List<File> result = Arrays.asList(available);
|
||||||
|
return findNewestFile(result).getAbsolutePath();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return path;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static File findNewestFile(List<File> files) {
|
||||||
|
File newestFile = null;
|
||||||
|
String newestVersion = null;
|
||||||
|
for (File file : files) {
|
||||||
|
String fileName = file.getName();
|
||||||
|
String version = extractVersion(fileName);
|
||||||
|
|
||||||
|
if (newestVersion == null || compareVersions(version, newestVersion) > 0) {
|
||||||
|
newestFile = file;
|
||||||
|
newestVersion = version;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return newestFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String extractVersion(String fileName) {
|
||||||
|
// Assuming the version is between the last '-' and the last '.'
|
||||||
|
int lastDashIndex = fileName.lastIndexOf('-');
|
||||||
|
int lastDotIndex = fileName.lastIndexOf('.');
|
||||||
|
if (lastDashIndex == -1 || lastDotIndex == -1 || lastDashIndex >= lastDotIndex) {
|
||||||
|
throw new IllegalArgumentException("Invalid file name format: " + fileName);
|
||||||
|
}
|
||||||
|
return fileName.substring(lastDashIndex + 1, lastDotIndex);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static int compareVersions(String v1, String v2) {
|
||||||
|
String[] parts1 = v1.split("\\.");
|
||||||
|
String[] parts2 = v2.split("\\.");
|
||||||
|
|
||||||
|
int length = Math.max(parts1.length, parts2.length);
|
||||||
|
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
|
int num1 = i < parts1.length ? Integer.parseInt(parts1[i]) : 0;
|
||||||
|
int num2 = i < parts2.length ? Integer.parseInt(parts2[i]) : 0;
|
||||||
|
|
||||||
|
if (num1 < num2) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
if (num1 > num2) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0; // Both versions are equal
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
private static String[] parseStrAsList(String str) {
|
private static String[] parseStrAsList(String str) {
|
||||||
if (str == null) {
|
if (str == null) {
|
||||||
return new String[] {};
|
return new String[] {};
|
||||||
@ -318,8 +371,8 @@ public class CMHttpServer {
|
|||||||
ContractRepositoryMain.start();
|
ContractRepositoryMain.start();
|
||||||
final CMHttpHandler serverHandler = new CMHttpHandler();
|
final CMHttpHandler serverHandler = new CMHttpHandler();
|
||||||
EventLoopGroup bossGroup = new NioEventLoopGroup(1);
|
EventLoopGroup bossGroup = new NioEventLoopGroup(1);
|
||||||
NettyConnectServerHandler trafficSharp =
|
// NettyConnectServerHandler trafficSharp =
|
||||||
new NettyConnectServerHandler(new AtomicInteger(0));
|
// new NettyConnectServerHandler(new AtomicInteger(0));
|
||||||
try {
|
try {
|
||||||
ServerBootstrap b1 = new ServerBootstrap();
|
ServerBootstrap b1 = new ServerBootstrap();
|
||||||
b1.option(ChannelOption.ALLOCATOR, PooledByteBufAllocator.DEFAULT);
|
b1.option(ChannelOption.ALLOCATOR, PooledByteBufAllocator.DEFAULT);
|
||||||
@ -330,7 +383,8 @@ public class CMHttpServer {
|
|||||||
if (sslContext != null) {
|
if (sslContext != null) {
|
||||||
arg0.pipeline().addLast(new OptionalSslHandler(sslContext));
|
arg0.pipeline().addLast(new OptionalSslHandler(sslContext));
|
||||||
}
|
}
|
||||||
arg0.pipeline().addLast(trafficSharp).addLast(new HttpServerCodec())
|
arg0.pipeline()// .addLast(trafficSharp)
|
||||||
|
.addLast(new HttpServerCodec())
|
||||||
.addLast(new HttpObjectAggregator(10 * 1024 * 1024))
|
.addLast(new HttpObjectAggregator(10 * 1024 * 1024))
|
||||||
.addLast(new WebSocketServerProtocolHandler(PATH, null, true))
|
.addLast(new WebSocketServerProtocolHandler(PATH, null, true))
|
||||||
.addLast(new ChunkedWriteHandler()).addLast(serverHandler)
|
.addLast(new ChunkedWriteHandler()).addLast(serverHandler)
|
||||||
|
@ -21,7 +21,7 @@ public class CongestionControl {
|
|||||||
public static int maxMasterServerLoad = 0;
|
public static int maxMasterServerLoad = 0;
|
||||||
|
|
||||||
// configurations
|
// configurations
|
||||||
public static int maxHttpConnCount = 100;
|
public static int maxHttpConnCount = 1000;
|
||||||
|
|
||||||
// TODO remove sync call of executeOnOthreNode
|
// TODO remove sync call of executeOnOthreNode
|
||||||
public static void httpCControl(ChannelHandlerContext ctx) {
|
public static void httpCControl(ChannelHandlerContext ctx) {
|
||||||
|
@ -302,7 +302,7 @@ public class FileActions {
|
|||||||
fout = fileMap.get(target.getAbsolutePath());
|
fout = fileMap.get(target.getAbsolutePath());
|
||||||
try {
|
try {
|
||||||
fout.close();
|
fout.close();
|
||||||
} catch (IOException e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
fileMap.remove(target.getAbsolutePath());
|
fileMap.remove(target.getAbsolutePath());
|
||||||
|
@ -322,6 +322,7 @@ public class CMHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
LOGGER.warn("catch exception in " + parseCtx2String(ctx) + ": "
|
LOGGER.warn("catch exception in " + parseCtx2String(ctx) + ": "
|
||||||
+ cause.getClass().getSimpleName());
|
+ cause.getClass().getSimpleName());
|
||||||
LOGGER.debug(ExceptionUtil.exceptionToString(cause));
|
LOGGER.debug(ExceptionUtil.exceptionToString(cause));
|
||||||
|
cause.printStackTrace();
|
||||||
// ctx.close();
|
// ctx.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
package org.bdware.server.http;
|
package org.bdware.server.http;
|
||||||
|
|
||||||
|
import com.google.gson.Gson;
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import io.netty.buffer.Unpooled;
|
import io.netty.buffer.Unpooled;
|
||||||
import io.netty.channel.ChannelFuture;
|
import io.netty.channel.ChannelFuture;
|
||||||
@ -13,6 +14,7 @@ import io.netty.util.concurrent.GenericFutureListener;
|
|||||||
import org.apache.logging.log4j.LogManager;
|
import org.apache.logging.log4j.LogManager;
|
||||||
import org.apache.logging.log4j.Logger;
|
import org.apache.logging.log4j.Logger;
|
||||||
import org.bdware.sc.ContractMeta;
|
import org.bdware.sc.ContractMeta;
|
||||||
|
import org.bdware.sc.YPKResourceManager;
|
||||||
import org.bdware.sc.conn.ResultCallback;
|
import org.bdware.sc.conn.ResultCallback;
|
||||||
import org.bdware.sc.util.JsonUtil;
|
import org.bdware.sc.util.JsonUtil;
|
||||||
import org.bdware.server.action.CMActions;
|
import org.bdware.server.action.CMActions;
|
||||||
@ -21,7 +23,6 @@ import org.zz.gmhelper.SM2Util;
|
|||||||
import java.io.*;
|
import java.io.*;
|
||||||
import java.net.URLDecoder;
|
import java.net.URLDecoder;
|
||||||
import java.util.*;
|
import java.util.*;
|
||||||
import java.util.zip.ZipEntry;
|
|
||||||
import java.util.zip.ZipFile;
|
import java.util.zip.ZipFile;
|
||||||
|
|
||||||
import static io.netty.handler.codec.http.HttpVersion.HTTP_1_1;
|
import static io.netty.handler.codec.http.HttpVersion.HTTP_1_1;
|
||||||
@ -49,9 +50,18 @@ public class DOIPOverHttpHandler {
|
|||||||
lastModified.remove(str);
|
lastModified.remove(str);
|
||||||
zf.close();
|
zf.close();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
@URIPath({"/HTTPStat/"})
|
||||||
}
|
public void getHTTPStat(ChannelHandlerContext ctx, FullHttpRequest request) {
|
||||||
|
FullHttpResponse response =
|
||||||
|
new DefaultFullHttpResponse(HTTP_1_1, HttpResponseStatus.OK, Unpooled.wrappedBuffer(
|
||||||
|
new Gson().toJson(DOIPOverHttpStatics.httpRecords).getBytes()));
|
||||||
|
response.headers().set(HttpHeaderNames.CONTENT_TYPE, "text/plain; charset=UTF-8");
|
||||||
|
ctx.writeAndFlush(response).addListener(ChannelFutureListener.CLOSE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@URIPath({"/contracts/", "/DOIP/"})
|
@URIPath({"/contracts/", "/DOIP/"})
|
||||||
@ -188,6 +198,7 @@ public class DOIPOverHttpHandler {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void sendAssets(JsonObject arg, ChannelHandlerContext ctx) throws Exception {
|
private void sendAssets(JsonObject arg, ChannelHandlerContext ctx) throws Exception {
|
||||||
ContractMeta meta = CMActions.manager.statusRecorder
|
ContractMeta meta = CMActions.manager.statusRecorder
|
||||||
.getContractMeta(arg.get("contractID").getAsString());
|
.getContractMeta(arg.get("contractID").getAsString());
|
||||||
@ -196,15 +207,25 @@ public class DOIPOverHttpHandler {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
String path = arg.get("argument").getAsString();
|
String path = arg.get("argument").getAsString();
|
||||||
ZipFile zipFile = getZipFileFromPool(meta.contract.getScriptStr());
|
String dir = YPKResourceManager.getUnzipDir(meta.contract);
|
||||||
ZipEntry zipEntry = zipFile.getEntry(path);
|
File toSend = new File(dir, path);
|
||||||
if (zipEntry == null) {
|
if (!toSend.exists()) {
|
||||||
|
if (YPKResourceManager.existYPK(meta.contract)) {
|
||||||
|
YPKResourceManager.unzipYPK(meta.contract);
|
||||||
|
} else {
|
||||||
HttpFileHandleAdapter.sendError(ctx, HttpResponseStatus.NOT_FOUND);
|
HttpFileHandleAdapter.sendError(ctx, HttpResponseStatus.NOT_FOUND);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
InputStream in = zipFile.getInputStream(zipEntry);
|
}
|
||||||
|
InputStream in = YPKResourceManager.getCachedStream(meta.contract, path);
|
||||||
|
DOIPOverHttpStatics.Records httpRecords = new DOIPOverHttpStatics.Records();
|
||||||
|
httpRecords.start = System.currentTimeMillis();
|
||||||
|
httpRecords.url = path;
|
||||||
|
DOIPOverHttpStatics.httpRecords.add(httpRecords);
|
||||||
HttpResponse response = new DefaultHttpResponse(HTTP_1_1, HttpResponseStatus.OK);
|
HttpResponse response = new DefaultHttpResponse(HTTP_1_1, HttpResponseStatus.OK);
|
||||||
HttpFileHandleAdapter.appendContentType(path, response.headers());
|
HttpFileHandleAdapter.appendContentType(path, response.headers());
|
||||||
|
// HttpHeaders headers = response.headers();
|
||||||
|
// headers.set(HttpHeaderNames.CACHE_CONTROL, "public, max-age=2592000");
|
||||||
ctx.write(response);
|
ctx.write(response);
|
||||||
ChannelFuture future = ctx.writeAndFlush(new ChunkedStream(in));
|
ChannelFuture future = ctx.writeAndFlush(new ChunkedStream(in));
|
||||||
future.addListener(new GenericFutureListener<Future<? super Void>>() {
|
future.addListener(new GenericFutureListener<Future<? super Void>>() {
|
||||||
@ -212,6 +233,9 @@ public class DOIPOverHttpHandler {
|
|||||||
public void operationComplete(Future<? super Void> arg0) throws Exception {
|
public void operationComplete(Future<? super Void> arg0) throws Exception {
|
||||||
ctx.writeAndFlush(LastHttpContent.EMPTY_LAST_CONTENT);
|
ctx.writeAndFlush(LastHttpContent.EMPTY_LAST_CONTENT);
|
||||||
in.close();
|
in.close();
|
||||||
|
httpRecords.end = System.currentTimeMillis();
|
||||||
|
httpRecords.dur = httpRecords.end - httpRecords.start;
|
||||||
|
ctx.close();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// 写入文件尾部
|
// 写入文件尾部
|
||||||
@ -219,7 +243,7 @@ public class DOIPOverHttpHandler {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
private ZipFile getZipFileFromPool(String scriptStr) throws Exception {
|
private synchronized ZipFile getZipFileFromPool(String scriptStr) throws Exception {
|
||||||
try {
|
try {
|
||||||
ZipFile cachedFile = zipFilePool.get(scriptStr);
|
ZipFile cachedFile = zipFilePool.get(scriptStr);
|
||||||
if (cachedFile == null) {
|
if (cachedFile == null) {
|
||||||
|
@ -0,0 +1,15 @@
|
|||||||
|
package org.bdware.server.http;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
public class DOIPOverHttpStatics {
|
||||||
|
public static List<Records> httpRecords = new ArrayList<Records>();
|
||||||
|
|
||||||
|
static class Records {
|
||||||
|
long start;
|
||||||
|
long end;
|
||||||
|
long dur;
|
||||||
|
String url;
|
||||||
|
}
|
||||||
|
}
|
@ -117,7 +117,7 @@ public class NetworkManager {
|
|||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
// e.printStackTrace();
|
// e.printStackTrace();
|
||||||
LOGGER.warn("connecting to node center failed! " + e.getMessage());
|
// LOGGER.warn("connecting to node center failed! " + e.getMessage());
|
||||||
}
|
}
|
||||||
}, 4, 30 + (int) (20 * Math.random()), TimeUnit.SECONDS);
|
}, 4, 30 + (int) (20 * Math.random()), TimeUnit.SECONDS);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user