javacommons/security/javasrc/javax/microedition/pki/CertificateException.java
branchRCL_3
changeset 14 04becd199f91
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/javacommons/security/javasrc/javax/microedition/pki/CertificateException.java	Tue Apr 27 16:30:29 2010 +0300
@@ -0,0 +1,95 @@
+/*
+* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description:
+*
+*/
+
+
+package javax.microedition.pki;
+
+import java.io.IOException;
+
+public class CertificateException
+        extends IOException
+{
+    public static final byte BAD_EXTENSIONS = 1;
+    public static final byte CERTIFICATE_CHAIN_TOO_LONG = 2;
+    public static final byte EXPIRED = 3;
+    public static final byte UNAUTHORIZED_INTERMEDIATE_CA = 4;
+    public static final byte MISSING_SIGNATURE = 5;
+    public static final byte NOT_YET_VALID = 6;
+    public static final byte SITENAME_MISMATCH = 7;
+    public static final byte UNRECOGNIZED_ISSUER = 8;
+    public static final byte UNSUPPORTED_SIGALG = 9;
+    public static final byte INAPPROPRIATE_KEY_USAGE = 10;
+    public static final byte BROKEN_CHAIN = 11;
+    public static final byte ROOT_CA_EXPIRED = 12;
+    public static final byte UNSUPPORTED_PUBLIC_KEY_TYPE = 13;
+    public static final byte VERIFICATION_FAILED = 14;
+
+
+
+    private final Certificate iCert;
+    private final byte iReason;
+
+
+
+    public CertificateException(Certificate aCert, byte aReason)
+    {
+        this(null, aCert, aReason);
+    }
+
+
+
+    public CertificateException(String aMessage, Certificate aCert, byte aReason)
+    {
+        super(aMessage);
+        iCert = aCert;
+        switch (aReason)
+        {
+        case BAD_EXTENSIONS:
+        case CERTIFICATE_CHAIN_TOO_LONG:
+        case EXPIRED:
+        case UNAUTHORIZED_INTERMEDIATE_CA:
+        case MISSING_SIGNATURE:
+        case NOT_YET_VALID:
+        case SITENAME_MISMATCH:
+        case UNRECOGNIZED_ISSUER:
+        case UNSUPPORTED_SIGALG:
+        case INAPPROPRIATE_KEY_USAGE:
+        case BROKEN_CHAIN:
+        case ROOT_CA_EXPIRED:
+        case UNSUPPORTED_PUBLIC_KEY_TYPE:
+        case VERIFICATION_FAILED:
+            iReason = aReason;
+            break;
+        default:
+            throw new IllegalArgumentException();
+        }
+    }
+
+
+
+    public Certificate getCertificate()
+    {
+        return iCert;
+    }
+
+
+
+    public byte getReason()
+    {
+        return iReason;
+    }
+}