mirror of
https://gitee.com/BDWare/router-backend
synced 2025-01-10 01:44:05 +00:00
add update node manager
This commit is contained in:
parent
6030bdf2ad
commit
144804efd0
@ -27,6 +27,7 @@ import org.bdware.sc.db.MultiIndexTimeRocksDBUtil;
|
||||
import org.bdware.sc.db.TimeDBUtil;
|
||||
import org.bdware.server.irp.LocalLHSProxy;
|
||||
import org.bdware.server.nodecenter.*;
|
||||
import org.bdware.server.permission.Role;
|
||||
import org.bdware.server.ws.DelimiterCodec;
|
||||
|
||||
import java.io.BufferedReader;
|
||||
@ -143,7 +144,7 @@ public class NodeCenterServer {
|
||||
NCTables.ConfigDB.toString(), NCManagerAction.centerManger, pubKey);
|
||||
KeyValueDBUtil.instance.setValue(
|
||||
NCTables.ConfigDB.toString(), NCManagerAction.clusterName, "clusterName_" + pubKey.substring(0, 5));
|
||||
KeyValueDBUtil.instance.setValue(NCTables.NodeUser.toString(), pubKey, "NodeManager");
|
||||
KeyValueDBUtil.instance.setValue(NCTables.NodeUser.toString(), pubKey, Role.CenterManager.toString());
|
||||
KeyValueDBUtil.instance.setValue(
|
||||
NCTables.NodeTime.toString(), pubKey, Long.toString(new Date().getTime()));
|
||||
LOGGER.info("set node manager from manager.key");
|
||||
|
@ -96,12 +96,11 @@ public class FileActions {
|
||||
String sign = transformedParam.get("sign");
|
||||
boolean verify = SM2Util.plainStrVerify(pubkey, str, sign);
|
||||
|
||||
LOGGER.info("[CMHttpHandler] upload http请求验签结果 : " + verify);
|
||||
LOGGER.info("[FileAction] upload http请求验签结果 : " + verify);
|
||||
|
||||
if (verify) {
|
||||
// 查permission
|
||||
String ret = KeyValueDBUtil.instance.getValue(NCTables.NodeUser.toString(), pubkey);
|
||||
|
||||
if (ret != null && ret.length() > 0) {
|
||||
permission = 0x86000d41L | Role.compoundValue(ret.split(","));
|
||||
} else {
|
||||
|
@ -141,6 +141,7 @@ public class NCHttpHandler extends SimpleChannelInboundHandler<HttpObject> {
|
||||
transformedParam.addProperty("permission", permission + "");
|
||||
LOGGER.debug("[CMHttpHandler] http 请求查看用户权限为 : " + permission);
|
||||
} else {
|
||||
transformedParam.remove("pubKey");
|
||||
transformedParam.addProperty("permission", 0 + "");
|
||||
}
|
||||
}
|
||||
|
@ -136,6 +136,7 @@ public class NCManagerAction {
|
||||
} else if (role.isEmpty()) {
|
||||
role = Role.Anonymous.name();
|
||||
}
|
||||
if (handler != null)
|
||||
handler.setPermission(Role.compoundValue(role.split(",")));
|
||||
simpleReply(resultCallback, "onLogin", role);
|
||||
} else {
|
||||
@ -176,6 +177,32 @@ public class NCManagerAction {
|
||||
LOGGER.debug("time:" + (end - start));
|
||||
}
|
||||
|
||||
@Action(userPermission = 0)
|
||||
public void resetCenterManager(JsonObject json, ResultCallback resultCallback) {
|
||||
getNodeRole(json, new ResultCallback() {
|
||||
@Override
|
||||
public void onResult(String str) {
|
||||
if (str.contains(Role.CenterManager.toString())) {
|
||||
if (json.has("newPubKey")) {
|
||||
String newPubKey = json.get("newPubKey").getAsString();
|
||||
KeyValueDBUtil.instance.setValue(NCTables.ConfigDB.toString(), centerManger, newPubKey);
|
||||
KeyValueDBUtil.instance.setValue(
|
||||
NCTables.NodeUser.toString(), newPubKey, Role.CenterManager.toString());
|
||||
resultCallback.onResult("{\"action\":\"onResetCenterManager\",\"data\":\"success\",\"pubKey\":\""
|
||||
+ newPubKey + "\"}");
|
||||
} else {
|
||||
//just keep the same
|
||||
resultCallback.onResult("{\"action\":\"onResetCenterManager\",\"data\":\"success\",\"pubKey\":\""
|
||||
+ getPubKey(json) + "\"}");
|
||||
}
|
||||
} else {
|
||||
resultCallback.onResult("{\"action\":\"onResetCenterManager\",\"data\":\"failed, no permission\"}");
|
||||
}
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Action(userPermission = 0)
|
||||
public void applyRole(JsonObject json, ResultCallback resultCallback) {
|
||||
String pubKey = getPubKey(json);
|
||||
|
@ -199,10 +199,10 @@ public class NodeCenterActions {
|
||||
Long.toString(new Date().getTime()));
|
||||
return Role.Node.getValue();
|
||||
*/
|
||||
return Role.Anonymous.getValue();
|
||||
// TODO fix permission bugs.
|
||||
return Role.compoundValue(new String[]{"NodeManager"});
|
||||
// return Role.compoundValue(new String[]{"CenterManager"});
|
||||
} else {
|
||||
|
||||
return (Role.compoundValue(ret.split(",")));
|
||||
}
|
||||
} catch (Exception e) {
|
||||
|
Loading…
Reference in New Issue
Block a user