mirror of
				https://gitee.com/BDWare/cp.git
				synced 2025-06-12 10:44:02 +00:00 
			
		
		
		
	merge newest origin/master
This commit is contained in:
		
						commit
						14e5fffe1d
					
				| @ -6,7 +6,11 @@ plugins { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| group = "org.bdware.sc" | group = "org.bdware.sc" | ||||||
|  | <<<<<<< HEAD | ||||||
| version = "2.0.0" | version = "2.0.0" | ||||||
|  | ======= | ||||||
|  | version = "1.7.2" | ||||||
|  | >>>>>>> origin/master | ||||||
| repositories { | repositories { | ||||||
|     mavenCentral() |     mavenCentral() | ||||||
|     mavenLocal() |     mavenLocal() | ||||||
|  | |||||||
| @ -63,7 +63,8 @@ public class DebugMain { | |||||||
|                 = new ResultCallback() { |                 = new ResultCallback() { | ||||||
|             @Override |             @Override | ||||||
|             public void onResult(String str) { |             public void onResult(String str) { | ||||||
|                 LOGGER.debug(str); | 
 | ||||||
|  |                 LOGGER.info("[PrintCB] " + str); | ||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
|         ContractProcess.instance.handler.setDBInfo(wrap("", config.dbPath), printCallback); |         ContractProcess.instance.handler.setDBInfo(wrap("", config.dbPath), printCallback); | ||||||
| @ -80,7 +81,7 @@ public class DebugMain { | |||||||
|         Map<String, Object> resp = HttpUtil.httpGet(url); |         Map<String, Object> resp = HttpUtil.httpGet(url); | ||||||
| 
 | 
 | ||||||
|         String data = (String) resp.get("response"); |         String data = (String) resp.get("response"); | ||||||
| //        LOGGER.info(JsonUtil.toPrettyJson(JsonUtil.parseStringAsJsonObject(data))); |         LOGGER.info(JsonUtil.toPrettyJson(JsonUtil.parseStringAsJsonObject(data))); | ||||||
|         LOGGER.info("start done!"); |         LOGGER.info("start done!"); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -554,7 +554,6 @@ public class ContractProcess { | |||||||
|             if (fun.isConfidential()) { |             if (fun.isConfidential()) { | ||||||
|                 fun.appendBeforeInvokeHandler(new ConfidentialHandler(fun)); |                 fun.appendBeforeInvokeHandler(new ConfidentialHandler(fun)); | ||||||
|             } |             } | ||||||
| 
 |  | ||||||
|             ArgSchemaHandler argSchemaHandler = createHandlerIfExist(fun, fun.annotations, ArgSchemaHandler.class); |             ArgSchemaHandler argSchemaHandler = createHandlerIfExist(fun, fun.annotations, ArgSchemaHandler.class); | ||||||
|             if (argSchemaHandler != null) { |             if (argSchemaHandler != null) { | ||||||
|                 fun.appendBeforeInvokeHandler(argSchemaHandler); |                 fun.appendBeforeInvokeHandler(argSchemaHandler); | ||||||
| @ -566,6 +565,10 @@ public class ContractProcess { | |||||||
| 
 | 
 | ||||||
|             if (fun.isExport()) { |             if (fun.isExport()) { | ||||||
|                 //if(fun.annotations...) |                 //if(fun.annotations...) | ||||||
|  |                 AccessHandler accessHandler = createHandlerIfExist(fun,fun.annotations,AccessHandler.class); | ||||||
|  |                 if (accessHandler != null) { | ||||||
|  |                     fun.appendBeforeInvokeHandler(accessHandler); | ||||||
|  |                 } | ||||||
|                 fun.appendAfterInvokeHandler(new ObjToJsonHandler()); |                 fun.appendAfterInvokeHandler(new ObjToJsonHandler()); | ||||||
|                 // fun.appendBeforeInvokeHandler(new ReadMeHandler()); |                 // fun.appendBeforeInvokeHandler(new ReadMeHandler()); | ||||||
|                 // Mask是用于返回真正结果之后,做一些偏移,以保护数据隐私。 |                 // Mask是用于返回真正结果之后,做一些偏移,以保护数据隐私。 | ||||||
|  | |||||||
| @ -3,13 +3,14 @@ package org.bdware.sc.compiler.ap; | |||||||
| import org.bdware.sc.compiler.AnnotationProcessor; | import org.bdware.sc.compiler.AnnotationProcessor; | ||||||
| import org.bdware.sc.node.AnnotationNode; | import org.bdware.sc.node.AnnotationNode; | ||||||
| import org.bdware.sc.node.ContractNode; | import org.bdware.sc.node.ContractNode; | ||||||
|  | import org.bdware.sc.node.FunctionNode; | ||||||
| 
 | 
 | ||||||
| public class Access extends AnnotationProcessor { | public class Access extends AnnotationProcessor { | ||||||
|     @Override |     @Override | ||||||
|     public void processContract(AnnotationNode anno, ContractNode contractNode) { |     public void processContract(AnnotationNode anno, ContractNode contractNode) { | ||||||
|         contractNode.sigRequired = false; |         for (FunctionNode fn : contractNode.getFunctions()) { | ||||||
|         if (anno != null) { |             fn.addAnnotation(anno); | ||||||
|             contractNode.sigRequired = "\"verified\"".equals(anno.getArgs().get(0)); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -608,33 +608,32 @@ public class DesktopEngine extends JSEngine { | |||||||
| 
 | 
 | ||||||
|     public Object executeWithoutLock(FunctionNode fun, ContractRequest input, Object injectedArg) throws ScriptException, NoSuchMethodException { |     public Object executeWithoutLock(FunctionNode fun, ContractRequest input, Object injectedArg) throws ScriptException, NoSuchMethodException { | ||||||
|         //              long start = System.currentTimeMillis(); |         //              long start = System.currentTimeMillis(); | ||||||
|         ArgPacks argPack = new ArgPacks(input, input.getArg(), null); |         ArgPacks argPacks = new ArgPacks(input, input.getArg(), null); | ||||||
|         if(injectedArg != null) { |         if(injectedArg != null) { | ||||||
|             argPack.arg = injectedArg; |             argPacks.arg = injectedArg; | ||||||
|         } |         } | ||||||
|         for (AnnotationHook handler : fun.beforeExecutionAnnotations()) { |         for (AnnotationHook handler : fun.beforeExecutionAnnotations()) { | ||||||
|             argPack = handler.handle(this, argPack); |             argPacks = handler.handle(this, argPacks); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         // actually invoke! |         // actually invoke! | ||||||
|         // todo 这里invoke应该如何调用,改了一行代码正确吗?input.getArg() -> argPack.arg |         if (argPacks.ret == null) { | ||||||
|         if (argPack.ret == null) { |             argPacks.ret = | ||||||
|             argPack.ret = |  | ||||||
|                     engine.invokeFunction( |                     engine.invokeFunction( | ||||||
|                             input.getAction(), |                             input.getAction(), | ||||||
|                             (fun.isHandler() |                             (fun.isHandler() | ||||||
|                                     ? JsonUtil.fromJson(input.getArg(), Event.class) |                                     ? JsonUtil.fromJson(input.getArg(), Event.class) | ||||||
|                                     : JSONTool.convertJsonElementToMirror(argPack.arg)), |                                     : JSONTool.convertJsonElementToMirror(argPacks.arg)), | ||||||
|                             input.getRequester(), |                             input.getRequester(), | ||||||
|                             input.getRequesterDOI()); |                             input.getRequesterDOI()); | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         for (AnnotationHook handler : fun.afterExecutionAnnotations()) { |         for (AnnotationHook handler : fun.afterExecutionAnnotations()) { | ||||||
|             //Mask在after裏面 |             //Mask在after裏面 | ||||||
|             //System.out.println("afterHook"+contract.Mask); |             //System.out.println("afterHook"+contract.Mask); | ||||||
| 
 |             argPacks = handler.handle(this, argPacks); | ||||||
|             argPack = handler.handle(this, argPack); |  | ||||||
|         } |         } | ||||||
|         return argPack.ret; |         return argPacks.ret; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     private String extractException(String msg, List<String> stack) { |     private String extractException(String msg, List<String> stack) { | ||||||
|  | |||||||
							
								
								
									
										78
									
								
								src/main/java/org/bdware/sc/engine/hook/AccessHandler.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										78
									
								
								src/main/java/org/bdware/sc/engine/hook/AccessHandler.java
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,78 @@ | |||||||
|  | package org.bdware.sc.engine.hook; | ||||||
|  | 
 | ||||||
|  | import com.google.gson.JsonElement; | ||||||
|  | import com.google.gson.JsonObject; | ||||||
|  | import com.google.gson.JsonParser; | ||||||
|  | import org.bdware.sc.JSEngine; | ||||||
|  | import org.bdware.sc.bean.ContractRequest; | ||||||
|  | import org.bdware.sc.boundry.ScriptReturnException; | ||||||
|  | import org.bdware.sc.engine.DesktopEngine; | ||||||
|  | import org.bdware.sc.engine.JSONTool; | ||||||
|  | import org.bdware.sc.node.AnnotationHook; | ||||||
|  | import org.bdware.sc.node.AnnotationNode; | ||||||
|  | import org.bdware.sc.node.ArgPacks; | ||||||
|  | import org.bdware.sc.node.FunctionNode; | ||||||
|  | import wrp.jdk.nashorn.internal.objects.Global; | ||||||
|  | import wrp.jdk.nashorn.internal.runtime.Context; | ||||||
|  | import wrp.jdk.nashorn.internal.runtime.PropertyMap; | ||||||
|  | import wrp.jdk.nashorn.internal.scripts.JO; | ||||||
|  | 
 | ||||||
|  | @YJSAnnotation(name = "Access") | ||||||
|  | public class AccessHandler implements AnnotationHook { | ||||||
|  |     public String acFunction; | ||||||
|  |     public boolean requireSign; | ||||||
|  | 
 | ||||||
|  |     public AccessHandler(AnnotationNode annoNode) { | ||||||
|  |         requireSign = false; | ||||||
|  |         String content = annoNode.getArgs().get(0); | ||||||
|  |         JsonElement je = JsonParser.parseString(content); | ||||||
|  |         if (je.isJsonPrimitive() && je.getAsJsonPrimitive().getAsString().equals("verified")) { | ||||||
|  |             requireSign = true; | ||||||
|  |         } | ||||||
|  |         if (je.isJsonObject()) { | ||||||
|  |             acFunction = je.getAsJsonObject().get("ACFunction").getAsString(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public static AccessHandler fromAnnotationNode(FunctionNode funNode, AnnotationNode annoNode) { | ||||||
|  |         return new AccessHandler(annoNode); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public ArgPacks handle(JSEngine desktopEngine, ArgPacks argPacks) { | ||||||
|  |         if (requireSign) { | ||||||
|  |             if (!argPacks.request.verifySignature()) { | ||||||
|  |                 throw new ScriptReturnException(JsonParser.parseString("{\"code\":400,\"msg\":\"permission denied\"}")); | ||||||
|  |             } | ||||||
|  |             return argPacks; | ||||||
|  |         } | ||||||
|  |         if (acFunction == null) return argPacks; | ||||||
|  |         DesktopEngine de = (DesktopEngine) desktopEngine; | ||||||
|  |         Global oldGlobal = Context.getGlobal(); | ||||||
|  |         Global newGlobal = de.getDesktopGlobal(); | ||||||
|  |         boolean globalChanged = (oldGlobal != newGlobal); | ||||||
|  |         try { | ||||||
|  |             if (globalChanged) { | ||||||
|  |                 Context.setGlobal(newGlobal); | ||||||
|  |             } | ||||||
|  |             ContractRequest input = argPacks.request; | ||||||
|  |             JO jo = new JO(PropertyMap.newMap()); | ||||||
|  |             jo.put("requester", input.getRequester(), false); | ||||||
|  |             jo.put("action", input.getAction(), false); | ||||||
|  |             jo.put("arg", JSONTool.convertJsonElementToMirror(input.getArg()), false); | ||||||
|  |             de.engine.invokeFunction(acFunction, jo); | ||||||
|  |             return argPacks; | ||||||
|  |         } catch (ScriptReturnException e) { | ||||||
|  |             throw e; | ||||||
|  |         } catch (Exception e) { | ||||||
|  |             JsonObject jo = new JsonObject(); | ||||||
|  |             jo.addProperty("code", "401"); | ||||||
|  |             jo.addProperty("msg", "access check meets exception! " + e); | ||||||
|  |             throw new ScriptReturnException(jo); | ||||||
|  |         } finally { | ||||||
|  |             if (globalChanged) Context.setGlobal(oldGlobal); | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -29,7 +29,6 @@ public class ArgSchemaHandler implements AnnotationHook { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static ArgSchemaHandler fromAnnotationNode(FunctionNode funNode, AnnotationNode annoNode) { |     public static ArgSchemaHandler fromAnnotationNode(FunctionNode funNode, AnnotationNode annoNode) { | ||||||
|         //a= annoNode; |  | ||||||
|         return new ArgSchemaHandler(annoNode); |         return new ArgSchemaHandler(annoNode); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user