final class sun.security.ssl.JsseJce
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.JsseJce
  super_class: java.lang.Object
{
  static final boolean ALLOW_ECC;
    descriptor: Z
    flags: (0x0018) ACC_STATIC, ACC_FINAL

  private static final sun.security.jca.ProviderList fipsProviderList;
    descriptor: Lsun/security/jca/ProviderList;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static final java.lang.String CIPHER_RSA_PKCS1;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RSA/ECB/PKCS1Padding"

  static final java.lang.String CIPHER_RC4;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RC4"

  static final java.lang.String CIPHER_DES;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "DES/CBC/NoPadding"

  static final java.lang.String CIPHER_3DES;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "DESede/CBC/NoPadding"

  static final java.lang.String CIPHER_AES;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "AES/CBC/NoPadding"

  static final java.lang.String CIPHER_AES_GCM;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "AES/GCM/NoPadding"

  static final java.lang.String CIPHER_CHACHA20_POLY1305;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "ChaCha20-Poly1305"

  static final java.lang.String SIGNATURE_DSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "DSA"

  static final java.lang.String SIGNATURE_ECDSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "SHA1withECDSA"

  static final java.lang.String SIGNATURE_RAWDSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RawDSA"

  static final java.lang.String SIGNATURE_RAWECDSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "NONEwithECDSA"

  static final java.lang.String SIGNATURE_RAWRSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "NONEwithRSA"

  static final java.lang.String SIGNATURE_SSLRSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "MD5andSHA1withRSA"

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=0
         0: .line 48
            ldc "com.sun.net.ssl.enableECC"
            iconst_1
            invokestatic sun.security.ssl.Utilities.getBooleanProperty:(Ljava/lang/String;Z)Z
         1: .line 47
            putstatic sun.security.ssl.JsseJce.ALLOW_ECC:Z
         2: .line 57
            invokestatic sun.security.ssl.SunJSSE.isFIPS:()Z
            ifne 5
         3: .line 58
            aconst_null
            putstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
         4: .line 59
            goto 12
         5: .line 64
      StackMap locals:
      StackMap stack:
            ldc "SUN"
            invokestatic java.security.Security.getProvider:(Ljava/lang/String;)Ljava/security/Provider;
            astore 0 /* sun */
        start local 0 // java.security.Provider sun
         6: .line 65
            aload 0 /* sun */
            ifnonnull 10
         7: .line 66
            new java.lang.RuntimeException
            dup
         8: .line 67
            ldc "FIPS mode: SUN provider must be installed"
         9: .line 66
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
        10: .line 69
      StackMap locals: java.security.Provider
      StackMap stack:
            new sun.security.ssl.JsseJce$SunCertificates
            dup
            aload 0 /* sun */
            invokespecial sun.security.ssl.JsseJce$SunCertificates.<init>:(Ljava/security/Provider;)V
            astore 1 /* sunCerts */
        start local 1 // java.security.Provider sunCerts
        11: .line 70
            iconst_2
            anewarray java.security.Provider
            dup
            iconst_0
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            aastore
            dup
            iconst_1
            aload 1 /* sunCerts */
            aastore
            invokestatic sun.security.jca.ProviderList.newList:([Ljava/security/Provider;)Lsun/security/jca/ProviderList;
            putstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
        end local 1 // java.security.Provider sunCerts
        end local 0 // java.security.Provider sun
        12: .line 173
      StackMap locals:
      StackMap stack:
            return
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            6   12     0       sun  Ljava/security/Provider;
           11   12     1  sunCerts  Ljava/security/Provider;

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.JsseJce this
         0: .line 175
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 177
            return
        end local 0 // sun.security.ssl.JsseJce this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lsun/security/ssl/JsseJce;

  static boolean isEcAvailable();
    descriptor: ()Z
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 180
            getstatic sun.security.ssl.JsseJce$EcAvailability.isAvailable:Z
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static javax.crypto.Cipher getCipher(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/Cipher;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.lang.String transformation
         0: .line 189
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 3
         1: .line 190
            aload 0 /* transformation */
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;)Ljavax/crypto/Cipher;
         2: areturn
         3: .line 192
      StackMap locals:
      StackMap stack:
            aload 0 /* transformation */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.Cipher.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/Cipher;
         4: areturn
         5: .line 194
      StackMap locals:
      StackMap stack: javax.crypto.NoSuchPaddingException
            astore 1 /* e */
        start local 1 // javax.crypto.NoSuchPaddingException e
         6: .line 195
            new java.security.NoSuchAlgorithmException
            dup
            aload 1 /* e */
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // javax.crypto.NoSuchPaddingException e
        end local 0 // java.lang.String transformation
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    7     0  transformation  Ljava/lang/String;
            6    7     1               e  Ljavax/crypto/NoSuchPaddingException;
      Exception table:
        from    to  target  type
           0     2       5  Class javax.crypto.NoSuchPaddingException
           3     4       5  Class javax.crypto.NoSuchPaddingException
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
                Name  Flags
      transformation  

  static java.security.Signature getSignature(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/Signature;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 206
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 207
            aload 0 /* algorithm */
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;)Ljava/security/Signature;
            areturn
         2: .line 210
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            ldc "MD5andSHA1withRSA"
            if_acmpne 8
         3: .line 215
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ldc "Signature"
            aload 0 /* algorithm */
            invokevirtual java.security.Provider.getService:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Provider$Service;
            ifnonnull 8
         4: .line 220
            aload 0 /* algorithm */
            ldc "SunJSSE"
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/lang/String;)Ljava/security/Signature;
         5: areturn
         6: .line 221
      StackMap locals:
      StackMap stack: java.security.NoSuchProviderException
            astore 1 /* e */
        start local 1 // java.security.NoSuchProviderException e
         7: .line 222
            new java.security.NoSuchAlgorithmException
            dup
            aload 1 /* e */
            invokespecial java.security.NoSuchAlgorithmException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.NoSuchProviderException e
         8: .line 226
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.Signature.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/Signature;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0  algorithm  Ljava/lang/String;
            7    8     1          e  Ljava/security/NoSuchProviderException;
      Exception table:
        from    to  target  type
           4     5       6  Class java.security.NoSuchProviderException
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static javax.crypto.KeyGenerator getKeyGenerator(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 232
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 233
            aload 0 /* algorithm */
            invokestatic javax.crypto.KeyGenerator.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
            areturn
         2: .line 235
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.KeyGenerator.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/KeyGenerator;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.KeyPairGenerator getKeyPairGenerator(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/KeyPairGenerator;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 241
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 242
            aload 0 /* algorithm */
            invokestatic java.security.KeyPairGenerator.getInstance:(Ljava/lang/String;)Ljava/security/KeyPairGenerator;
            areturn
         2: .line 244
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.KeyPairGenerator.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/KeyPairGenerator;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static javax.crypto.KeyAgreement getKeyAgreement(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/KeyAgreement;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 250
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 251
            aload 0 /* algorithm */
            invokestatic javax.crypto.KeyAgreement.getInstance:(Ljava/lang/String;)Ljavax/crypto/KeyAgreement;
            areturn
         2: .line 253
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.KeyAgreement.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/KeyAgreement;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static javax.crypto.Mac getMac(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljavax/crypto/Mac;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 259
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 260
            aload 0 /* algorithm */
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;)Ljavax/crypto/Mac;
            areturn
         2: .line 262
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic javax.crypto.Mac.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljavax/crypto/Mac;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.KeyFactory getKeyFactory(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/KeyFactory;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 268
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 269
            aload 0 /* algorithm */
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;)Ljava/security/KeyFactory;
            areturn
         2: .line 271
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.KeyFactory.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/KeyFactory;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.AlgorithmParameters getAlgorithmParameters(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/AlgorithmParameters;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 277
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 278
            aload 0 /* algorithm */
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;)Ljava/security/AlgorithmParameters;
            areturn
         2: .line 280
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.AlgorithmParameters.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/AlgorithmParameters;
            areturn
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0  algorithm  Ljava/lang/String;
    Exceptions:
      throws java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static java.security.SecureRandom getSecureRandom();
    descriptor: ()Ljava/security/SecureRandom;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=2, args_size=0
         0: .line 285
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 2
         1: .line 286
            new java.security.SecureRandom
            dup
            invokespecial java.security.SecureRandom.<init>:()V
            areturn
         2: .line 291
      StackMap locals:
      StackMap stack:
            ldc "PKCS11"
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.SecureRandom.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/SecureRandom;
         3: areturn
         4: .line 292
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
         5: .line 295
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokevirtual java.security.Provider.getServices:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 1
            goto 12
      StackMap locals: top java.util.Iterator
      StackMap stack:
         6: aload 1
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.Provider$Service
            astore 0 /* s */
        start local 0 // java.security.Provider$Service s
         7: .line 296
            aload 0 /* s */
            invokevirtual java.security.Provider$Service.getType:()Ljava/lang/String;
            ldc "SecureRandom"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 12
         8: .line 299
            aload 0 /* s */
            invokevirtual java.security.Provider$Service.getAlgorithm:()Ljava/lang/String;
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
         9: .line 298
            invokestatic java.security.SecureRandom.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/SecureRandom;
        10: areturn
        11: .line 300
      StackMap locals: java.security.Provider$Service java.util.Iterator
      StackMap stack: java.security.NoSuchAlgorithmException
            pop
        end local 0 // java.security.Provider$Service s
        12: .line 295
      StackMap locals: top java.util.Iterator
      StackMap stack:
            aload 1
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        13: .line 305
            new java.security.KeyManagementException
            dup
            new java.lang.StringBuilder
            dup
            ldc "FIPS mode: no SecureRandom  implementation found in provider "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        14: .line 306
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokevirtual java.security.Provider.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        15: .line 305
            invokespecial java.security.KeyManagementException.<init>:(Ljava/lang/String;)V
            athrow
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            7   12     0     s  Ljava/security/Provider$Service;
      Exception table:
        from    to  target  type
           2     3       4  Class java.security.NoSuchAlgorithmException
           8    10      11  Class java.security.NoSuchAlgorithmException
    Exceptions:
      throws java.security.KeyManagementException

  static java.security.MessageDigest getMD5();
    descriptor: ()Ljava/security/MessageDigest;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 310
            ldc "MD5"
            invokestatic sun.security.ssl.JsseJce.getMessageDigest:(Ljava/lang/String;)Ljava/security/MessageDigest;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static java.security.MessageDigest getSHA();
    descriptor: ()Ljava/security/MessageDigest;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 314
            ldc "SHA"
            invokestatic sun.security.ssl.JsseJce.getMessageDigest:(Ljava/lang/String;)Ljava/security/MessageDigest;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static java.security.MessageDigest getMessageDigest(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/MessageDigest;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=5, locals=2, args_size=1
        start local 0 // java.lang.String algorithm
         0: .line 319
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            ifnonnull 3
         1: .line 320
            aload 0 /* algorithm */
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;)Ljava/security/MessageDigest;
         2: areturn
         3: .line 322
      StackMap locals:
      StackMap stack:
            aload 0 /* algorithm */
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            invokestatic java.security.MessageDigest.getInstance:(Ljava/lang/String;Ljava/security/Provider;)Ljava/security/MessageDigest;
         4: areturn
         5: .line 324
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 1 /* e */
        start local 1 // java.security.NoSuchAlgorithmException e
         6: .line 325
            new java.lang.RuntimeException
            dup
         7: .line 326
            new java.lang.StringBuilder
            dup
            ldc "Algorithm "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* algorithm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " not available"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 1 /* e */
         8: .line 325
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.security.NoSuchAlgorithmException e
        end local 0 // java.lang.String algorithm
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0  algorithm  Ljava/lang/String;
            6    9     1          e  Ljava/security/NoSuchAlgorithmException;
      Exception table:
        from    to  target  type
           0     2       5  Class java.security.NoSuchAlgorithmException
           3     4       5  Class java.security.NoSuchAlgorithmException
    MethodParameters:
           Name  Flags
      algorithm  

  static int getRSAKeyLength(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)I
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // java.security.PublicKey key
         0: .line 332
            aload 0 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 3
         1: .line 333
            aload 0 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
            astore 1 /* modulus */
        start local 1 // java.math.BigInteger modulus
         2: .line 334
            goto 5
        end local 1 // java.math.BigInteger modulus
         3: .line 335
      StackMap locals:
      StackMap stack:
            aload 0 /* key */
            invokestatic sun.security.ssl.JsseJce.getRSAPublicKeySpec:(Ljava/security/PublicKey;)Ljava/security/spec/RSAPublicKeySpec;
            astore 2 /* spec */
        start local 2 // java.security.spec.RSAPublicKeySpec spec
         4: .line 336
            aload 2 /* spec */
            invokevirtual java.security.spec.RSAPublicKeySpec.getModulus:()Ljava/math/BigInteger;
            astore 1 /* modulus */
        end local 2 // java.security.spec.RSAPublicKeySpec spec
        start local 1 // java.math.BigInteger modulus
         5: .line 338
      StackMap locals: java.math.BigInteger
      StackMap stack:
            aload 1 /* modulus */
            invokevirtual java.math.BigInteger.bitLength:()I
            ireturn
        end local 1 // java.math.BigInteger modulus
        end local 0 // java.security.PublicKey key
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0      key  Ljava/security/PublicKey;
            2    3     1  modulus  Ljava/math/BigInteger;
            5    6     1  modulus  Ljava/math/BigInteger;
            4    5     2     spec  Ljava/security/spec/RSAPublicKeySpec;
    MethodParameters:
      Name  Flags
      key   

  static java.security.spec.RSAPublicKeySpec getRSAPublicKeySpec(java.security.PublicKey);
    descriptor: (Ljava/security/PublicKey;)Ljava/security/spec/RSAPublicKeySpec;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // java.security.PublicKey key
         0: .line 342
            aload 0 /* key */
            instanceof java.security.interfaces.RSAPublicKey
            ifeq 5
         1: .line 343
            aload 0 /* key */
            checkcast java.security.interfaces.RSAPublicKey
            astore 1 /* rsaKey */
        start local 1 // java.security.interfaces.RSAPublicKey rsaKey
         2: .line 344
            new java.security.spec.RSAPublicKeySpec
            dup
            aload 1 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getModulus:()Ljava/math/BigInteger;
         3: .line 345
            aload 1 /* rsaKey */
            invokeinterface java.security.interfaces.RSAPublicKey.getPublicExponent:()Ljava/math/BigInteger;
         4: .line 344
            invokespecial java.security.spec.RSAPublicKeySpec.<init>:(Ljava/math/BigInteger;Ljava/math/BigInteger;)V
            areturn
        end local 1 // java.security.interfaces.RSAPublicKey rsaKey
         5: .line 348
      StackMap locals:
      StackMap stack:
            ldc "RSA"
            invokestatic sun.security.ssl.JsseJce.getKeyFactory:(Ljava/lang/String;)Ljava/security/KeyFactory;
            astore 1 /* factory */
        start local 1 // java.security.KeyFactory factory
         6: .line 349
            aload 1 /* factory */
            aload 0 /* key */
            ldc Ljava/security/spec/RSAPublicKeySpec;
            invokevirtual java.security.KeyFactory.getKeySpec:(Ljava/security/Key;Ljava/lang/Class;)Ljava/security/spec/KeySpec;
            checkcast java.security.spec.RSAPublicKeySpec
         7: areturn
        end local 1 // java.security.KeyFactory factory
         8: .line 350
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
         9: .line 351
            new java.lang.RuntimeException
            dup
            aload 1 /* e */
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 1 // java.lang.Exception e
        end local 0 // java.security.PublicKey key
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   10     0      key  Ljava/security/PublicKey;
            2    5     1   rsaKey  Ljava/security/interfaces/RSAPublicKey;
            6    8     1  factory  Ljava/security/KeyFactory;
            9   10     1        e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           5     7       8  Class java.lang.Exception
    MethodParameters:
      Name  Flags
      key   

  static java.security.spec.ECParameterSpec getECParameterSpec(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/security/spec/ECParameterSpec;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.lang.String namedCurveOid
         0: .line 356
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            aload 0 /* namedCurveOid */
            invokestatic sun.security.util.ECUtil.getECParameterSpec:(Ljava/security/Provider;Ljava/lang/String;)Ljava/security/spec/ECParameterSpec;
            areturn
        end local 0 // java.lang.String namedCurveOid
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    1     0  namedCurveOid  Ljava/lang/String;
    MethodParameters:
               Name  Flags
      namedCurveOid  

  static java.lang.String getNamedCurveOid(java.security.spec.ECParameterSpec);
    descriptor: (Ljava/security/spec/ECParameterSpec;)Ljava/lang/String;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // java.security.spec.ECParameterSpec params
         0: .line 360
            getstatic sun.security.ssl.SunJSSE.cryptoProvider:Ljava/security/Provider;
            aload 0 /* params */
            invokestatic sun.security.util.ECUtil.getCurveName:(Ljava/security/Provider;Ljava/security/spec/ECParameterSpec;)Ljava/lang/String;
            areturn
        end local 0 // java.security.spec.ECParameterSpec params
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0  params  Ljava/security/spec/ECParameterSpec;
    MethodParameters:
        Name  Flags
      params  

  static java.security.spec.ECPoint decodePoint(byte[], java.security.spec.EllipticCurve);
    descriptor: ([BLjava/security/spec/EllipticCurve;)Ljava/security/spec/ECPoint;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // byte[] encoded
        start local 1 // java.security.spec.EllipticCurve curve
         0: .line 365
            aload 0 /* encoded */
            aload 1 /* curve */
            invokestatic sun.security.util.ECUtil.decodePoint:([BLjava/security/spec/EllipticCurve;)Ljava/security/spec/ECPoint;
            areturn
        end local 1 // java.security.spec.EllipticCurve curve
        end local 0 // byte[] encoded
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    1     0  encoded  [B
            0    1     1    curve  Ljava/security/spec/EllipticCurve;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      encoded  
      curve    

  static byte[] encodePoint(java.security.spec.ECPoint, java.security.spec.EllipticCurve);
    descriptor: (Ljava/security/spec/ECPoint;Ljava/security/spec/EllipticCurve;)[B
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.security.spec.ECPoint point
        start local 1 // java.security.spec.EllipticCurve curve
         0: .line 369
            aload 0 /* point */
            aload 1 /* curve */
            invokestatic sun.security.util.ECUtil.encodePoint:(Ljava/security/spec/ECPoint;Ljava/security/spec/EllipticCurve;)[B
            areturn
        end local 1 // java.security.spec.EllipticCurve curve
        end local 0 // java.security.spec.ECPoint point
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    1     0  point  Ljava/security/spec/ECPoint;
            0    1     1  curve  Ljava/security/spec/EllipticCurve;
    MethodParameters:
       Name  Flags
      point  
      curve  

  static java.lang.Object beginFipsProvider();
    descriptor: ()Ljava/lang/Object;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 375
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            ifnonnull 2
         1: .line 376
            aconst_null
            areturn
         2: .line 378
      StackMap locals:
      StackMap stack:
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            invokestatic sun.security.jca.Providers.beginThreadProviderList:(Lsun/security/jca/ProviderList;)Lsun/security/jca/ProviderList;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  static void endFipsProvider(java.lang.Object);
    descriptor: (Ljava/lang/Object;)V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.lang.Object o
         0: .line 383
            getstatic sun.security.ssl.JsseJce.fipsProviderList:Lsun/security/jca/ProviderList;
            ifnull 2
         1: .line 384
            aload 0 /* o */
            checkcast sun.security.jca.ProviderList
            invokestatic sun.security.jca.Providers.endThreadProviderList:(Lsun/security/jca/ProviderList;)V
         2: .line 386
      StackMap locals:
      StackMap stack:
            return
        end local 0 // java.lang.Object o
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0     o  Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      o     
}
SourceFile: "JsseJce.java"
NestMembers:
  sun.security.ssl.JsseJce$EcAvailability  sun.security.ssl.JsseJce$SunCertificates  sun.security.ssl.JsseJce$SunCertificates$1
InnerClasses:
  public Service = java.security.Provider$Service of java.security.Provider
  private EcAvailability = sun.security.ssl.JsseJce$EcAvailability of sun.security.ssl.JsseJce
  private final SunCertificates = sun.security.ssl.JsseJce$SunCertificates of sun.security.ssl.JsseJce