[rfc][icedtea-web] (PR1264) Run in Sandbox button

Andrew Azores aazores at redhat.com
Mon Feb 10 08:25:25 PST 2014


On 01/27/2014 02:55 PM, Andrew Azores wrote:
> On 01/14/2014 04:26 PM, Andrew Azores wrote:
>> On 01/10/2014 04:58 PM, Andrew Azores wrote:
>>> Hi,
>>>
>>> As inspired by an earlier mailing list thread [1]/[2]/[3], this 
>>> patch introduces a new "Sandbox" button in the dialog that appears 
>>> when a user is prompted to decide whether or not they trust the 
>>> signer of an applet. If the user clicks "Run", then the applet 
>>> proceeds as normal, being granted full Java Permissions (except in 
>>> edge cases such as PR1592 - mixed JAR signing - and PR1513 - 
>>> external main-class). If the user clicks "Sandbox", however, the 
>>> classloader will treat the applet as if it is completely unsigned, 
>>> and run it only with Sandbox Permissions, disregarding the fact that 
>>> the applet has been signed.
>>>
>>> More work will need to be done with this patch once the 
>>> PartiallySigned Dialogs patch goes in, so that that dialog also 
>>> supports this action. This will be done at a later date in a new 
>>> changeset.
>>>
>>> Automated tests have been largely left out of this patch since it 
>>> deals with adding GUI elements, and the state of the ClassLoader 
>>> itself cannot be directly influenced by a reproducer without 
>>> interacting with security prompts (obviously). A small unit test was 
>>> included to check the conversion between a new AppletAction enum 
>>> type and arbitrary Object references - see the patch for the 
>>> relevance of this enum and why this test needs to be done.
>>>
>>> Non-automated testing should involve:
>>> 1) running unsigned applets and verifying that the CertWarning 
>>> dialog does not appear
>>> 2) running unsigned applets and verifying that there is no Sandbox 
>>> button
>>> 3) running signed applets and verifying that there is a Sandbox 
>>> button, which is enabled iff the "always trust content" checkbox is 
>>> NOT ticked
>>> 4) running signed applets with the "Run" button results in a normal 
>>> applet launch (same behaviour with and without patch applied)
>>> 5) running signed applets with the "Sandbox" button results in the 
>>> applet not being able to perform privileged actions
>>>
>>> Some sample signed applets to test with:
>>> a) http://caff.de/applettest/Signed.html - once the applet launches, 
>>> privileged actions include printing and saving local files. 
>>> "Sandbox" mode should result in permission denied error dialogs
>>> b) https://oasisweb.uga.edu/oasis.html - launch browser from 
>>> terminal to run this test. The applet will attempt to read several 
>>> system properties, which it will print out. In standard run, these 
>>> will be successfully read. In Sandbox mode, permission denied errors 
>>> will be printed instead.
>>> c) JOGL tests at 
>>> http://jogamp.org/deployment/jogamp-current/jogl-test-applets.html - 
>>> launch browser from terminal to run this test. Running applets in 
>>> Sandbox mode will cause most of the applets to fail at runtime, with 
>>> AccessControlExceptions printed to the terminal.
>>>
>>> Known issues (needing discussion):
>>> - The CertWarning dialog sometimes appears more than once for a 
>>> given applet (this is existing behaviour) - once per certificate 
>>> that the user needs to approve trust. It doesn't seem to make sense 
>>> for the "Sandbox" button to only apply to some subset of JARs in an 
>>> applet based on signers, rather it should simply apply to the entire 
>>> applet. Should further CertWarnings simply not be shown after the 
>>> first time, if the Sandbox option is chosen the first time? 
>>> Currently the implementation sets the entire classloader to Sandbox 
>>> mode when a Sandbox button is pressed, which *must* occur before any 
>>> classes are loaded and assigned security descriptors, so pressing 
>>> Sandbox the first time and Run the second time will still result in 
>>> Sandboxed behaviour. Or, should subsequent CertWarnings still be 
>>> shown but perhaps with the Run button disabled if Sandbox has been 
>>> chosen at least once prior?
>>> - The entire classloader is set to Sandbox mode, and this is not 
>>> done with any more fine-grained control than this. If multiple 
>>> applets are sharing the same classloader instance, then they will 
>>> all be run sandboxed. This can be changed, but I think it's going to 
>>> be a very rare situation where applets that are sharing a 
>>> classloader will not all be trusted at the same level by the user. 
>>> Leaving it as it is keeps the implementation simpler.
>>>
>>> ChangeLog:
>>> Added "Sandbox" button to CertWarning dialogs, allowing signed applets
>>> to be run with restricted permissions
>>> * netx/net/sourceforge/jnlp/resources/Messages.properties: (ButSandbox,
>>> LRunInSandboxError, LRunInSandboxErrorInfo): new messages
>>> * netx/net/sourceforge/jnlp/runtime/JNLPClassLoader.java: (security)
>>> initialize to null when declared. (runInSandbox) new field.
>>> (getRunInSandbox) getter for new field. (setRunInSandbox) set the
>>> classloader to run current applet sandboxed. (activateJars,
>>> initializeResources, addNewJar, setSecurity) assign sandbox permissions
>>> regardless of signing if runInSandbox is set. (createInstance) do 
>>> not show
>>> unsigned applet prompt if runInSandbox is set.
>>> * netx/net/sourceforge/jnlp/security/AppVerifier.java:
>>> (checkTrustWithUser) added JNLPClassLoader param
>>> * netx/net/sourceforge/jnlp/security/CertWarningPane.java: added 
>>> Sandbox
>>> button
>>> * netx/net/sourceforge/jnlp/security/JNLPAppVerifier.java:
>>> (checkTrustWithUser) uses AppletAction enum type, calls
>>> JNLPClassLoader#setRunInSandbox if AppletAction is SANDBOX
>>> * netx/net/sourceforge/jnlp/security/PluginAppVerifier.java: same
>>> * netx/net/sourceforge/jnlp/security/SecurityDialogs.java: added
>>> (AppletAction) enum type. (showCertWarning) returns AppletAction
>>> rather than boolean
>>> * netx/net/sourceforge/jnlp/security/VariableX509TrustManager.java:
>>> (askUser) refactor to use AppletAction rather than boolean
>>> * netx/net/sourceforge/jnlp/tools/JarCertVerifier.java:
>>> (checkTrustWithUser) added JNLPClassLoader param
>>> * 
>>> tests/netx/unit/net/sourceforge/jnlp/security/SecurityDialogsTest.java:
>>> (testGetIntegerResponseAsAppletAction) new tests for converting Object
>>> references into AppletActions
>>>
>>>
>>> [1] 
>>> http://mail.openjdk.java.net/pipermail/distro-pkg-dev/2013-October/025394.html
>>> [2] 
>>> http://mail.openjdk.java.net/pipermail/distro-pkg-dev/2013-November/025396.html
>>> [3] 
>>> http://mail.openjdk.java.net/pipermail/distro-pkg-dev/2013-December/025399.html
>>>
>>> Thanks,
>>>
>>
>> Again, updating the patches here due to discussions on IRC.
>>
>> Changes since the last set:
>> - There's a new "-Xtrustnone" switch for command-line javaws. This is 
>> like -Xtrustall but rather than choosing the "Run/Proceed" option, 
>> the "Sandbox" option is taken.
>>     - this is used for the new reproducer that is included, which 
>> verifies that the Run in Sandbox button really does reduce the 
>> permissions of a signed applet
>> - part of JNLPClassLoader#initializeResources was refactored
>> - the buttons on CertWarningDialogs now have tooltips
>> - Clicking "Sandbox" on a CertWarningDialog causes any subsequent 
>> CertWarningDialogs to not appear, at least not from the same 
>> classloader. In the unusual cases where an applet has multiple 
>> classloaders (eg some of the jogl jnlp applets), then multiple 
>> dialogs may still appear.
>>
>> Thanks,
>>
>
> Ping.
>
> Thanks,
>

Ping... ?

Thanks,

-- 
Andrew A



More information about the distro-pkg-dev mailing list