final class sun.security.ssl.X509KeyManagerImpl$CheckType extends java.lang.Enum<sun.security.ssl.X509KeyManagerImpl$CheckType>
  minor version: 0
  major version: 59
  flags: flags: (0x4030) ACC_FINAL, ACC_SUPER, ACC_ANNOTATION
  this_class: sun.security.ssl.X509KeyManagerImpl$CheckType
  super_class: java.lang.Enum
{
  public static final sun.security.ssl.X509KeyManagerImpl$CheckType NONE;
    descriptor: Lsun/security/ssl/X509KeyManagerImpl$CheckType;
    flags: (0x4019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL, ACC_ANNOTATION

  public static final sun.security.ssl.X509KeyManagerImpl$CheckType CLIENT;
    descriptor: Lsun/security/ssl/X509KeyManagerImpl$CheckType;
    flags: (0x4019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL, ACC_ANNOTATION

  public static final sun.security.ssl.X509KeyManagerImpl$CheckType SERVER;
    descriptor: Lsun/security/ssl/X509KeyManagerImpl$CheckType;
    flags: (0x4019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL, ACC_ANNOTATION

  final java.util.Set<java.lang.String> validEku;
    descriptor: Ljava/util/Set;
    flags: (0x0010) ACC_FINAL
    Signature: Ljava/util/Set<Ljava/lang/String;>;

  private static final sun.security.ssl.X509KeyManagerImpl$CheckType[] ENUM$VALUES;
    descriptor: [Lsun/security/ssl/X509KeyManagerImpl$CheckType;
    flags: (0x101a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=10, locals=0, args_size=0
         0: .line 408
            new sun.security.ssl.X509KeyManagerImpl$CheckType
            dup
            ldc "NONE"
            iconst_0
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            invokespecial sun.security.ssl.X509KeyManagerImpl$CheckType.<init>:(Ljava/lang/String;ILjava/util/Set;)V
            putstatic sun.security.ssl.X509KeyManagerImpl$CheckType.NONE:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         1: .line 412
            new sun.security.ssl.X509KeyManagerImpl$CheckType
            dup
            ldc "CLIENT"
            iconst_1
            new java.util.HashSet
            dup
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
         2: .line 413
            ldc "2.5.29.37.0"
            aastore
            dup
            iconst_1
            ldc "1.3.6.1.5.5.7.3.2"
            aastore
         3: .line 412
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            invokespecial sun.security.ssl.X509KeyManagerImpl$CheckType.<init>:(Ljava/lang/String;ILjava/util/Set;)V
            putstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         4: .line 417
            new sun.security.ssl.X509KeyManagerImpl$CheckType
            dup
            ldc "SERVER"
            iconst_2
            new java.util.HashSet
            dup
            iconst_4
            anewarray java.lang.String
            dup
            iconst_0
         5: .line 418
            ldc "2.5.29.37.0"
            aastore
            dup
            iconst_1
            ldc "1.3.6.1.5.5.7.3.1"
            aastore
            dup
            iconst_2
            ldc "2.16.840.1.113730.4.1"
            aastore
            dup
            iconst_3
         6: .line 419
            ldc "1.3.6.1.4.1.311.10.3.3"
            aastore
         7: .line 417
            invokestatic java.util.Arrays.asList:([Ljava/lang/Object;)Ljava/util/List;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            invokespecial sun.security.ssl.X509KeyManagerImpl$CheckType.<init>:(Ljava/lang/String;ILjava/util/Set;)V
            putstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
         8: .line 405
            iconst_3
            anewarray sun.security.ssl.X509KeyManagerImpl$CheckType
            dup
            iconst_0
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.NONE:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            aastore
            dup
            iconst_1
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            aastore
            dup
            iconst_2
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            aastore
            putstatic sun.security.ssl.X509KeyManagerImpl$CheckType.ENUM$VALUES:[Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>(java.util.Set<java.lang.String>);
    descriptor: (Ljava/lang/String;ILjava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // sun.security.ssl.X509KeyManagerImpl$CheckType this
        start local 3 // java.util.Set validEku
         0: .line 424
            aload 0 /* this */
            aload 1
            iload 2
            invokespecial java.lang.Enum.<init>:(Ljava/lang/String;I)V
         1: .line 425
            aload 0 /* this */
            aload 3 /* validEku */
            putfield sun.security.ssl.X509KeyManagerImpl$CheckType.validEku:Ljava/util/Set;
         2: .line 426
            return
        end local 3 // java.util.Set validEku
        end local 0 // sun.security.ssl.X509KeyManagerImpl$CheckType this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0    3     3  validEku  Ljava/util/Set<Ljava/lang/String;>;
    Signature: (Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
               Name  Flags
      $enum$name     
      $enum$ordinal  
      validEku       

  private static boolean getBit(boolean[], int);
    descriptor: ([ZI)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // boolean[] keyUsage
        start local 1 // int bit
         0: .line 429
            iload 1 /* bit */
            aload 0 /* keyUsage */
            arraylength
            if_icmpge 1
            aload 0 /* keyUsage */
            iload 1 /* bit */
            baload
            ifeq 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 1 // int bit
        end local 0 // boolean[] keyUsage
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0  keyUsage  [Z
            0    2     1       bit  I
    MethodParameters:
          Name  Flags
      keyUsage  
      bit       

  sun.security.ssl.X509KeyManagerImpl$CheckResult check(java.security.cert.X509Certificate, java.util.Date);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/util/Date;)Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
    flags: (0x0000) 
    Code:
      stack=2, locals=7, args_size=3
        start local 0 // sun.security.ssl.X509KeyManagerImpl$CheckType this
        start local 1 // java.security.cert.X509Certificate cert
        start local 2 // java.util.Date date
         0: .line 437
            aload 0 /* this */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.NONE:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            if_acmpne 2
         1: .line 438
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.OK:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            areturn
         2: .line 444
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getExtendedKeyUsage:()Ljava/util/List;
            astore 3 /* certEku */
        start local 3 // java.util.List certEku
         3: .line 445
            aload 3 /* certEku */
            ifnull 6
            aload 0 /* this */
            getfield sun.security.ssl.X509KeyManagerImpl$CheckType.validEku:Ljava/util/Set;
            aload 3 /* certEku */
            invokestatic java.util.Collections.disjoint:(Ljava/util/Collection;Ljava/util/Collection;)Z
            ifeq 6
         4: .line 448
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
         5: areturn
         6: .line 452
      StackMap locals: java.util.List
      StackMap stack:
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getKeyUsage:()[Z
            astore 4 /* ku */
        start local 4 // boolean[] ku
         7: .line 453
            aload 4 /* ku */
            ifnull 32
         8: .line 454
            aload 1 /* cert */
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            astore 5 /* algorithm */
        start local 5 // java.lang.String algorithm
         9: .line 455
            aload 4 /* ku */
            iconst_0
            invokestatic sun.security.ssl.X509KeyManagerImpl$CheckType.getBit:([ZI)Z
            istore 6 /* kuSignature */
        start local 6 // boolean kuSignature
        10: .line 456
            ldc "RSA"
            aload 5 /* algorithm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 15
        11: .line 459
            iload 6 /* kuSignature */
            ifne 32
        12: .line 460
            aload 0 /* this */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            if_acmpeq 13
            aload 4 /* ku */
            iconst_2
            invokestatic sun.security.ssl.X509KeyManagerImpl$CheckType.getBit:([ZI)Z
            ifne 32
        13: .line 461
      StackMap locals: boolean[] java.lang.String int
      StackMap stack:
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        14: areturn
        15: .line 464
      StackMap locals:
      StackMap stack:
            ldc "DSA"
            aload 5 /* algorithm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 19
        16: .line 466
            iload 6 /* kuSignature */
            ifne 32
        17: .line 467
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        18: areturn
        19: .line 469
      StackMap locals:
      StackMap stack:
            ldc "DH"
            aload 5 /* algorithm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 23
        20: .line 471
            aload 4 /* ku */
            iconst_4
            invokestatic sun.security.ssl.X509KeyManagerImpl$CheckType.getBit:([ZI)Z
            ifne 32
        21: .line 472
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        22: areturn
        23: .line 474
      StackMap locals:
      StackMap stack:
            ldc "EC"
            aload 5 /* algorithm */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 32
        24: .line 476
            iload 6 /* kuSignature */
            ifne 27
        25: .line 477
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        26: areturn
        27: .line 485
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            if_acmpne 32
            aload 4 /* ku */
            iconst_4
            invokestatic sun.security.ssl.X509KeyManagerImpl$CheckType.getBit:([ZI)Z
            ifne 32
        28: .line 486
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        29: areturn
        end local 6 // boolean kuSignature
        end local 5 // java.lang.String algorithm
        end local 4 // boolean[] ku
        end local 3 // java.util.List certEku
        30: .line 490
      StackMap locals: sun.security.ssl.X509KeyManagerImpl$CheckType java.security.cert.X509Certificate java.util.Date
      StackMap stack: java.security.cert.CertificateException
            pop
        31: .line 492
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXTENSION_MISMATCH:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            areturn
        32: .line 496
      StackMap locals:
      StackMap stack:
            aload 1 /* cert */
            aload 2 /* date */
            invokevirtual java.security.cert.X509Certificate.checkValidity:(Ljava/util/Date;)V
        33: .line 497
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.OK:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
        34: areturn
        35: .line 498
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            pop
        36: .line 499
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckResult.EXPIRED:Lsun/security/ssl/X509KeyManagerImpl$CheckResult;
            areturn
        end local 2 // java.util.Date date
        end local 1 // java.security.cert.X509Certificate cert
        end local 0 // sun.security.ssl.X509KeyManagerImpl$CheckType this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   37     0         this  Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            0   37     1         cert  Ljava/security/cert/X509Certificate;
            0   37     2         date  Ljava/util/Date;
            3   30     3      certEku  Ljava/util/List<Ljava/lang/String;>;
            7   30     4           ku  [Z
            9   30     5    algorithm  Ljava/lang/String;
           10   30     6  kuSignature  Z
      Exception table:
        from    to  target  type
           2     5      30  Class java.security.cert.CertificateException
           6    14      30  Class java.security.cert.CertificateException
          15    18      30  Class java.security.cert.CertificateException
          19    22      30  Class java.security.cert.CertificateException
          23    26      30  Class java.security.cert.CertificateException
          27    29      30  Class java.security.cert.CertificateException
          32    34      35  Class java.security.cert.CertificateException
    MethodParameters:
      Name  Flags
      cert  
      date  

  public java.lang.String getValidator();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.ssl.X509KeyManagerImpl$CheckType this
         0: .line 504
            aload 0 /* this */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.CLIENT:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            if_acmpne 2
         1: .line 505
            ldc "tls client"
            areturn
         2: .line 506
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.SERVER:Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            if_acmpne 4
         3: .line 507
            ldc "tls server"
            areturn
         4: .line 509
      StackMap locals:
      StackMap stack:
            ldc "generic"
            areturn
        end local 0 // sun.security.ssl.X509KeyManagerImpl$CheckType this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lsun/security/ssl/X509KeyManagerImpl$CheckType;

  public static sun.security.ssl.X509KeyManagerImpl$CheckType[] values();
    descriptor: ()[Lsun/security/ssl/X509KeyManagerImpl$CheckType;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=3, args_size=0
         0: .line 1
            getstatic sun.security.ssl.X509KeyManagerImpl$CheckType.ENUM$VALUES:[Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            dup
            astore 0
            iconst_0
            aload 0
            arraylength
            dup
            istore 1
            anewarray sun.security.ssl.X509KeyManagerImpl$CheckType
            dup
            astore 2
            iconst_0
            iload 1
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
            aload 2
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public static sun.security.ssl.X509KeyManagerImpl$CheckType valueOf(java.lang.String);
    descriptor: (Ljava/lang/String;)Lsun/security/ssl/X509KeyManagerImpl$CheckType;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=2, locals=1, args_size=1
         0: .line 1
            ldc Lsun/security/ssl/X509KeyManagerImpl$CheckType;
            aload 0
            invokestatic java.lang.Enum.valueOf:(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Enum;
            checkcast sun.security.ssl.X509KeyManagerImpl$CheckType
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    MethodParameters:
      Name  Flags
      name  
}
Signature: Ljava/lang/Enum<Lsun/security/ssl/X509KeyManagerImpl$CheckType;>;
SourceFile: "X509KeyManagerImpl.java"
NestHost: sun.security.ssl.X509KeyManagerImpl
InnerClasses:
  private final CheckResult = sun.security.ssl.X509KeyManagerImpl$CheckResult of sun.security.ssl.X509KeyManagerImpl
  private final CheckType = sun.security.ssl.X509KeyManagerImpl$CheckType of sun.security.ssl.X509KeyManagerImpl