[icedtea-web][rfc] Update on Danesh's major rework of JarCertVerifier
Adam Domurad
adomurad at redhat.com
Tue Sep 25 07:59:23 PDT 2012
The original topic email for this is: [RFC][icedtea-web] Major rework
of JarCertVerifier. I have picked up review of this and added
additional patches on top for review.
I will still be creating an additional reproducer that tests the effect
of multiple signers per jar for JNLP & HTML-based applications, but
wanted to get review on my additional patches.
I have ensured there was no regressions in the reproducer suite (I
fixed one regression with empty signed jars). I have also ran the
manual browser tests. (Note these tests were with all patches applied)
Here are the patches, in order that they should be applied, and how to
direct reviewing attention. Essentially the JCV rework patch has been
more or less validated, and I want the additional patches reviewed
before I continue.
===========================================================================
1) jcv-major-rework-02.patch:
The most recent version of Danesh's patch, unmodified. I have purposely
left this as-was and made additional patches on top of it, because
between Omair and I, I consider this patch reviewed. Feel free to point
out
any additional concerns (but hopefully addressable after we get this in
HEAD.)
See the original discussion for details + ChangeLog.
===========================================================================
===========================================================================
2) CodeStyle.patch:
Modifies newly added code to use interface types instead of concrete
types
wherever it is applicable.
ChangeLog:
2012-09-25 Adam Domurad <adomurad at redhat.com>
* netx/net/sourceforge/jnlp/security/AppVerifier.java: Use interface
types for declared types where applicable.
* netx/net/sourceforge/jnlp/security/PluginAppVerifier.java: Same.
* netx/net/sourceforge/jnlp/tools/JarCertVerifier.java: Same.
===========================================================================
===========================================================================
3) FixForEmptySignedReproducer.patch
Fixes a slight problem that prohibited correctly identifying trivially
signed jars.
ChangeLog:
2012-09-25 Adam Domurad <adomurad at redhat.com>
Fixes JCV#isTriviallySigned(). Reproducer 'EmptySignedJar' passes
again.
* netx/net/sourceforge/jnlp/tools/JarCertVerifier.java: Remove
problematic 'triviallySigned' variable and instead determine
whether triviallySigned on the fly. Consider jars with 0 signable
entries as SIGNED_OK.
===========================================================================
===========================================================================
3) NewMessage.patch:
A new message for when a JNLP application is fully signed, but by
mismatching signers. (A JNLP application can have multiple signers, but
each jar needs a common signer).
ChangeLog:
2012-09-25 Adam Domurad <adomurad at redhat.com>
New message for signer mismatch in JNLP applications.
* netx/net/sourceforge/jnlp/resources/Messages.properties: Added
message 'The JNLP application is not fully signed by a single cert.'
* netx/net/sourceforge/jnlp/runtime/JNLPClassLoader.java: Message
thrown when JNLP's jcv.allJarsSigned() is true but not
jcv.isFullySigned();
===========================================================================
===========================================================================
4) TestForPR822.patch:
The existing tests for PR822 weren't really demonstrating the offending
behaviour. I have removed their @Bug annotation, and made them expect
the
new messages added.
Also added an HTML test applet to signed2/MultipleSignaturesTest that is
fully
signed, but by different signers. (In the case of HTML-tag applets, this
is
allowed.)
ChangeLog:
2012-09-25 Adam Domurad <adomurad at redhat.com>
Revised multiple signatures test to check for new message. Added more
accurate reproducer for PR822.
*
tests/reproducers/signed2/MultipleSignaturesTest/srcs/somecrazytestpackage/MultipleSignaturesTest.java:
Made class take a classname parameter so different out-of-package
classes could be executed.
*
tests/reproducers/signed2/MultipleSignaturesTest/resources/MultipleSignaturesTest.html:
Added main-class parameter.
*
tests/reproducers/signed2/MultipleSignaturesTest/resources/MultipleSignaturesTest1.jnlp:
Same.
*
tests/reproducers/signed2/MultipleSignaturesTest/resources/MultipleSignaturesTest1_requesting.jnlp:
Same.
*
tests/reproducers/signed2/MultipleSignaturesTest/resources/MultipleSignaturesTest2.jnlp:
Same.
*
tests/reproducers/signed2/MultipleSignaturesTest/testcases/MultipleSignaturesTestTests.java
(multipleSignaturesTestHtmlAppletUsesPermissions): New, tests if fully
signed HTML applets with varied signers can (as they should) execute
with full permissions. Reproduces PR822.
(multipleSignaturesTestJnlpApplicationRequesting): Check for
mismatching signers JNLP failure message. Remove known-to-fail &
(incorrect) bug annotation.
*
tests/reproducers/signed2/MultipleSignaturesTestSamePackage/testcases/MultipleSignaturesTestTestsSamePackage.java
(multipleSignaturesTestSamePackageJnlpApplicationRequesting): Check
for
mismatching signers JNLP failure message. Remove known-to-fail &
(incorrect) bug annotation.
===========================================================================
-------------- next part --------------
A non-text attachment was scrubbed...
Name: jcv-major-rework-02.patch
Type: text/x-patch
Size: 118979 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120925/c13576b5/jcv-major-rework-02.patch
-------------- next part --------------
A non-text attachment was scrubbed...
Name: CodeStyle.patch
Type: text/x-patch
Size: 9623 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120925/c13576b5/CodeStyle.patch
-------------- next part --------------
A non-text attachment was scrubbed...
Name: FixForEmptySignedReproducer.patch
Type: text/x-patch
Size: 2659 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120925/c13576b5/FixForEmptySignedReproducer.patch
-------------- next part --------------
A non-text attachment was scrubbed...
Name: NewMessage.patch
Type: text/x-patch
Size: 2202 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120925/c13576b5/NewMessage.patch
-------------- next part --------------
A non-text attachment was scrubbed...
Name: TestforPR822.patch
Type: text/x-patch
Size: 11286 bytes
Desc: not available
Url : http://mail.openjdk.java.net/pipermail/distro-pkg-dev/attachments/20120925/c13576b5/TestforPR822.patch
More information about the distro-pkg-dev
mailing list