You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@ofbiz.apache.org by mt...@apache.org on 2019/03/02 17:16:48 UTC
svn commit: r1854656 -
/ofbiz/ofbiz-framework/trunk/framework/service/src/main/java/org/apache/ofbiz/service/engine/GroovyEngine.java
Author: mthl
Date: Sat Mar 2 17:16:47 2019
New Revision: 1854656
URL: http://svn.apache.org/viewvc?rev=1854656&view=rev
Log:
Improved: Inline ‘serviceInvoker’ method in Groovy engine (OFBIZ-10808)
The ‘runSync’ method of the Groovy engine was only passing its
arguments to the serviceInvoker method which was private and used only
by the ‘runSync’ method. By inlining this private method the work is
now done directly in the ‘runSync’ method.
Modified:
ofbiz/ofbiz-framework/trunk/framework/service/src/main/java/org/apache/ofbiz/service/engine/GroovyEngine.java
Modified: ofbiz/ofbiz-framework/trunk/framework/service/src/main/java/org/apache/ofbiz/service/engine/GroovyEngine.java
URL: http://svn.apache.org/viewvc/ofbiz/ofbiz-framework/trunk/framework/service/src/main/java/org/apache/ofbiz/service/engine/GroovyEngine.java?rev=1854656&r1=1854655&r2=1854656&view=diff
==============================================================================
--- ofbiz/ofbiz-framework/trunk/framework/service/src/main/java/org/apache/ofbiz/service/engine/GroovyEngine.java (original)
+++ ofbiz/ofbiz-framework/trunk/framework/service/src/main/java/org/apache/ofbiz/service/engine/GroovyEngine.java Sat Mar 2 17:16:47 2019
@@ -75,15 +75,9 @@ public final class GroovyEngine extends
runSync(localName, modelService, context);
}
- /**
- * @see org.apache.ofbiz.service.engine.GenericEngine#runSync(java.lang.String, org.apache.ofbiz.service.ModelService, java.util.Map)
- */
@Override
- public Map<String, Object> runSync(String localName, ModelService modelService, Map<String, Object> context) throws GenericServiceException {
- return serviceInvoker(localName, modelService, context);
- }
-
- private Map<String, Object> serviceInvoker(String localName, ModelService modelService, Map<String, Object> context) throws GenericServiceException {
+ public Map<String, Object> runSync(String localName, ModelService modelService, Map<String, Object> context)
+ throws GenericServiceException {
if (UtilValidate.isEmpty(modelService.location)) {
throw new GenericServiceException("Cannot run Groovy service with empty location");
}
@@ -105,13 +99,16 @@ public final class GroovyEngine extends
if (scriptHelper != null) {
gContext.put(ScriptUtil.SCRIPT_HELPER_KEY, scriptHelper);
}
- Script script = InvokerHelper.createScript(GroovyUtil.getScriptClassFromLocation(this.getLocation(modelService)), GroovyUtil.getBinding(gContext));
- Object resultObj = null;
- if (UtilValidate.isEmpty(modelService.invoke)) {
- resultObj = script.run();
- } else {
- resultObj = script.invokeMethod(modelService.invoke, EMPTY_ARGS);
- }
+
+ Script script = InvokerHelper.createScript(
+ GroovyUtil.getScriptClassFromLocation(getLocation(modelService)),
+ GroovyUtil.getBinding(gContext));
+
+ // Groovy services can either be implemented as a stand-alone script or with a method inside a script.
+ Object resultObj = UtilValidate.isEmpty(modelService.invoke)
+ ? script.run()
+ : script.invokeMethod(modelService.invoke, EMPTY_ARGS);
+
if (resultObj == null) {
resultObj = scriptContext.getAttribute(ScriptUtil.RESULT_KEY);
}
@@ -119,14 +116,18 @@ public final class GroovyEngine extends
return cast(resultObj);
}
Map<String, Object> result = ServiceUtil.returnSuccess();
- result.putAll(modelService.makeValid(scriptContext.getBindings(ScriptContext.ENGINE_SCOPE), ModelService.OUT_PARAM));
+ result.putAll(modelService.makeValid(
+ scriptContext.getBindings(ScriptContext.ENGINE_SCOPE),
+ ModelService.OUT_PARAM));
return result;
} catch (GeneralException ge) {
throw new GenericServiceException(ge);
} catch (Exception e) {
- // detailMessage can be null. If it is null, the exception won't be properly returned and logged, and that will
- // make spotting problems very difficult. Disabling this for now in favor of returning a proper exception.
- throw new GenericServiceException("Error running Groovy method [" + modelService.invoke + "] in Groovy file [" + modelService.location + "]: ", e);
+ // detailMessage can be null. If it is null, the exception won't be properly returned and logged,
+ // and that will make spotting problems very difficult.
+ // Disabling this for now in favor of returning a proper exception.
+ throw new GenericServiceException("Error running Groovy method [" + modelService.invoke + "]"
+ + " in Groovy file [" + modelService.location + "]: ", e);
}
}
}