aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--netx/net/sourceforge/jnlp/runtime/RhinoBasedPacEvaluator.java7
2 files changed, 12 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 80116aa..4d2a668 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2013-07-22 Andrew Azores <aazores@redhat.com>
+ * netx/net/sourceforge/jnlp/runtime/RhinoBasedPacEvaluator.java:
+ (getProxiesWithoutCaching) added java.vm.name read permission to fix
+ Rhino parsing and PAC proxy configuration
+
2013-07-18 Jiri Vanek <jvanek@redhat.com>
IcedTea-Web is now following XDG .config and .cache specification(RH947647)
diff --git a/netx/net/sourceforge/jnlp/runtime/RhinoBasedPacEvaluator.java b/netx/net/sourceforge/jnlp/runtime/RhinoBasedPacEvaluator.java
index c3f90ae..b1c290a 100644
--- a/netx/net/sourceforge/jnlp/runtime/RhinoBasedPacEvaluator.java
+++ b/netx/net/sourceforge/jnlp/runtime/RhinoBasedPacEvaluator.java
@@ -48,6 +48,7 @@ import java.security.AccessController;
import java.security.Permissions;
import java.security.PrivilegedAction;
import java.security.ProtectionDomain;
+import java.util.PropertyPermission;
import net.sourceforge.jnlp.util.TimedHashMap;
@@ -124,9 +125,15 @@ public class RhinoBasedPacEvaluator implements PacEvaluator {
EvaluatePacAction evaluatePacAction = new EvaluatePacAction(pacContents, pacUrl.toString(),
pacHelperFunctionContents, url);
+
+ // Purposefully giving only these permissions rather than using java.policy. The "evaluatePacAction"
+ // isn't supposed to do very much and so doesn't require all the default permissions given by
+ // java.policy
Permissions p = new Permissions();
p.add(new RuntimePermission("accessClassInPackage.org.mozilla.javascript"));
p.add(new SocketPermission("*", "resolve"));
+ p.add(new PropertyPermission("java.vm.name", "read"));
+
ProtectionDomain pd = new ProtectionDomain(null, p);
AccessControlContext context = new AccessControlContext(new ProtectionDomain[] { pd });