Skip to content

Instantly share code, notes, and snippets.

@gsimard
Created March 28, 2012 03:38
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save gsimard/2223372 to your computer and use it in GitHub Desktop.
Save gsimard/2223372 to your computer and use it in GitHub Desktop.
Clojail security problem
Exception in thread "main" java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at com.simontuffs.onejar.Boot.run(Boot.java:340)
at com.simontuffs.onejar.Boot.main(Boot.java:166)
Caused by: java.util.concurrent.ExecutionException: java.security.AccessControlException: access denied (java.lang.RuntimePermission setContextClassLoader), compiling:(NO_SOURCE_PATH:0)
at java.util.concurrent.FutureTask$Sync.innerGet(FutureTask.java:232)
at java.util.concurrent.FutureTask.get(FutureTask.java:91)
at clojail.core$thunk_timeout.invoke(core.clj:54)
at clojail.core$sandbox_STAR_$fn__152.doInvoke(core.clj:258)
at clojure.lang.RestFn.applyTo(RestFn.java:142)
at clojure.core$apply.invoke(core.clj:604)
at clojail.core$sandbox$fn__159.doInvoke(core.clj:273)
at clojure.lang.RestFn.invoke(RestFn.java:423)
at ca.gsimard.spacecraft.client.clojail$epadEval.invoke(clojail.clj:28)
at clojure.lang.Var.invoke(Var.java:401)
at ca.gsimard.spacecraft.client.EpadLoader.callClojail(EpadLoader.java:25)
at ca.gsimard.spacecraft.client.Main$.main(MainClient.scala:30)
at ca.gsimard.spacecraft.client.Main.main(MainClient.scala)
... 6 more
Caused by: java.security.AccessControlException: access denied (java.lang.RuntimePermission setContextClassLoader), compiling:(NO_SOURCE_PATH:0)
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6416)
at clojure.lang.Compiler.analyze(Compiler.java:6216)
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6397)
at clojure.lang.Compiler.analyze(Compiler.java:6216)
at clojure.lang.Compiler.access$100(Compiler.java:37)
at clojure.lang.Compiler$DefExpr$Parser.parse(Compiler.java:492)
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6409)
at clojure.lang.Compiler.analyze(Compiler.java:6216)
at clojure.lang.Compiler.analyze(Compiler.java:6177)
at clojure.lang.Compiler.eval(Compiler.java:6469)
at clojure.lang.Compiler.eval(Compiler.java:6454)
at clojure.lang.Compiler.eval(Compiler.java:6454)
at clojure.lang.Compiler.eval(Compiler.java:6431)
at clojure.core$eval.invoke(core.clj:2795)
at clojail.core$evaluator$fn__138$fn__139$fn__140.invoke(core.clj:197)
at clojail.jvm$priv_action$fn__56.invoke(jvm.clj:31)
at clojail.jvm.proxy$java.lang.Object$PrivilegedAction$5d874c2b.run(Unknown Source)
at java.security.AccessController.doPrivileged(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
at java.lang.reflect.Method.invoke(Method.java:597)
at clojure.lang.Reflector.invokeMatchingMethod(Reflector.java:92)
at clojure.lang.Reflector.invokeStaticMethod(Reflector.java:225)
at clojail.jvm$jvm_sandbox.invoke(jvm.clj:37)
at clojail.core$evaluator$fn__138$fn__139.invoke(core.clj:197)
at clojure.lang.AFn.applyToHelper(AFn.java:159)
at clojure.lang.AFn.applyTo(AFn.java:151)
at clojure.core$apply.invoke(core.clj:600)
at clojure.core$with_bindings_STAR_.doInvoke(core.clj:1769)
at clojure.lang.RestFn.invoke(RestFn.java:425)
at clojail.core$evaluator$fn__138.invoke(core.clj:197)
at clojure.core$comp$fn__408.invoke(core.clj:2276)
at clojure.lang.AFn.call(AFn.java:18)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
at java.util.concurrent.FutureTask.run(FutureTask.java:138)
at java.lang.Thread.run(Thread.java:662)
Caused by: java.security.AccessControlException: access denied (java.lang.RuntimePermission setContextClassLoader)
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:374)
at java.security.AccessController.checkPermission(AccessController.java:546)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:532)
at java.lang.Thread.setContextClassLoader(Thread.java:1394)
at com.simontuffs.onejar.JarClassLoader.loadClass(JarClassLoader.java:629)
at java.lang.ClassLoader.loadClass(ClassLoader.java:295)
at java.lang.ClassLoader.loadClass(ClassLoader.java:295)
at java.lang.ClassLoader.loadClass(ClassLoader.java:295)
at java.lang.ClassLoader.loadClass(ClassLoader.java:247)
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(ClassLoader.java:631)
at java.lang.ClassLoader.defineClass(ClassLoader.java:615)
at java.lang.ClassLoader.defineClass(ClassLoader.java:465)
at clojure.lang.DynamicClassLoader.defineClass(DynamicClassLoader.java:46)
at clojure.lang.Compiler$ObjExpr.getCompiledClass(Compiler.java:4533)
at clojure.lang.Compiler$FnExpr.parse(Compiler.java:3697)
at clojure.lang.Compiler.analyzeSeq(Compiler.java:6407)
... 36 more
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment