[rfc][icedtea-web] Fix support for signed applets with sandbox permissions in manifest

Andrew Azores aazores at redhat.com
Wed Jun 11 13:46:59 UTC 2014


On 06/03/2014 01:48 PM, Andrew Azores wrote:
> On 05/27/2014 12:23 PM, Andrew Azores wrote:
>> Hi,
>>
>> This patch allows signed applets with sandbox permissions specified 
>> in their manifests to actually be run sandboxed. This is in contrast 
>> to the current behaviour where such applets will fail to launch, and 
>> the failure message presented asks the user to try launching via the 
>> Sandbox button next time. This was because the dialog which presented 
>> the Sandbox button appeared very early in the JNLPClassLoader's life 
>> cycle - early enough that no security settings had yet been set for 
>> the classloader or any of the applet's JAR locations - whereas the 
>> manifest checks were done later, after these settings would have 
>> already been initialized. Fixing the issue was not as simple as doing 
>> the manifest checks before presenting the security dialog because the 
>> dialog was presented part way through the initialization process, 
>> where JARs are being downloaded and checked for signing, so that the 
>> appropriate security dialog could be shown to the user. Putting the 
>> manifest checks first would therefore not work properly because the 
>> JARs were not yet available. This patch resolves the issue by moving 
>> the manifest checks inside the method which initializes the relevant 
>> security settings, such that the required resources are available, it 
>> is known what type of applet is about to be run, but the security 
>> settings for the JAR locations have not yet been initialized and the 
>> applet can thus still be set to run sandboxed safely.
>>
>> Additionally, the ManifestAttributesChecker check for the Permissions 
>> attribute is no longer skipped when Extended Applet Security is set 
>> to the Low level, since this allows for signed applets with Sandbox 
>> permissions specified in their manifests to run with full permissions 
>> when Low security is set.
>>
>> All existing reproducers have been run with this patch applied and 
>> there appears to be no effect. Manual tests from the wiki have also 
>> been run and no failures noted. Two new applets, reported in PR1767 
>> [0], have been added as test cases to the wiki. These fail without 
>> the patch and pass with it. A reproducer is also included, however, 
>> the ALACA dialog will appear, which means manual intervention is 
>> required to run this test as well. The test is marked KnownToFail and 
>> this issue documented with the test case. This cannot be worked 
>> around by disabling manifest attributes checking since this would 
>> render the test meaningless as the Permissions manifest attribute 
>> would then not be run to force sandboxing.
>>
>> ChangeLog:
>>
>> 2014-05-27  Andrew Azores  <aazores at redhat.com>
>>
>>     Fixed support for signed applets which specify the Permissions 
>> attribute
>>     as "sandbox" in their manifests. These applets are now properly run
>>     sandboxed automatically, rather than requiring the user to click the
>>     "Sandbox" run button.
>>     * netx/net/sourceforge/jnlp/runtime/JNLPClassLoader.java
>>     (JNLPClassLoader): manifest attributes checking and security 
>> settings
>>     moved inside initializeResources
>>     (initializeResources): do not set entries in 
>> jarLocationSecurityMap until
>>     after prompting the user on whether to run the applet as well as
>>     performing manifest attribute checks
>>     (initializeManifestAttributesChecker): new method
>>     (getJnlpFileCodebase): new method, extracted from 
>> initializeResources
>>     (SecurityDelegateImpl.setRunInSandbox): throw exception if 
>> already forced
>>     to run in sandbox, rather than if already prompted
>>     * netx/net/sourceforge/jnlp/runtime/ManifestAttributesChecker.java
>>     (checkPermissionsAttribute): do not skip checking if Extended Applet
>>     Security is Low. Remove try/catch on setRunInSandbox call as this 
>> is now
>>     supported.
>>     * 
>> tests/reproducers/custom/SignedAppletManifestSpecifiesSandbox/testcases/SignedAppletManifestSpecifiesSandboxTests.java:
>>     new test case
>>     * 
>> tests/reproducers/custom/SignedAppletManifestSpecifiesSandbox/resources/SignedAppletManifestSpecifiesSandbox.html:
>>     same
>>     * 
>> tests/reproducers/custom/SignedAppletManifestSpecifiesSandbox/srcs/MANIFEST.MF:
>>     same
>>     * 
>> tests/reproducers/custom/SignedAppletManifestSpecifiesSandbox/srcs/Makefile:
>>     same
>>     * 
>> tests/reproducers/custom/SignedAppletManifestSpecifiesSandbox/srcs/SignedAppletManifestSpecifiesSandbox.java:
>>     same
>>
>>
>> [0] http://icedtea.classpath.org/bugzilla/show_bug.cgi?id=1767
>>
>> Thanks,
>>
>
> Ping. I know this is a big one, and there's currently a decent 
> workaround in place, so no rush on review. Just need to make sure it 
> doesn't get lost.
>
> Thanks,
>

Ping again. I think this is probably going to have to wait for Jiri to 
come back though.

Thanks,

-- 
Andrew A



More information about the distro-pkg-dev mailing list