Skip to content

Commit

Permalink
protection domain for the legacy JavaScript compiler (for gh-12)
Browse files Browse the repository at this point in the history
  • Loading branch information
dadza committed Dec 15, 2017
1 parent 70ac424 commit f91cdb1
Showing 1 changed file with 30 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
*/
package net.sf.jasperreports.compilers;

import java.security.ProtectionDomain;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
Expand All @@ -34,6 +35,8 @@
import net.sf.jasperreports.engine.fill.JRFillField;
import net.sf.jasperreports.engine.fill.JRFillParameter;
import net.sf.jasperreports.engine.fill.JRFillVariable;
import net.sf.jasperreports.engine.util.JRClassLoader;
import net.sf.jasperreports.engine.util.ProtectionDomainFactory;
import net.sf.jasperreports.functions.FunctionsUtil;

import org.apache.commons.logging.Log;
Expand All @@ -43,6 +46,8 @@
import org.mozilla.javascript.EvaluatorException;
import org.mozilla.javascript.Script;
import org.mozilla.javascript.ScriptableObject;
import org.mozilla.javascript.optimizer.Codegen;
import org.mozilla.javascript.tools.shell.JavaPolicySecurity;

/**
* @author Lucian Chirita (lucianc@users.sourceforge.net)
Expand Down Expand Up @@ -145,6 +150,7 @@ public Object getEstimatedValue()

private Context context;
private ScriptableObject scope;
private volatile ProtectionDomain protectionDomain;
private Map<String, Script> compiledExpressions = new HashMap<String, Script>();

public JavaScriptEvaluatorScope(JasperReportsContext jrContext, JREvaluator evaluator, FunctionsUtil functionsUtil)
Expand All @@ -160,6 +166,9 @@ public JavaScriptEvaluatorScope(JasperReportsContext jrContext, JREvaluator eval

context.getWrapFactory().setJavaPrimitiveWrap(false);

//using a protection domain in getCompiledExpression
context.setSecurityController(new JavaPolicySecurity());

JavaScriptFunctionsObject functionsObject = new JavaScriptFunctionsObject(context, functionsUtil, evaluator);
this.scope = context.initStandardObjects();
// is this OK? the original prototype set by initStandardObjects is lost, and functionsObject has no prototype.
Expand Down Expand Up @@ -251,6 +260,7 @@ public void setScopeVariable(String name, Object value)
scope.put(name, scope, value);
}

//TODO move expression compilation to a separate class
protected Script getCompiledExpression(String expression)
{
Script compiledExpression = compiledExpressions.get(expression);
Expand All @@ -263,12 +273,31 @@ protected Script getCompiledExpression(String expression)

ensureContext();

compiledExpression = context.compileString(expression, "expression", 0, null);
compiledExpression = context.compileString(expression, "expression", 0, getProtectionDomain());
compiledExpressions.put(expression, compiledExpression);
}
return compiledExpression;
}

protected ProtectionDomain getProtectionDomain()
{
ProtectionDomain domain = protectionDomain;
if (domain == null)
{
synchronized (this)
{
domain = protectionDomain;
if (domain == null)
{
ProtectionDomainFactory protectionDomainFactory = JRClassLoader.getProtectionDomainFactory();
domain = protectionDomain = protectionDomainFactory.getProtectionDomain(
Codegen.class.getClassLoader());
}
}
}
return domain;
}

// enter a precreated context, or a new one if null is passed
protected static Context enter(Context context)
{
Expand Down

0 comments on commit f91cdb1

Please sign in to comment.