1 /*
   2  * Copyright (c) 2009, Oracle and/or its affiliates. All rights reserved.
   3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
   4  *
   5  * This code is free software; you can redistribute it and/or modify it
   6  * under the terms of the GNU General Public License version 2 only, as
   7  * published by the Free Software Foundation.
   8  *
   9  * This code is distributed in the hope that it will be useful, but WITHOUT
  10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
  12  * version 2 for more details (a copy is included in the LICENSE file that
  13  * accompanied this code).
  14  *
  15  * You should have received a copy of the GNU General Public License version
  16  * 2 along with this work; if not, write to the Free Software Foundation,
  17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
  18  *
  19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
  20  * or visit www.oracle.com if you need additional information or have any
  21  * questions.
  22  */
  23 
  24 // This test case relies on updated static security property, no way to re-use
  25 // security property in samevm/agentvm mode.
  26 
  27 /**
  28  * @test
  29  *
  30  * @bug 6861062
  31  * @summary Disable MD2 support
  32  * @run main/othervm CPValidatorIntermediate
  33  * @author Xuelei Fan
  34  */
  35 
  36 import java.io.*;
  37 import java.net.SocketException;
  38 import java.util.*;
  39 import java.security.Security;
  40 import java.security.cert.*;
  41 
  42 public class CPValidatorIntermediate {
  43 
  44     // SHA1withRSA 1024
  45     static String trustAnchor_SHA1withRSA_1024 =
  46         "-----BEGIN CERTIFICATE-----\n" +
  47         "MIICPjCCAaegAwIBAgIBADANBgkqhkiG9w0BAQUFADAfMQswCQYDVQQGEwJVUzEQ\n" +
  48         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDRaFw0zMDA3MTcwMTExNDRa\n" +
  49         "MB8xCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMIGfMA0GCSqGSIb3DQEB\n" +
  50         "AQUAA4GNADCBiQKBgQC8UdC863pFk1Rvd7xUYd60+e9KsLhb6SqOfU42ZA715FcH\n" +
  51         "E1TRvQPmYzAnHcO04TrWZQtO6E+E2RCmeBnetBvIMVka688QkO14wnrIrf2tRodd\n" +
  52         "rZNZEBzkX+zyXCRo9tKEUDFf9Qze7Ilbb+Zzm9CUfu4M1Oz6iQcXRx7aM0jEAQID\n" +
  53         "AQABo4GJMIGGMB0GA1UdDgQWBBTn0C+xmZY/BTab4W9gBp3dGa7WgjBHBgNVHSME\n" +
  54         "QDA+gBTn0C+xmZY/BTab4W9gBp3dGa7WgqEjpCEwHzELMAkGA1UEBhMCVVMxEDAO\n" +
  55         "BgNVBAoTB0V4YW1wbGWCAQAwDwYDVR0TAQH/BAUwAwEB/zALBgNVHQ8EBAMCAgQw\n" +
  56         "DQYJKoZIhvcNAQEFBQADgYEAiCXL2Yp4ruyRXAIJ8zBEaPC9oV2agqgbSbly2z8z\n" +
  57         "Ik5SeSRysP+GHBpb8uNyANJnQKv+T0GrJiTLMBjKCOiJl6xzk3EZ2wbQB6G/SQ9+\n" +
  58         "UWcsXSC8oGSEPpkj5In/9/UbuUIfT9H8jmdyLNKQvlqgq6kyfnskME7ptGgT95Hc\n" +
  59         "tas=\n" +
  60         "-----END CERTIFICATE-----";
  61 
  62     // SHA1withRSA 512
  63     static String trustAnchor_SHA1withRSA_512 =
  64         "-----BEGIN CERTIFICATE-----\n" +
  65         "MIIBuTCCAWOgAwIBAgIBADANBgkqhkiG9w0BAQUFADAfMQswCQYDVQQGEwJVUzEQ\n" +
  66         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDRaFw0zMDA3MTcwMTExNDRa\n" +
  67         "MB8xCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMFwwDQYJKoZIhvcNAQEB\n" +
  68         "BQADSwAwSAJBAM0Kn4ieCdCHsrm78ZMMN4jQEEEqACAMKB7O8j9g4gfz2oAfmHwv\n" +
  69         "7JH/hZ0Xen1zUmBbwe+e2J5D/4Fisp9Bn98CAwEAAaOBiTCBhjAdBgNVHQ4EFgQU\n" +
  70         "g4Kwd47hdNQBp8grZsRJ5XvhvxAwRwYDVR0jBEAwPoAUg4Kwd47hdNQBp8grZsRJ\n" +
  71         "5XvhvxChI6QhMB8xCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlggEAMA8G\n" +
  72         "A1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgIEMA0GCSqGSIb3DQEBBQUAA0EAn77b\n" +
  73         "FJx+HvyRvjZYCzMjnUct3Ql4iLOkURYDh93J5TXi/l9ajvAMEuwzYj0qZ+Ktm/ia\n" +
  74         "U5r+8B9nzx+j2Zh3kw==\n" +
  75         "-----END CERTIFICATE-----";
  76 
  77     // SHA1withRSA 1024 signed with RSA 1024
  78     static String intermediate_SHA1withRSA_1024_1024 =
  79         "-----BEGIN CERTIFICATE-----\n" +
  80         "MIICUDCCAbmgAwIBAgIBAjANBgkqhkiG9w0BAQUFADAfMQswCQYDVQQGEwJVUzEQ\n" +
  81         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDhaFw0yOTA0MjMwMTExNDha\n" +
  82         "MDExCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFz\n" +
  83         "cy0xMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCVOqnlZspyAEr90ELFaUo8\n" +
  84         "BF0O2Kn0yTdUeyiLOth4RA3qxWrjxJq45VmEBjZpEzPHfnp3PhnfmLcLfhoPONFg\n" +
  85         "bcHzlkj75ZaKCgHoyV456fMBmj348fcoUkH2WdSQ82pmxHOiHqquYNUSTimFIq82\n" +
  86         "AayhbKqDmhfx5lJdYNqd5QIDAQABo4GJMIGGMB0GA1UdDgQWBBTfWD9mRTppcUAl\n" +
  87         "UqGuu/R5t8CB5jBHBgNVHSMEQDA+gBTn0C+xmZY/BTab4W9gBp3dGa7WgqEjpCEw\n" +
  88         "HzELMAkGA1UEBhMCVVMxEDAOBgNVBAoTB0V4YW1wbGWCAQAwDwYDVR0TAQH/BAUw\n" +
  89         "AwEB/zALBgNVHQ8EBAMCAgQwDQYJKoZIhvcNAQEFBQADgYEAHze3wAcIe84zNOoN\n" +
  90         "P8l9EmlVVoU30z3LB3hxq3m/dC/4gE5Z9Z8EG1wJw4qaxlTZ4dif12nbTTdofVhb\n" +
  91         "Bd4syjo6fcUA4q7sfg9TFpoHQ+Ap7PgjK99moMKdMy50Xy8s6FPvaVkF89s66Z6y\n" +
  92         "e4q7TSwe6QevGOZaL5N/iy2XGEs=\n" +
  93         "-----END CERTIFICATE-----";
  94 
  95     // SHA1withRSA 1024 signed with RSA 512
  96     static String intermediate_SHA1withRSA_1024_512 =
  97         "-----BEGIN CERTIFICATE-----\n" +
  98         "MIICDzCCAbmgAwIBAgIBAzANBgkqhkiG9w0BAQUFADAfMQswCQYDVQQGEwJVUzEQ\n" +
  99         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDlaFw0yOTA0MjMwMTExNDla\n" +
 100         "MDExCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFz\n" +
 101         "cy0xMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCVOqnlZspyAEr90ELFaUo8\n" +
 102         "BF0O2Kn0yTdUeyiLOth4RA3qxWrjxJq45VmEBjZpEzPHfnp3PhnfmLcLfhoPONFg\n" +
 103         "bcHzlkj75ZaKCgHoyV456fMBmj348fcoUkH2WdSQ82pmxHOiHqquYNUSTimFIq82\n" +
 104         "AayhbKqDmhfx5lJdYNqd5QIDAQABo4GJMIGGMB0GA1UdDgQWBBTfWD9mRTppcUAl\n" +
 105         "UqGuu/R5t8CB5jBHBgNVHSMEQDA+gBSDgrB3juF01AGnyCtmxEnle+G/EKEjpCEw\n" +
 106         "HzELMAkGA1UEBhMCVVMxEDAOBgNVBAoTB0V4YW1wbGWCAQAwDwYDVR0TAQH/BAUw\n" +
 107         "AwEB/zALBgNVHQ8EBAMCAgQwDQYJKoZIhvcNAQEFBQADQQCYNmdkONfuk07XjRze\n" +
 108         "WQyq2cfdae4uIdyUfa2rpgYMtSXuQW3/XrQGiz4G6WBXA2wo7folOOpAKYgvHPrm\n" +
 109         "w6Dd\n" +
 110         "-----END CERTIFICATE-----";
 111 
 112     // SHA1withRSA 512 signed with RSA 1024
 113     static String intermediate_SHA1withRSA_512_1024 =
 114         "-----BEGIN CERTIFICATE-----\n" +
 115         "MIICDDCCAXWgAwIBAgIBBDANBgkqhkiG9w0BAQUFADAfMQswCQYDVQQGEwJVUzEQ\n" +
 116         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDlaFw0yOTA0MjMwMTExNDla\n" +
 117         "MDExCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFz\n" +
 118         "cy0xMFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAKubXYoEHZpZkhzA9XX+NrpqJ4SV\n" +
 119         "lOMBoL3aWExQpJIgrUaZfbGMBBozIHBJMMayokguHbJvq4QigEgLuhfJNqsCAwEA\n" +
 120         "AaOBiTCBhjAdBgNVHQ4EFgQUN0CHiTYPtjyvpP2a6y6mhsZ6U40wRwYDVR0jBEAw\n" +
 121         "PoAU59AvsZmWPwU2m+FvYAad3Rmu1oKhI6QhMB8xCzAJBgNVBAYTAlVTMRAwDgYD\n" +
 122         "VQQKEwdFeGFtcGxlggEAMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgIEMA0G\n" +
 123         "CSqGSIb3DQEBBQUAA4GBAE2VOlw5ySLT3gUzKCYEga4QPaSrf6lHHPi2g48LscEY\n" +
 124         "h9qQXh4nuIVugReBIEf6N49RdT+M2cgRJo4sZ3ukYLGQzxNuttL5nPSuuvrAR1oG\n" +
 125         "LUyzOWcUpKHbVHi6zlTt79RvTKZvLcduLutmtPtLJcM9PdiAI1wEooSgxTwZtB/Z\n" +
 126         "-----END CERTIFICATE-----";
 127 
 128     // SHA1withRSA 512 signed with RSA 512
 129     static String intermediate_SHA1withRSA_512_512 =
 130         "-----BEGIN CERTIFICATE-----\n" +
 131         "MIIByzCCAXWgAwIBAgIBBTANBgkqhkiG9w0BAQUFADAfMQswCQYDVQQGEwJVUzEQ\n" +
 132         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDlaFw0yOTA0MjMwMTExNDla\n" +
 133         "MDExCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFz\n" +
 134         "cy0xMFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAKubXYoEHZpZkhzA9XX+NrpqJ4SV\n" +
 135         "lOMBoL3aWExQpJIgrUaZfbGMBBozIHBJMMayokguHbJvq4QigEgLuhfJNqsCAwEA\n" +
 136         "AaOBiTCBhjAdBgNVHQ4EFgQUN0CHiTYPtjyvpP2a6y6mhsZ6U40wRwYDVR0jBEAw\n" +
 137         "PoAUg4Kwd47hdNQBp8grZsRJ5XvhvxChI6QhMB8xCzAJBgNVBAYTAlVTMRAwDgYD\n" +
 138         "VQQKEwdFeGFtcGxlggEAMA8GA1UdEwEB/wQFMAMBAf8wCwYDVR0PBAQDAgIEMA0G\n" +
 139         "CSqGSIb3DQEBBQUAA0EAoCf0Zu559qcB4xPpzqkVsYiyW49S4Yc0mmQXb1yoQgLx\n" +
 140         "O+DCkjG5d14+t1MsnkhB2izoQUMxQ3vDc1YnA/tEpw==\n" +
 141         "-----END CERTIFICATE-----";
 142 
 143     // MD2withRSA 1024 signed with RSA 1024
 144     static String intermediate_MD2withRSA_1024_1024 =
 145         "-----BEGIN CERTIFICATE-----\n" +
 146         "MIICUDCCAbmgAwIBAgIBBjANBgkqhkiG9w0BAQIFADAfMQswCQYDVQQGEwJVUzEQ\n" +
 147         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDlaFw0yOTA0MjMwMTExNDla\n" +
 148         "MDExCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFz\n" +
 149         "cy0xMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCVOqnlZspyAEr90ELFaUo8\n" +
 150         "BF0O2Kn0yTdUeyiLOth4RA3qxWrjxJq45VmEBjZpEzPHfnp3PhnfmLcLfhoPONFg\n" +
 151         "bcHzlkj75ZaKCgHoyV456fMBmj348fcoUkH2WdSQ82pmxHOiHqquYNUSTimFIq82\n" +
 152         "AayhbKqDmhfx5lJdYNqd5QIDAQABo4GJMIGGMB0GA1UdDgQWBBTfWD9mRTppcUAl\n" +
 153         "UqGuu/R5t8CB5jBHBgNVHSMEQDA+gBTn0C+xmZY/BTab4W9gBp3dGa7WgqEjpCEw\n" +
 154         "HzELMAkGA1UEBhMCVVMxEDAOBgNVBAoTB0V4YW1wbGWCAQAwDwYDVR0TAQH/BAUw\n" +
 155         "AwEB/zALBgNVHQ8EBAMCAgQwDQYJKoZIhvcNAQECBQADgYEAPtEjwbWuC5kc4DPc\n" +
 156         "Ttf/wdbD8ZCdAWzcc3XF9q1TlvwVMNk6mbfM05y6ZVsztKTkwZ4EcvFu/yIqw1EB\n" +
 157         "E1zlXQCaWXT3/ZMbqYZV4+mx+RUl8spUCb1tda25jnTg3mTOzB1iztm4gy903EMd\n" +
 158         "m8omKDKeCgcw5dR4ITQYvyxe1as=\n" +
 159         "-----END CERTIFICATE-----";
 160 
 161     // MD2withRSA 1024 signed with RSA 512
 162     static String intermediate_MD2withRSA_1024_512 =
 163         "-----BEGIN CERTIFICATE-----\n" +
 164         "MIICDzCCAbmgAwIBAgIBBzANBgkqhkiG9w0BAQIFADAfMQswCQYDVQQGEwJVUzEQ\n" +
 165         "MA4GA1UEChMHRXhhbXBsZTAeFw0wOTA4MDYwMTExNDlaFw0yOTA0MjMwMTExNDla\n" +
 166         "MDExCzAJBgNVBAYTAlVTMRAwDgYDVQQKEwdFeGFtcGxlMRAwDgYDVQQLEwdDbGFz\n" +
 167         "cy0xMIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCVOqnlZspyAEr90ELFaUo8\n" +
 168         "BF0O2Kn0yTdUeyiLOth4RA3qxWrjxJq45VmEBjZpEzPHfnp3PhnfmLcLfhoPONFg\n" +
 169         "bcHzlkj75ZaKCgHoyV456fMBmj348fcoUkH2WdSQ82pmxHOiHqquYNUSTimFIq82\n" +
 170         "AayhbKqDmhfx5lJdYNqd5QIDAQABo4GJMIGGMB0GA1UdDgQWBBTfWD9mRTppcUAl\n" +
 171         "UqGuu/R5t8CB5jBHBgNVHSMEQDA+gBSDgrB3juF01AGnyCtmxEnle+G/EKEjpCEw\n" +
 172         "HzELMAkGA1UEBhMCVVMxEDAOBgNVBAoTB0V4YW1wbGWCAQAwDwYDVR0TAQH/BAUw\n" +
 173         "AwEB/zALBgNVHQ8EBAMCAgQwDQYJKoZIhvcNAQECBQADQQBHok1v6xymtpB7N9xy\n" +
 174         "0OmDT27uhmzlP0eOzJvXVxj3Oi9TLQJgCUJ9122MzfRAs1E1uJTtvuu+UmI80NQx\n" +
 175         "KQdp\n" +
 176         "-----END CERTIFICATE-----";
 177 
 178     private static CertPath generateCertificatePath(String certStr)
 179             throws CertificateException {
 180         // generate certificate from cert strings
 181         CertificateFactory cf = CertificateFactory.getInstance("X.509");
 182 
 183         ByteArrayInputStream is;
 184 
 185         is = new ByteArrayInputStream(certStr.getBytes());
 186         Certificate cert = cf.generateCertificate(is);
 187 
 188         // generate certification path
 189         List<Certificate> list = Arrays.asList(new Certificate[] {cert});
 190 
 191         return cf.generateCertPath(list);
 192     }
 193 
 194     private static Set<TrustAnchor> generateTrustAnchors()
 195             throws CertificateException {
 196         // generate certificate from cert string
 197         CertificateFactory cf = CertificateFactory.getInstance("X.509");
 198         HashSet<TrustAnchor> anchors = new HashSet<TrustAnchor>();
 199 
 200         ByteArrayInputStream is =
 201             new ByteArrayInputStream(trustAnchor_SHA1withRSA_1024.getBytes());
 202         Certificate cert = cf.generateCertificate(is);
 203         TrustAnchor anchor = new TrustAnchor((X509Certificate)cert, null);
 204         anchors.add(anchor);
 205 
 206         is = new ByteArrayInputStream(trustAnchor_SHA1withRSA_512.getBytes());
 207         cert = cf.generateCertificate(is);
 208         anchor = new TrustAnchor((X509Certificate)cert, null);
 209         anchors.add(anchor);
 210 
 211         return anchors;
 212     }
 213 
 214     public static void main(String args[]) throws Exception {
 215         // reset the security property to make sure that the algorithms
 216         // and keys used in this test are not disabled.
 217         Security.setProperty("jdk.certpath.disabledAlgorithms", "MD2");
 218 
 219         try {
 220             validate(intermediate_SHA1withRSA_1024_1024);
 221             validate(intermediate_SHA1withRSA_1024_512);
 222             validate(intermediate_SHA1withRSA_512_1024);
 223             validate(intermediate_SHA1withRSA_512_512);
 224         } catch (CertPathValidatorException cpve) {
 225             throw new Exception(
 226                 "unexpect exception, it is valid cert", cpve);
 227         }
 228 
 229         try {
 230             validate(intermediate_MD2withRSA_1024_1024);
 231             throw new Exception("expected algorithm disabled exception");
 232         } catch (CertPathValidatorException cpve) {
 233             System.out.println("Get the expected exception " + cpve);
 234         }
 235 
 236         try {
 237             validate(intermediate_MD2withRSA_1024_512);
 238             throw new Exception("expected algorithm disabled exception");
 239         } catch (CertPathValidatorException cpve) {
 240             System.out.println("Get the expected exception " + cpve);
 241         }
 242     }
 243 
 244     private static void validate(String intermediate)
 245             throws CertPathValidatorException, Exception {
 246 
 247         CertPath path = generateCertificatePath(intermediate);
 248         Set<TrustAnchor> anchors = generateTrustAnchors();
 249 
 250         PKIXParameters params = new PKIXParameters(anchors);
 251 
 252         // disable certificate revocation checking
 253         params.setRevocationEnabled(false);
 254 
 255         // set the validation time
 256         params.setDate(new Date(109, 9, 1));   // 2009-09-01
 257 
 258         CertPathValidator validator = CertPathValidator.getInstance("PKIX");
 259 
 260         validator.validate(path, params);
 261     }
 262 
 263 }