mirror of
https://gitee.com/BDWare/router-backend
synced 2025-01-10 01:44:05 +00:00
optimize file distribute
This commit is contained in:
parent
0fd984d5fd
commit
6030bdf2ad
@ -77,8 +77,9 @@ public class DistributeCallback extends ResultCallback {
|
|||||||
if (progress.equals("100.00")) index++;
|
if (progress.equals("100.00")) index++;
|
||||||
|
|
||||||
Map<String, String> map = new HashMap<>();
|
Map<String, String> map = new HashMap<>();
|
||||||
map.put("action", "onDistributeYPK");
|
map.put("action", "onDistribute");
|
||||||
map.put("responseID", distributeID);
|
map.put("responseID", distributeID);
|
||||||
|
map.put("distributeID", distributeID);
|
||||||
map.put("content", JsonUtil.toJson(ret2));
|
map.put("content", JsonUtil.toJson(ret2));
|
||||||
map.put("nodeIP", nodeIP);
|
map.put("nodeIP", nodeIP);
|
||||||
map.put("progress", progress);
|
map.put("progress", progress);
|
||||||
@ -86,7 +87,7 @@ public class DistributeCallback extends ResultCallback {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void onReceive(Map<String, String> map) {
|
public void onReceive(Map<String, String> map) {
|
||||||
LOGGER.debug("[DistributeCallback] onReceive : position----9");
|
LOGGER.info("[DistributeCallback] onReceive : position----9");
|
||||||
String progress = map.get("progress");
|
String progress = map.get("progress");
|
||||||
String nodeIP = map.get("ipPort");
|
String nodeIP = map.get("ipPort");
|
||||||
if (progress.equals("100")) {
|
if (progress.equals("100")) {
|
||||||
@ -95,15 +96,17 @@ public class DistributeCallback extends ResultCallback {
|
|||||||
args.put("pubKey", pubKey);
|
args.put("pubKey", pubKey);
|
||||||
args.put("signature", signature);
|
args.put("signature", signature);
|
||||||
count++;
|
count++;
|
||||||
LOGGER.debug(count + "个节点已收完成" + " 总共有" + nodes.size() + " 个节点");
|
LOGGER.info(count + "个节点已收完成" + " 总共有" + nodes.size() + " 个节点");
|
||||||
if (count == nodes.size()) {
|
if (count >= nodes.size() - 1) {
|
||||||
// res返回给前端,合约分发完成
|
// res返回给前端,合约分发完成
|
||||||
|
LOGGER.info("个节点已收完成" + "send on finish!!!!!");
|
||||||
Map<String, String> ret2 = new HashMap<>();
|
Map<String, String> ret2 = new HashMap<>();
|
||||||
ret2.put("action", "onDistributeFinish");
|
ret2.put("action", "onDistributeFinish");
|
||||||
ret2.put("progress", "100%");
|
ret2.put("progress", "100%");
|
||||||
Map<String, String> map_send = new HashMap<>();
|
Map<String, String> map_send = new HashMap<>();
|
||||||
map_send.put("action", "onDistribute");
|
map_send.put("action", "onDistribute");
|
||||||
map_send.put("responseID", distributeID);
|
map_send.put("responseID", distributeID);
|
||||||
|
map_send.put("distributeID", distributeID);
|
||||||
map_send.put("over", "true");
|
map_send.put("over", "true");
|
||||||
map_send.put("nodeIP", nodeIP);
|
map_send.put("nodeIP", nodeIP);
|
||||||
map_send.put("content", JsonUtil.toJson(ret2));
|
map_send.put("content", JsonUtil.toJson(ret2));
|
||||||
@ -118,7 +121,7 @@ public class DistributeCallback extends ResultCallback {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onResult(String str) {
|
public void onResult(String str) {
|
||||||
LOGGER.debug("[DistributeCallback] str=" + str);
|
LOGGER.info("[DistributeCallback] str=" + str);
|
||||||
|
|
||||||
Map<String, String> map = JsonUtil.fromJson(str, new TypeToken<Map<String, String>>() {
|
Map<String, String> map = JsonUtil.fromJson(str, new TypeToken<Map<String, String>>() {
|
||||||
}.getType());
|
}.getType());
|
||||||
@ -128,15 +131,19 @@ public class DistributeCallback extends ResultCallback {
|
|||||||
String operation = map.get("operation");
|
String operation = map.get("operation");
|
||||||
|
|
||||||
switch (operation) {
|
switch (operation) {
|
||||||
|
//上传到nodecenter
|
||||||
case "NCreceive":
|
case "NCreceive":
|
||||||
NCreceive(map.get("progress"));
|
NCreceive(map.get("progress"));
|
||||||
break;
|
break;
|
||||||
|
//开始分发给各个节点
|
||||||
case "distribute":
|
case "distribute":
|
||||||
distributeContractProject(map.get("receiveFileName"), map.get("isPrivate"));
|
distributeContractProject(map.get("receiveFileName"), map.get("isPrivate"));
|
||||||
break;
|
break;
|
||||||
|
//分发给各个节点
|
||||||
case "onDistribute":
|
case "onDistribute":
|
||||||
onDistribute(map.get("progress"), map.get("nodeIP"));
|
onDistribute(map.get("progress"), map.get("nodeIP"));
|
||||||
break;
|
break;
|
||||||
|
//各个节点返回收到
|
||||||
case "onReceive":
|
case "onReceive":
|
||||||
onReceive(map);
|
onReceive(map);
|
||||||
break;
|
break;
|
||||||
|
@ -130,7 +130,7 @@ public class LogActions {
|
|||||||
@Action(userPermission = 1 << 9, async = true)
|
@Action(userPermission = 1 << 9, async = true)
|
||||||
public void listNodes(JsonObject json, ResultCallback resultCallback) {
|
public void listNodes(JsonObject json, ResultCallback resultCallback) {
|
||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
final String pubKey = managerAction.pubKey;
|
final String pubKey = managerAction.getPubKey(json);
|
||||||
LOGGER.debug("[listNodes] managerAction.pubKey " + pubKey);
|
LOGGER.debug("[listNodes] managerAction.pubKey " + pubKey);
|
||||||
Map<String, CMNode> nodeinfos = NodeCenterActions.nodeInfos; // 所有在线节点?
|
Map<String, CMNode> nodeinfos = NodeCenterActions.nodeInfos; // 所有在线节点?
|
||||||
final Map<String, CMNode> cinodeinfos = new HashMap<>();
|
final Map<String, CMNode> cinodeinfos = new HashMap<>();
|
||||||
|
@ -28,11 +28,7 @@ import org.bdware.server.nodecenter.searchresult.ContractMeta;
|
|||||||
import org.bdware.server.nodecenter.searchresult.ResultModel;
|
import org.bdware.server.nodecenter.searchresult.ResultModel;
|
||||||
import org.wltea.analyzer.lucene.IKAnalyzer;
|
import org.wltea.analyzer.lucene.IKAnalyzer;
|
||||||
|
|
||||||
import java.io.ByteArrayOutputStream;
|
import java.io.*;
|
||||||
import java.io.File;
|
|
||||||
import java.io.IOException;
|
|
||||||
import java.io.PrintStream;
|
|
||||||
import java.io.InputStreamReader;
|
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.nio.file.Paths;
|
import java.nio.file.Paths;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@ -105,9 +101,9 @@ public class MetaIndexAction { // public static IndexWriter indexWriter;
|
|||||||
LOGGER.warn("getting index failed! " + e.getMessage());
|
LOGGER.warn("getting index failed! " + e.getMessage());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
req.addProperty("action", "requestReadMe");
|
// req.addProperty("action", "requestReadMe");
|
||||||
req.addProperty("contractID", thisDesp.contractID);
|
// req.addProperty("contractID", thisDesp.contractID);
|
||||||
rc.onResult(req);
|
// rc.onResult(req);
|
||||||
LOGGER.info("contract " + thisDesp.contractName + " --> actually to index");
|
LOGGER.info("contract " + thisDesp.contractName + " --> actually to index");
|
||||||
}
|
}
|
||||||
if (null != indexReader) {
|
if (null != indexReader) {
|
||||||
|
@ -1,10 +1,8 @@
|
|||||||
package org.bdware.server.nodecenter;
|
package org.bdware.server.nodecenter;
|
||||||
|
|
||||||
import com.google.gson.JsonObject;
|
import com.google.gson.JsonObject;
|
||||||
import com.google.gson.JsonParser;
|
|
||||||
import com.google.gson.reflect.TypeToken;
|
import com.google.gson.reflect.TypeToken;
|
||||||
import io.netty.buffer.ByteBuf;
|
import io.netty.buffer.ByteBuf;
|
||||||
import io.netty.buffer.ByteBufInputStream;
|
|
||||||
import io.netty.buffer.Unpooled;
|
import io.netty.buffer.Unpooled;
|
||||||
import io.netty.channel.ChannelFuture;
|
import io.netty.channel.ChannelFuture;
|
||||||
import io.netty.channel.ChannelFutureListener;
|
import io.netty.channel.ChannelFutureListener;
|
||||||
@ -22,13 +20,15 @@ import org.bdware.server.NodeCenterServer;
|
|||||||
import org.bdware.server.action.Action;
|
import org.bdware.server.action.Action;
|
||||||
import org.bdware.server.action.ActionExecutor;
|
import org.bdware.server.action.ActionExecutor;
|
||||||
import org.bdware.server.action.HttpResultCallback;
|
import org.bdware.server.action.HttpResultCallback;
|
||||||
import org.bdware.server.http.HttpFileHandleAdapter;
|
import org.bdware.server.http.HttpMethod;
|
||||||
import org.bdware.server.http.URIHandler;
|
import org.bdware.server.http.*;
|
||||||
import org.bdware.server.http.URIPath;
|
|
||||||
import org.bdware.server.permission.Role;
|
import org.bdware.server.permission.Role;
|
||||||
import org.zz.gmhelper.SM2Util;
|
import org.zz.gmhelper.SM2Util;
|
||||||
|
|
||||||
import java.io.*;
|
import java.io.ByteArrayOutputStream;
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileFilter;
|
||||||
|
import java.io.PrintStream;
|
||||||
import java.net.URLDecoder;
|
import java.net.URLDecoder;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
@ -43,9 +43,14 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
private static final String UNSUPPORTED_HTTP_METHOD = "{\"msg\":\"unsupported http method\"}";
|
private static final String UNSUPPORTED_HTTP_METHOD = "{\"msg\":\"unsupported http method\"}";
|
||||||
private static final String UNSUPPORTED_ACTION = "{\"msg\":\"unsupported action\"}";
|
private static final String UNSUPPORTED_ACTION = "{\"msg\":\"unsupported action\"}";
|
||||||
private static final Logger LOGGER = LogManager.getLogger(NCHttpHandler.class);
|
private static final Logger LOGGER = LogManager.getLogger(NCHttpHandler.class);
|
||||||
|
static NCManagerAction managerAction = new NCManagerAction(null);
|
||||||
|
static LogActions logActions = new LogActions(managerAction);
|
||||||
|
static UnitActions unitActions = new UnitActions(managerAction);
|
||||||
private static final ActionExecutor<ResultCallback, JsonObject> actionExecutor =
|
private static final ActionExecutor<ResultCallback, JsonObject> actionExecutor =
|
||||||
new ActionExecutor<ResultCallback, JsonObject>(
|
new ActionExecutor<ResultCallback, JsonObject>(
|
||||||
NodeCenterFrameHandler.executorService, new NodeCenterActions(null)) {
|
NodeCenterFrameHandler.executorService,
|
||||||
|
new NodeCenterActions(null),
|
||||||
|
managerAction, logActions, unitActions) {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean checkPermission(Action a, JsonObject arg, long per) {
|
public boolean checkPermission(Action a, JsonObject arg, long per) {
|
||||||
@ -119,42 +124,61 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
ctx.flush();
|
ctx.flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
@URIPath({"/NodeCenter", "/SCIDE/SCExecutor", "/SCIDE/CMManager", "/SCIDE/SCManager"})
|
public static class VerifiyCallback implements ArgParser.VerifiedCallback {
|
||||||
public void parseGetAndHandle(ChannelHandlerContext ctx, FullHttpRequest req) {
|
|
||||||
QueryStringDecoder decoderQuery = new QueryStringDecoder(req.uri());
|
@Override
|
||||||
Map<String, List<String>> params = decoderQuery.parameters();
|
public void onResult(boolean verified, JsonObject transformedParam) {
|
||||||
JsonObject map = new JsonObject();
|
LOGGER.info("verify signature: " + verified);
|
||||||
for (String key : params.keySet()) {
|
if (verified) {
|
||||||
List<String> val = params.get(key);
|
// 查permission
|
||||||
if (val != null) map.addProperty(key, val.get(0));
|
String ret = getRole(transformedParam.get("pubKey").getAsString());
|
||||||
|
long permission;
|
||||||
|
if (ret != null && ret.length() > 0) {
|
||||||
|
permission = 0x86000d41L | Role.compoundValue(ret.split(","));
|
||||||
|
} else {
|
||||||
|
permission = Role.compoundValue(ret.split(","));
|
||||||
|
}
|
||||||
|
transformedParam.addProperty("permission", permission + "");
|
||||||
|
LOGGER.debug("[CMHttpHandler] http 请求查看用户权限为 : " + permission);
|
||||||
|
} else {
|
||||||
|
transformedParam.addProperty("permission", 0 + "");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
String uri = URLDecoder.decode(req.uri()).split("\\?")[1];
|
|
||||||
int index = uri.lastIndexOf('&');
|
|
||||||
String str = uri;
|
|
||||||
if (index != -1) {
|
|
||||||
str = uri.substring(0, index);
|
|
||||||
}
|
|
||||||
injectPermission(map, str);
|
|
||||||
handleReq(map, ctx);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@URIPath(
|
@URIPath(method = HttpMethod.OPTIONS)
|
||||||
method = org.bdware.server.http.HttpMethod.POST,
|
public void crossOrigin(ChannelHandlerContext ctx, FullHttpRequest request) {
|
||||||
|
DefaultFullHttpResponse fullResponse =
|
||||||
|
new DefaultFullHttpResponse(
|
||||||
|
request.protocolVersion(),
|
||||||
|
OK,
|
||||||
|
Unpooled.wrappedBuffer("success".getBytes()));
|
||||||
|
fullResponse.headers().remove("Access-Control-Allow-Origin");
|
||||||
|
fullResponse.headers().remove("Access-Control-Allow-Headers");
|
||||||
|
fullResponse.headers().add("Access-Control-Allow-Origin", "*");
|
||||||
|
fullResponse.headers().add("Access-Control-Allow-Methods", "*");
|
||||||
|
fullResponse
|
||||||
|
.headers()
|
||||||
|
.add("Access-Control-Allow-Headers",
|
||||||
|
"Content-Type, Cookie, Accept-Encoding, User-Agent, Host, Referer, " +
|
||||||
|
"X-Requested-With, Accept, Accept-Language, Cache-Control, Connection");
|
||||||
|
ChannelFuture f = ctx.write(fullResponse);
|
||||||
|
f.addListener(ChannelFutureListener.CLOSE);
|
||||||
|
LOGGER.info("[Option] received!");
|
||||||
|
}
|
||||||
|
|
||||||
|
@URIPath({"/NodeCenter", "/SCIDE/SCExecutor", "/SCIDE/CMManager", "/SCIDE/SCManager"})
|
||||||
|
public void parseGetAndHandle(ChannelHandlerContext ctx, FullHttpRequest req) throws Exception {
|
||||||
|
JsonObject transformedParam = ArgParser.parseGetAndVerify(req, new VerifiyCallback());
|
||||||
|
handleReq(transformedParam, ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
@URIPath(method = org.bdware.server.http.HttpMethod.POST,
|
||||||
value = {"/NodeCenter", "/SCIDE/SCExecutor", "/SCIDE/CMManager", "/SCIDE/SCManager"})
|
value = {"/NodeCenter", "/SCIDE/SCExecutor", "/SCIDE/CMManager", "/SCIDE/SCManager"})
|
||||||
public void parsePostAndHandle(ChannelHandlerContext ctx, FullHttpRequest req)
|
public void parsePostAndHandle(ChannelHandlerContext ctx, FullHttpRequest req)
|
||||||
throws UnsupportedEncodingException {
|
throws Exception {
|
||||||
ByteBuf content = req.content();
|
JsonObject map = ArgParser.parsePostAndVerify(req, new VerifiyCallback());
|
||||||
JsonObject map =
|
// injectPermission(map, str);
|
||||||
JsonParser.parseReader(new InputStreamReader(new ByteBufInputStream(content)))
|
|
||||||
.getAsJsonObject();
|
|
||||||
// FIXME 感觉不太对劲
|
|
||||||
String uri = URLDecoder.decode(req.uri(), "utf-8").split("\\?")[1];
|
|
||||||
int index = uri.lastIndexOf('&');
|
|
||||||
String str = uri;
|
|
||||||
if (index != -1) {
|
|
||||||
str = uri.substring(0, index);
|
|
||||||
}
|
|
||||||
injectPermission(map, str);
|
|
||||||
handleReq(map, ctx);
|
handleReq(map, ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,6 +213,8 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
HttpVersion.HTTP_1_1,
|
HttpVersion.HTTP_1_1,
|
||||||
OK,
|
OK,
|
||||||
Unpooled.wrappedBuffer(MetaIndexAction.search(map).getBytes()));
|
Unpooled.wrappedBuffer(MetaIndexAction.search(map).getBytes()));
|
||||||
|
response.headers().add("Access-Control-Allow-Origin", "*");
|
||||||
|
response.headers().add("Access-Control-Allow-Methods", "*");
|
||||||
ChannelFuture f = ctx.write(response);
|
ChannelFuture f = ctx.write(response);
|
||||||
f.addListener(ChannelFutureListener.CLOSE);
|
f.addListener(ChannelFutureListener.CLOSE);
|
||||||
|
|
||||||
@ -205,7 +231,7 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getRole(String pubKey) {
|
public static String getRole(String pubKey) {
|
||||||
try {
|
try {
|
||||||
String ret =
|
String ret =
|
||||||
KeyValueDBUtil.instance.getValue(
|
KeyValueDBUtil.instance.getValue(
|
||||||
@ -239,7 +265,6 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
String pubkey = map.get("pubKey").getAsString();
|
String pubkey = map.get("pubKey").getAsString();
|
||||||
boolean verify = SM2Util.plainStrVerify(pubkey, str, map.get("sign").getAsString());
|
boolean verify = SM2Util.plainStrVerify(pubkey, str, map.get("sign").getAsString());
|
||||||
LOGGER.debug("[CMHttpHandler] HTTP POST 请求验签为 " + verify);
|
LOGGER.debug("[CMHttpHandler] HTTP POST 请求验签为 " + verify);
|
||||||
|
|
||||||
if (verify) {
|
if (verify) {
|
||||||
// 查permission
|
// 查permission
|
||||||
String ret = getRole(pubkey);
|
String ret = getRole(pubkey);
|
||||||
@ -281,13 +306,15 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
cb = new HttpResultCallback(ctx, map.get("callback").getAsString());
|
cb = new HttpResultCallback(ctx, map.get("callback").getAsString());
|
||||||
cb.addHeader("charset", "utf-8");
|
cb.addHeader("charset", "utf-8");
|
||||||
cb.addHeader("Content-type", "text/plain");
|
cb.addHeader("Content-type", "text/plain");
|
||||||
|
cb.addHeader("Access-Control-Allow-Origin", "*");
|
||||||
|
cb.addHeader("Access-Control-Allow-Methods", "*");
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
if (map.has("callback"))
|
if (map.has("callback"))
|
||||||
cb = new HttpResultCallback(ctx, map.get("callback").getAsString());
|
cb = new HttpResultCallback(ctx, map.get("callback").getAsString());
|
||||||
else cb = new HttpResultCallback(ctx, null);
|
else cb = new HttpResultCallback(ctx, null);
|
||||||
|
cb.addHeader("Access-Control-Allow-Origin", "*");
|
||||||
|
cb.addHeader("Access-Control-Allow-Methods", "*");
|
||||||
cb.addHeader("charset", "utf-8");
|
cb.addHeader("charset", "utf-8");
|
||||||
cb.addHeader("Content-type", "application/json");
|
cb.addHeader("Content-type", "application/json");
|
||||||
}
|
}
|
||||||
@ -296,6 +323,8 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
DefaultFullHttpResponse response =
|
DefaultFullHttpResponse response =
|
||||||
new DefaultFullHttpResponse(
|
new DefaultFullHttpResponse(
|
||||||
HttpVersion.HTTP_1_1, OK, Unpooled.wrappedBuffer(ret.getBytes()));
|
HttpVersion.HTTP_1_1, OK, Unpooled.wrappedBuffer(ret.getBytes()));
|
||||||
|
response.headers().add("Access-Control-Allow-Origin", "*");
|
||||||
|
response.headers().add("Access-Control-Allow-Methods", "*");
|
||||||
ChannelFuture f = ctx.write(response);
|
ChannelFuture f = ctx.write(response);
|
||||||
f.addListener(ChannelFutureListener.CLOSE);
|
f.addListener(ChannelFutureListener.CLOSE);
|
||||||
}
|
}
|
||||||
@ -305,6 +334,8 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
HttpVersion.HTTP_1_1,
|
HttpVersion.HTTP_1_1,
|
||||||
OK,
|
OK,
|
||||||
Unpooled.wrappedBuffer(e.getMessage().getBytes()));
|
Unpooled.wrappedBuffer(e.getMessage().getBytes()));
|
||||||
|
response.headers().add("Access-Control-Allow-Origin", "*");
|
||||||
|
response.headers().add("Access-Control-Allow-Methods", "*");
|
||||||
ChannelFuture f = ctx.write(response);
|
ChannelFuture f = ctx.write(response);
|
||||||
f.addListener(ChannelFutureListener.CLOSE);
|
f.addListener(ChannelFutureListener.CLOSE);
|
||||||
|
|
||||||
@ -318,6 +349,8 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
|||||||
HttpVersion.HTTP_1_1,
|
HttpVersion.HTTP_1_1,
|
||||||
OK,
|
OK,
|
||||||
Unpooled.wrappedBuffer(JsonUtil.toJson(ret).getBytes()));
|
Unpooled.wrappedBuffer(JsonUtil.toJson(ret).getBytes()));
|
||||||
|
response.headers().add("Access-Control-Allow-Origin", "*");
|
||||||
|
response.headers().add("Access-Control-Allow-Methods", "*");
|
||||||
ChannelFuture f = ctx.write(response);
|
ChannelFuture f = ctx.write(response);
|
||||||
f.addListener(ChannelFutureListener.CLOSE);
|
f.addListener(ChannelFutureListener.CLOSE);
|
||||||
}
|
}
|
||||||
|
@ -34,13 +34,22 @@ public class NCManagerAction {
|
|||||||
SM2Util.DOMAIN_PARAMS);
|
SM2Util.DOMAIN_PARAMS);
|
||||||
private static final Logger LOGGER = LogManager.getLogger(NCManagerAction.class);
|
private static final Logger LOGGER = LogManager.getLogger(NCManagerAction.class);
|
||||||
String sessionID = null;
|
String sessionID = null;
|
||||||
String pubKey;
|
private String publicKey;
|
||||||
Random random = new Random();
|
Random random = new Random();
|
||||||
private NodeCenterWSFrameHandler handler;
|
private NodeCenterWSFrameHandler handler;
|
||||||
|
|
||||||
public NCManagerAction(NodeCenterWSFrameHandler nodeCenterWSFrameHandler) {
|
public NCManagerAction(NodeCenterWSFrameHandler nodeCenterWSFrameHandler) {
|
||||||
this.handler = nodeCenterWSFrameHandler;
|
this.handler = nodeCenterWSFrameHandler;
|
||||||
pubKey = null;
|
publicKey = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getPubKey(JsonObject jo) {
|
||||||
|
try {
|
||||||
|
if (publicKey != null) return publicKey;
|
||||||
|
return jo.get("pubKey").getAsString();
|
||||||
|
} catch (Exception e) {
|
||||||
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean isCenterManager(String pubkey) {
|
public static boolean isCenterManager(String pubkey) {
|
||||||
@ -104,6 +113,7 @@ public class NCManagerAction {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void getRole(JsonObject json, ResultCallback resultCallback) {
|
public void getRole(JsonObject json, ResultCallback resultCallback) {
|
||||||
|
String pubKey = getPubKey(json);
|
||||||
if (pubKey == null) {
|
if (pubKey == null) {
|
||||||
simpleReply(resultCallback, "onLogin", Role.Anonymous.name());
|
simpleReply(resultCallback, "onLogin", Role.Anonymous.name());
|
||||||
return;
|
return;
|
||||||
@ -156,7 +166,7 @@ public class NCManagerAction {
|
|||||||
boolean result = SM2Util.plainStrVerify(pubKey, sessionID, signature);
|
boolean result = SM2Util.plainStrVerify(pubKey, sessionID, signature);
|
||||||
LOGGER.debug("session:" + (sessionID));
|
LOGGER.debug("session:" + (sessionID));
|
||||||
if (result) {
|
if (result) {
|
||||||
this.pubKey = pubKey;
|
this.publicKey = pubKey;
|
||||||
LOGGER.debug("设置公钥" + pubKey);
|
LOGGER.debug("设置公钥" + pubKey);
|
||||||
getRole(json, resultCallback);
|
getRole(json, resultCallback);
|
||||||
} else {
|
} else {
|
||||||
@ -168,6 +178,8 @@ public class NCManagerAction {
|
|||||||
|
|
||||||
@Action(userPermission = 0)
|
@Action(userPermission = 0)
|
||||||
public void applyRole(JsonObject json, ResultCallback resultCallback) {
|
public void applyRole(JsonObject json, ResultCallback resultCallback) {
|
||||||
|
String pubKey = getPubKey(json);
|
||||||
|
|
||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
if (pubKey == null) {
|
if (pubKey == null) {
|
||||||
simpleReply(resultCallback, "onApplyRole", "missing pubKey");
|
simpleReply(resultCallback, "onApplyRole", "missing pubKey");
|
||||||
@ -176,7 +188,7 @@ public class NCManagerAction {
|
|||||||
if (json.has("role")) {
|
if (json.has("role")) {
|
||||||
Role role = Role.parse(json.get("role").getAsString());
|
Role role = Role.parse(json.get("role").getAsString());
|
||||||
if (role != Role.Anonymous) {
|
if (role != Role.Anonymous) {
|
||||||
applyAtDB(role, resultCallback, start);
|
applyAtDB(role, getPubKey(json), resultCallback, start);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -201,7 +213,9 @@ public class NCManagerAction {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void applyAtDB(Role role, ResultCallback resultCallback, long start) {
|
private void applyAtDB(Role role, String pubKey, ResultCallback resultCallback, long start) {
|
||||||
|
|
||||||
|
|
||||||
String str = KeyValueDBUtil.instance.getValue(NCTables.ApplyRole.toString(), pubKey);
|
String str = KeyValueDBUtil.instance.getValue(NCTables.ApplyRole.toString(), pubKey);
|
||||||
String already = KeyValueDBUtil.instance.getValue(NCTables.NodeUser.toString(), pubKey);
|
String already = KeyValueDBUtil.instance.getValue(NCTables.NodeUser.toString(), pubKey);
|
||||||
if (already != null && already.contains(role.toString())) {
|
if (already != null && already.contains(role.toString())) {
|
||||||
@ -241,6 +255,9 @@ public class NCManagerAction {
|
|||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
String pubKey = json.get("pubKey").getAsString();
|
String pubKey = json.get("pubKey").getAsString();
|
||||||
boolean isAccept = json.get("isAccept").getAsBoolean();
|
boolean isAccept = json.get("isAccept").getAsBoolean();
|
||||||
|
if (json.has("authorizedPubKey")) {
|
||||||
|
pubKey = json.get("authorizedPubKey").getAsString();
|
||||||
|
}
|
||||||
LOGGER.debug("[NCManagerAction] " + json.toString());
|
LOGGER.debug("[NCManagerAction] " + json.toString());
|
||||||
if (pubKey == null || pubKey.length() == 0) {
|
if (pubKey == null || pubKey.length() == 0) {
|
||||||
simpleReply(resultCallback, "onAuthNodeManager", "missing pubKey");
|
simpleReply(resultCallback, "onAuthNodeManager", "missing pubKey");
|
||||||
|
@ -41,7 +41,7 @@ public class NodeCenterActions {
|
|||||||
// TODO 定期清缓存
|
// TODO 定期清缓存
|
||||||
// public static Map<String, RequestCache> requestCache =
|
// public static Map<String, RequestCache> requestCache =
|
||||||
// new ConcurrentHashMap<>(); // key is contractID,only for requestAll type contract
|
// new ConcurrentHashMap<>(); // key is contractID,only for requestAll type contract
|
||||||
TimerTask checkAliveTask;
|
// TimerTask checkAliveTask;
|
||||||
static Timer checkAliveTimer = new Timer();
|
static Timer checkAliveTimer = new Timer();
|
||||||
public NodeCenterFrameHandler controller;
|
public NodeCenterFrameHandler controller;
|
||||||
String nodeID; // node pubKey
|
String nodeID; // node pubKey
|
||||||
@ -129,9 +129,9 @@ public class NodeCenterActions {
|
|||||||
@Action
|
@Action
|
||||||
public void syncPing(JsonObject json, ResultCallback rc) {
|
public void syncPing(JsonObject json, ResultCallback rc) {
|
||||||
// logger.debug("[NodeCenterAction] syncPing");
|
// logger.debug("[NodeCenterAction] syncPing");
|
||||||
checkAliveTask.cancel();
|
//checkAliveTask.cancel();
|
||||||
checkAliveTask = new CheckAgentAliveTimer(nodeID);
|
//checkAliveTask = new CheckAgentAliveTimer(nodeID);
|
||||||
checkAliveTimer.schedule(checkAliveTask, 20000L);
|
//checkAliveTimer.schedule(checkAliveTask, 200000L);
|
||||||
if (json.has("data")) {
|
if (json.has("data")) {
|
||||||
String data = json.get("data").getAsString();
|
String data = json.get("data").getAsString();
|
||||||
LOGGER.debug("[syncPing] data" + data);
|
LOGGER.debug("[syncPing] data" + data);
|
||||||
@ -229,8 +229,8 @@ public class NodeCenterActions {
|
|||||||
r.data = "failed";
|
r.data = "failed";
|
||||||
if (sessionID != null && SM2Util.plainStrVerify(pubkey, pubkey + sessionID, signature)) {
|
if (sessionID != null && SM2Util.plainStrVerify(pubkey, pubkey + sessionID, signature)) {
|
||||||
nodeID = pubkey;
|
nodeID = pubkey;
|
||||||
checkAliveTask = new CheckAgentAliveTimer(nodeID);
|
//checkAliveTask = new CheckAgentAliveTimer(nodeID);
|
||||||
checkAliveTimer.schedule(checkAliveTask, 20000L);
|
//checkAliveTimer.schedule(checkAliveTask, 20000L);
|
||||||
|
|
||||||
|
|
||||||
controller.pubKey = nodeID;
|
controller.pubKey = nodeID;
|
||||||
@ -274,30 +274,30 @@ public class NodeCenterActions {
|
|||||||
|
|
||||||
// TODO 如果是NC挂了,其他节点重连之后需要另外考虑
|
// TODO 如果是NC挂了,其他节点重连之后需要另外考虑
|
||||||
// 向该合约发送请求,令其查看自己崩溃前的集群合约
|
// 向该合约发送请求,令其查看自己崩溃前的集群合约
|
||||||
LOGGER.info("NodeCenter tells nodes new masters for contracts created before the crash!");
|
// LOGGER.info("NodeCenter tells nodes new masters for contracts created before the crash!");
|
||||||
Map<String, String> request = new HashMap<>();
|
// Map<String, String> request = new HashMap<>();
|
||||||
request.put("action", "queryUnitContractsID");
|
// request.put("action", "queryUnitContractsID");
|
||||||
try {
|
// try {
|
||||||
CMNode conn = nodeInfos.get(pubkey);
|
//// CMNode conn = nodeInfos.get(pubkey);
|
||||||
NodeCenterActions connection = conn.connection;
|
//// NodeCenterActions connection = conn.connection;
|
||||||
NodeCenterFrameHandler connController = connection.controller;
|
//// NodeCenterFrameHandler connController = connection.controller;
|
||||||
connController.sendMsg(JsonUtil.toJson(request));
|
//// connController.sendMsg(JsonUtil.toJson(request));
|
||||||
} catch (Exception e) {
|
// } catch (Exception e) {
|
||||||
e.printStackTrace();
|
// e.printStackTrace();
|
||||||
}
|
// }
|
||||||
Map<String, String> onNewNodeConnected = new HashMap<>();
|
// Map<String, String> onNewNodeConnected = new HashMap<>();
|
||||||
onNewNodeConnected.put("action", "onNewNodeConnected");
|
// onNewNodeConnected.put("action", "onNewNodeConnected");
|
||||||
onNewNodeConnected.put("pubKey", pubkey);
|
// onNewNodeConnected.put("pubKey", pubkey);
|
||||||
for (CMNode node : nodeInfos.values()) {
|
// for (CMNode node : nodeInfos.values()) {
|
||||||
if (node.pubKey.equals(pubkey)) {
|
// if (node.pubKey.equals(pubkey)) {
|
||||||
continue;
|
// continue;
|
||||||
}
|
// }
|
||||||
try {
|
// try {
|
||||||
node.connection.controller.sendMsg(JsonUtil.toJson(onNewNodeConnected));
|
// // node.connection.controller.sendMsg(JsonUtil.toJson(onNewNodeConnected));
|
||||||
} catch (Exception e) {
|
// } catch (Exception e) {
|
||||||
e.printStackTrace();
|
// e.printStackTrace();
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
rc.onResult(JsonUtil.toJson(r));
|
rc.onResult(JsonUtil.toJson(r));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -366,7 +366,7 @@ public class NodeCenterActions {
|
|||||||
json.get("contracts"),
|
json.get("contracts"),
|
||||||
new TypeToken<List<ContractDesp>>() {
|
new TypeToken<List<ContractDesp>>() {
|
||||||
}.getType());
|
}.getType());
|
||||||
MetaIndexAction.updateContractsIndex(contracts, rc);
|
//MetaIndexAction.updateContractsIndex(contracts, rc);
|
||||||
LOGGER.debug("update contracts: " + json.get("contracts"));
|
LOGGER.debug("update contracts: " + json.get("contracts"));
|
||||||
int version = -1;
|
int version = -1;
|
||||||
if (json.has("contractVersion")) {
|
if (json.has("contractVersion")) {
|
||||||
@ -376,6 +376,8 @@ public class NodeCenterActions {
|
|||||||
if (json.has("events")) {
|
if (json.has("events")) {
|
||||||
node.events = json.get("events").getAsInt();
|
node.events = json.get("events").getAsInt();
|
||||||
}
|
}
|
||||||
|
//just ignore recover
|
||||||
|
if (nodeInfos != null) return;
|
||||||
// 遍历所有节点
|
// 遍历所有节点
|
||||||
for (CMNode cmNode : nodeInfos.values()) {
|
for (CMNode cmNode : nodeInfos.values()) {
|
||||||
if (cmNode.pubKey.equals(nodeID)) {
|
if (cmNode.pubKey.equals(nodeID)) {
|
||||||
@ -1018,7 +1020,7 @@ public class NodeCenterActions {
|
|||||||
if (project.isFile()) {
|
if (project.isFile()) {
|
||||||
try {
|
try {
|
||||||
FileInputStream fin = new FileInputStream(project);
|
FileInputStream fin = new FileInputStream(project);
|
||||||
byte[] buff = new byte[30 * 1024];
|
byte[] buff = new byte[500 * 1024];
|
||||||
long count = 0;
|
long count = 0;
|
||||||
long preCount = 0;
|
long preCount = 0;
|
||||||
long total = project.length();
|
long total = project.length();
|
||||||
|
@ -47,7 +47,7 @@ public class NodeCenterWSFrameHandler extends SimpleChannelInboundHandler<WebSoc
|
|||||||
// Permission userPermission = a.userPermission();
|
// Permission userPermission = a.userPermission();
|
||||||
// long val=userPermission.getValue();
|
// long val=userPermission.getValue();
|
||||||
long val = a.userPermission();
|
long val = a.userPermission();
|
||||||
String pubKey = managerAction.pubKey;
|
String pubKey = managerAction.getPubKey(null);
|
||||||
String action = arg.get("action").getAsString();
|
String action = arg.get("action").getAsString();
|
||||||
LOGGER.debug("permission" + permission);
|
LOGGER.debug("permission" + permission);
|
||||||
LOGGER.debug("userPermission" + val);
|
LOGGER.debug("userPermission" + val);
|
||||||
@ -73,6 +73,7 @@ public class NodeCenterWSFrameHandler extends SimpleChannelInboundHandler<WebSoc
|
|||||||
ae.appendHandler(obj);
|
ae.appendHandler(obj);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private Object createInstanceByClzName(String clzName) {
|
private Object createInstanceByClzName(String clzName) {
|
||||||
try {
|
try {
|
||||||
Class<?> clz = Class.forName(clzName, true, pluginLoader);
|
Class<?> clz = Class.forName(clzName, true, pluginLoader);
|
||||||
@ -81,12 +82,13 @@ public class NodeCenterWSFrameHandler extends SimpleChannelInboundHandler<WebSoc
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ActionExecutor getAE() {
|
public ActionExecutor getAE() {
|
||||||
return ae;
|
return ae;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String getPubKey() {
|
public String getPubKey() {
|
||||||
return managerAction.pubKey;
|
return managerAction.getPubKey(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -45,7 +45,7 @@ public class UnitActions {
|
|||||||
@Action(userPermission = 1 << 6, async = true)
|
@Action(userPermission = 1 << 6, async = true)
|
||||||
public void listTrustUnits(JsonObject json, ResultCallback resultCallback) {
|
public void listTrustUnits(JsonObject json, ResultCallback resultCallback) {
|
||||||
long start = System.currentTimeMillis();
|
long start = System.currentTimeMillis();
|
||||||
final String pubKey = managerAction.pubKey;
|
final String pubKey = managerAction.getPubKey(json);
|
||||||
List<KV> allunits = KeyValueDBUtil.instance.getKeyValues(NCTables.TrustUnitsDB.toString());
|
List<KV> allunits = KeyValueDBUtil.instance.getKeyValues(NCTables.TrustUnitsDB.toString());
|
||||||
if (pubKey != null
|
if (pubKey != null
|
||||||
&& KeyValueDBUtil.instance
|
&& KeyValueDBUtil.instance
|
||||||
@ -73,7 +73,7 @@ public class UnitActions {
|
|||||||
|
|
||||||
@Action(userPermission = 1 << 6, async = true)
|
@Action(userPermission = 1 << 6, async = true)
|
||||||
public void createTrustUnit(JsonObject json, ResultCallback resultCallback) {
|
public void createTrustUnit(JsonObject json, ResultCallback resultCallback) {
|
||||||
final String pubKey = managerAction.pubKey;
|
final String pubKey = managerAction.getPubKey(json);
|
||||||
LOGGER.debug("[createTrustUnit] " + json.get("data").toString());
|
LOGGER.debug("[createTrustUnit] " + json.get("data").toString());
|
||||||
KeyValueDBUtil.instance.setValue(
|
KeyValueDBUtil.instance.setValue(
|
||||||
NCTables.TrustUnitsDB.toString(),
|
NCTables.TrustUnitsDB.toString(),
|
||||||
|
Loading…
Reference in New Issue
Block a user