final class sun.security.ssl.X509Authentication$X509PossessionGenerator implements sun.security.ssl.SSLPossessionGenerator
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: sun.security.ssl.X509Authentication$X509PossessionGenerator
  super_class: java.lang.Object
{
  private final java.lang.String[] keyTypes;
    descriptor: [Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private void <init>(java.lang.String[]);
    descriptor: ([Ljava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
        start local 1 // java.lang.String[] keyTypes
         0: .line 146
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 147
            aload 0 /* this */
            aload 1 /* keyTypes */
            putfield sun.security.ssl.X509Authentication$X509PossessionGenerator.keyTypes:[Ljava/lang/String;
         2: .line 148
            return
        end local 1 // java.lang.String[] keyTypes
        end local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lsun/security/ssl/X509Authentication$X509PossessionGenerator;
            0    3     1  keyTypes  [Ljava/lang/String;
    MethodParameters:
          Name  Flags
      keyTypes  

  public sun.security.ssl.SSLPossession createPossession(sun.security.ssl.HandshakeContext);
    descriptor: (Lsun/security/ssl/HandshakeContext;)Lsun/security/ssl/SSLPossession;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
        start local 1 // sun.security.ssl.HandshakeContext context
         0: .line 152
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 11
         1: .line 153
            aload 0 /* this */
            getfield sun.security.ssl.X509Authentication$X509PossessionGenerator.keyTypes:[Ljava/lang/String;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 9
      StackMap locals: sun.security.ssl.X509Authentication$X509PossessionGenerator sun.security.ssl.HandshakeContext top int int java.lang.String[]
      StackMap stack:
         2: aload 5
            iload 3
            aaload
            astore 2 /* keyType */
        start local 2 // java.lang.String keyType
         3: .line 154
            aload 0 /* this */
         4: .line 155
            aload 1 /* context */
            checkcast sun.security.ssl.ClientHandshakeContext
            aload 2 /* keyType */
         5: .line 154
            invokevirtual sun.security.ssl.X509Authentication$X509PossessionGenerator.createClientPossession:(Lsun/security/ssl/ClientHandshakeContext;Ljava/lang/String;)Lsun/security/ssl/SSLPossession;
            astore 6 /* poss */
        start local 6 // sun.security.ssl.SSLPossession poss
         6: .line 156
            aload 6 /* poss */
            ifnull 8
         7: .line 157
            aload 6 /* poss */
            areturn
        end local 6 // sun.security.ssl.SSLPossession poss
        end local 2 // java.lang.String keyType
         8: .line 153
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
         9: iload 3
            iload 4
            if_icmplt 2
        10: .line 160
            goto 20
        11: .line 161
      StackMap locals: sun.security.ssl.X509Authentication$X509PossessionGenerator sun.security.ssl.HandshakeContext
      StackMap stack:
            aload 0 /* this */
            getfield sun.security.ssl.X509Authentication$X509PossessionGenerator.keyTypes:[Ljava/lang/String;
            dup
            astore 5
            arraylength
            istore 4
            iconst_0
            istore 3
            goto 19
      StackMap locals: sun.security.ssl.X509Authentication$X509PossessionGenerator sun.security.ssl.HandshakeContext top int int java.lang.String[]
      StackMap stack:
        12: aload 5
            iload 3
            aaload
            astore 2 /* keyType */
        start local 2 // java.lang.String keyType
        13: .line 162
            aload 0 /* this */
        14: .line 163
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            aload 2 /* keyType */
        15: .line 162
            invokevirtual sun.security.ssl.X509Authentication$X509PossessionGenerator.createServerPossession:(Lsun/security/ssl/ServerHandshakeContext;Ljava/lang/String;)Lsun/security/ssl/SSLPossession;
            astore 6 /* poss */
        start local 6 // sun.security.ssl.SSLPossession poss
        16: .line 164
            aload 6 /* poss */
            ifnull 18
        17: .line 165
            aload 6 /* poss */
            areturn
        end local 6 // sun.security.ssl.SSLPossession poss
        end local 2 // java.lang.String keyType
        18: .line 161
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
        19: iload 3
            iload 4
            if_icmplt 12
        20: .line 170
      StackMap locals: sun.security.ssl.X509Authentication$X509PossessionGenerator sun.security.ssl.HandshakeContext
      StackMap stack:
            aconst_null
            areturn
        end local 1 // sun.security.ssl.HandshakeContext context
        end local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   21     0     this  Lsun/security/ssl/X509Authentication$X509PossessionGenerator;
            0   21     1  context  Lsun/security/ssl/HandshakeContext;
            3    8     2  keyType  Ljava/lang/String;
            6    8     6     poss  Lsun/security/ssl/SSLPossession;
           13   18     2  keyType  Ljava/lang/String;
           16   18     6     poss  Lsun/security/ssl/SSLPossession;
    MethodParameters:
         Name  Flags
      context  

  private sun.security.ssl.SSLPossession createClientPossession(sun.security.ssl.ClientHandshakeContext, java.lang.String);
    descriptor: (Lsun/security/ssl/ClientHandshakeContext;Ljava/lang/String;)Lsun/security/ssl/SSLPossession;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=8, args_size=3
        start local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
        start local 1 // sun.security.ssl.ClientHandshakeContext chc
        start local 2 // java.lang.String keyType
         0: .line 176
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getX509KeyManager:()Ljavax/net/ssl/X509ExtendedKeyManager;
            astore 3 /* km */
        start local 3 // javax.net.ssl.X509ExtendedKeyManager km
         1: .line 177
            aconst_null
            astore 4 /* clientAlias */
        start local 4 // java.lang.String clientAlias
         2: .line 178
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            instanceof sun.security.ssl.SSLSocketImpl
            ifeq 9
         3: .line 179
            aload 3 /* km */
         4: .line 180
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 2 /* keyType */
            aastore
         5: .line 181
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.peerSupportedAuthorities:[Ljavax/security/auth/x500/X500Principal;
         6: .line 182
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            checkcast javax.net.ssl.SSLSocket
         7: .line 179
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseClientAlias:([Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
            astore 4 /* clientAlias */
         8: .line 183
            goto 15
      StackMap locals: javax.net.ssl.X509ExtendedKeyManager java.lang.String
      StackMap stack:
         9: aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            instanceof sun.security.ssl.SSLEngineImpl
            ifeq 15
        10: .line 184
            aload 3 /* km */
        11: .line 185
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 2 /* keyType */
            aastore
        12: .line 186
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.peerSupportedAuthorities:[Ljavax/security/auth/x500/X500Principal;
        13: .line 187
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            checkcast javax.net.ssl.SSLEngine
        14: .line 184
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseEngineClientAlias:([Ljava/lang/String;[Ljava/security/Principal;Ljavax/net/ssl/SSLEngine;)Ljava/lang/String;
            astore 4 /* clientAlias */
        15: .line 190
      StackMap locals:
      StackMap stack:
            aload 4 /* clientAlias */
            ifnonnull 19
        16: .line 191
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 18
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 18
        17: .line 192
            new java.lang.StringBuilder
            dup
            ldc "No X.509 cert selected for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* keyType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        18: .line 194
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        19: .line 197
      StackMap locals:
      StackMap stack:
            aload 3 /* km */
            aload 4 /* clientAlias */
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.getPrivateKey:(Ljava/lang/String;)Ljava/security/PrivateKey;
            astore 5 /* clientPrivateKey */
        start local 5 // java.security.PrivateKey clientPrivateKey
        20: .line 198
            aload 5 /* clientPrivateKey */
            ifnonnull 25
        21: .line 199
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 24
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 24
        22: .line 201
            new java.lang.StringBuilder
            dup
            aload 4 /* clientAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " is not a private key entry"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        23: .line 200
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        24: .line 203
      StackMap locals: java.security.PrivateKey
      StackMap stack:
            aconst_null
            areturn
        25: .line 206
      StackMap locals:
      StackMap stack:
            aload 3 /* km */
            aload 4 /* clientAlias */
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.getCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 6 /* clientCerts */
        start local 6 // java.security.cert.X509Certificate[] clientCerts
        26: .line 207
            aload 6 /* clientCerts */
            ifnull 27
            aload 6 /* clientCerts */
            arraylength
            ifne 32
        27: .line 208
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 31
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 31
        28: .line 209
            new java.lang.StringBuilder
            dup
            aload 4 /* clientAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        29: .line 210
            ldc " is a private key entry with no cert chain stored"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        30: .line 209
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        31: .line 212
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        32: .line 215
      StackMap locals:
      StackMap stack:
            aload 6 /* clientCerts */
            iconst_0
            aaload
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 7 /* clientPublicKey */
        start local 7 // java.security.PublicKey clientPublicKey
        33: .line 216
            aload 5 /* clientPrivateKey */
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
            aload 2 /* keyType */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 35
        34: .line 217
            aload 7 /* clientPublicKey */
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            aload 2 /* keyType */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 41
        35: .line 218
      StackMap locals: java.security.PublicKey
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 40
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 40
        36: .line 220
            new java.lang.StringBuilder
            dup
            aload 4 /* clientAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " private or public key is not of "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        37: .line 221
            aload 2 /* keyType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " algorithm"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        38: .line 220
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        39: .line 219
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        40: .line 223
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        41: .line 226
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.X509Authentication$X509Possession
            dup
            aload 5 /* clientPrivateKey */
            aload 6 /* clientCerts */
            invokespecial sun.security.ssl.X509Authentication$X509Possession.<init>:(Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;)V
            areturn
        end local 7 // java.security.PublicKey clientPublicKey
        end local 6 // java.security.cert.X509Certificate[] clientCerts
        end local 5 // java.security.PrivateKey clientPrivateKey
        end local 4 // java.lang.String clientAlias
        end local 3 // javax.net.ssl.X509ExtendedKeyManager km
        end local 2 // java.lang.String keyType
        end local 1 // sun.security.ssl.ClientHandshakeContext chc
        end local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   42     0              this  Lsun/security/ssl/X509Authentication$X509PossessionGenerator;
            0   42     1               chc  Lsun/security/ssl/ClientHandshakeContext;
            0   42     2           keyType  Ljava/lang/String;
            1   42     3                km  Ljavax/net/ssl/X509ExtendedKeyManager;
            2   42     4       clientAlias  Ljava/lang/String;
           20   42     5  clientPrivateKey  Ljava/security/PrivateKey;
           26   42     6       clientCerts  [Ljava/security/cert/X509Certificate;
           33   42     7   clientPublicKey  Ljava/security/PublicKey;
    MethodParameters:
         Name  Flags
      chc      
      keyType  

  private sun.security.ssl.SSLPossession createServerPossession(sun.security.ssl.ServerHandshakeContext, java.lang.String);
    descriptor: (Lsun/security/ssl/ServerHandshakeContext;Ljava/lang/String;)Lsun/security/ssl/SSLPossession;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=10, args_size=3
        start local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
        start local 1 // sun.security.ssl.ServerHandshakeContext shc
        start local 2 // java.lang.String keyType
         0: .line 231
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.sslContext:Lsun/security/ssl/SSLContextImpl;
            invokevirtual sun.security.ssl.SSLContextImpl.getX509KeyManager:()Ljavax/net/ssl/X509ExtendedKeyManager;
            astore 3 /* km */
        start local 3 // javax.net.ssl.X509ExtendedKeyManager km
         1: .line 232
            aconst_null
            astore 4 /* serverAlias */
        start local 4 // java.lang.String serverAlias
         2: .line 233
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            instanceof sun.security.ssl.SSLSocketImpl
            ifeq 7
         3: .line 234
            aload 3 /* km */
            aload 2 /* keyType */
         4: .line 235
            aconst_null
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            checkcast javax.net.ssl.SSLSocket
         5: .line 234
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseServerAlias:(Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
            astore 4 /* serverAlias */
         6: .line 236
            goto 11
      StackMap locals: javax.net.ssl.X509ExtendedKeyManager java.lang.String
      StackMap stack:
         7: aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            instanceof sun.security.ssl.SSLEngineImpl
            ifeq 11
         8: .line 237
            aload 3 /* km */
            aload 2 /* keyType */
         9: .line 238
            aconst_null
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.conContext:Lsun/security/ssl/TransportContext;
            getfield sun.security.ssl.TransportContext.transport:Lsun/security/ssl/SSLTransport;
            checkcast javax.net.ssl.SSLEngine
        10: .line 237
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseEngineServerAlias:(Ljava/lang/String;[Ljava/security/Principal;Ljavax/net/ssl/SSLEngine;)Ljava/lang/String;
            astore 4 /* serverAlias */
        11: .line 241
      StackMap locals:
      StackMap stack:
            aload 4 /* serverAlias */
            ifnonnull 15
        12: .line 242
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 14
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 14
        13: .line 243
            new java.lang.StringBuilder
            dup
            ldc "No X.509 cert selected for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 2 /* keyType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        14: .line 245
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        15: .line 248
      StackMap locals:
      StackMap stack:
            aload 3 /* km */
            aload 4 /* serverAlias */
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.getPrivateKey:(Ljava/lang/String;)Ljava/security/PrivateKey;
            astore 5 /* serverPrivateKey */
        start local 5 // java.security.PrivateKey serverPrivateKey
        16: .line 249
            aload 5 /* serverPrivateKey */
            ifnonnull 21
        17: .line 250
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 20
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 20
        18: .line 252
            new java.lang.StringBuilder
            dup
            aload 4 /* serverAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " is not a private key entry"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        19: .line 251
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        20: .line 254
      StackMap locals: java.security.PrivateKey
      StackMap stack:
            aconst_null
            areturn
        21: .line 257
      StackMap locals:
      StackMap stack:
            aload 3 /* km */
            aload 4 /* serverAlias */
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.getCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 6 /* serverCerts */
        start local 6 // java.security.cert.X509Certificate[] serverCerts
        22: .line 258
            aload 6 /* serverCerts */
            ifnull 23
            aload 6 /* serverCerts */
            arraylength
            ifne 27
        23: .line 259
      StackMap locals: java.security.cert.X509Certificate[]
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 26
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 26
        24: .line 261
            new java.lang.StringBuilder
            dup
            aload 4 /* serverAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " is not a certificate entry"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        25: .line 260
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        26: .line 263
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        27: .line 266
      StackMap locals:
      StackMap stack:
            aload 6 /* serverCerts */
            iconst_0
            aaload
            invokevirtual java.security.cert.X509Certificate.getPublicKey:()Ljava/security/PublicKey;
            astore 7 /* serverPublicKey */
        start local 7 // java.security.PublicKey serverPublicKey
        28: .line 267
            aload 5 /* serverPrivateKey */
            invokeinterface java.security.PrivateKey.getAlgorithm:()Ljava/lang/String;
            aload 2 /* keyType */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 30
        29: .line 268
            aload 7 /* serverPublicKey */
            invokeinterface java.security.PublicKey.getAlgorithm:()Ljava/lang/String;
            aload 2 /* keyType */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 36
        30: .line 269
      StackMap locals: java.security.PublicKey
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 35
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 35
        31: .line 271
            new java.lang.StringBuilder
            dup
            aload 4 /* serverAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " private or public key is not of "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        32: .line 272
            aload 2 /* keyType */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " algorithm"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        33: .line 271
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        34: .line 270
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        35: .line 274
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        36: .line 280
      StackMap locals:
      StackMap stack:
            aload 2 /* keyType */
            ldc "EC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 56
        37: .line 281
            aload 7 /* serverPublicKey */
            instanceof java.security.interfaces.ECPublicKey
            ifne 43
        38: .line 282
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 42
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 42
        39: .line 283
            new java.lang.StringBuilder
            dup
            aload 4 /* serverAlias */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        40: .line 284
            ldc " public key is not an instance of ECPublicKey"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        41: .line 283
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
            invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
        42: .line 286
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        43: .line 293
      StackMap locals:
      StackMap stack:
            aload 7 /* serverPublicKey */
            checkcast java.security.interfaces.ECPublicKey
            invokeinterface java.security.interfaces.ECPublicKey.getParams:()Ljava/security/spec/ECParameterSpec;
        44: .line 292
            astore 8 /* params */
        start local 8 // java.security.spec.ECParameterSpec params
        45: .line 294
            aload 8 /* params */
            invokestatic sun.security.ssl.SupportedGroupsExtension$NamedGroup.valueOf:(Ljava/security/spec/ECParameterSpec;)Lsun/security/ssl/SupportedGroupsExtension$NamedGroup;
            astore 9 /* namedGroup */
        start local 9 // sun.security.ssl.SupportedGroupsExtension$NamedGroup namedGroup
        46: .line 295
            aload 9 /* namedGroup */
            ifnull 50
        47: .line 296
            aload 9 /* namedGroup */
            invokestatic sun.security.ssl.SupportedGroupsExtension$SupportedGroups.isSupported:(Lsun/security/ssl/SupportedGroupsExtension$NamedGroup;)Z
            ifeq 50
        48: .line 297
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.clientRequestedNamedGroups:Ljava/util/List;
            ifnull 56
        49: .line 298
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.clientRequestedNamedGroups:Ljava/util/List;
            aload 9 /* namedGroup */
            invokeinterface java.util.List.contains:(Ljava/lang/Object;)Z
            ifne 56
        50: .line 300
      StackMap locals: java.security.spec.ECParameterSpec sun.security.ssl.SupportedGroupsExtension$NamedGroup
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 55
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 55
        51: .line 302
            new java.lang.StringBuilder
            dup
            ldc "Unsupported named group ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* namedGroup */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        52: .line 303
            ldc ") used in the "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* serverAlias */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " certificate"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        53: .line 302
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        54: .line 301
            invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
        55: .line 306
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 9 // sun.security.ssl.SupportedGroupsExtension$NamedGroup namedGroup
        end local 8 // java.security.spec.ECParameterSpec params
        56: .line 310
      StackMap locals:
      StackMap stack:
            new sun.security.ssl.X509Authentication$X509Possession
            dup
            aload 5 /* serverPrivateKey */
            aload 6 /* serverCerts */
            invokespecial sun.security.ssl.X509Authentication$X509Possession.<init>:(Ljava/security/PrivateKey;[Ljava/security/cert/X509Certificate;)V
            areturn
        end local 7 // java.security.PublicKey serverPublicKey
        end local 6 // java.security.cert.X509Certificate[] serverCerts
        end local 5 // java.security.PrivateKey serverPrivateKey
        end local 4 // java.lang.String serverAlias
        end local 3 // javax.net.ssl.X509ExtendedKeyManager km
        end local 2 // java.lang.String keyType
        end local 1 // sun.security.ssl.ServerHandshakeContext shc
        end local 0 // sun.security.ssl.X509Authentication$X509PossessionGenerator this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   57     0              this  Lsun/security/ssl/X509Authentication$X509PossessionGenerator;
            0   57     1               shc  Lsun/security/ssl/ServerHandshakeContext;
            0   57     2           keyType  Ljava/lang/String;
            1   57     3                km  Ljavax/net/ssl/X509ExtendedKeyManager;
            2   57     4       serverAlias  Ljava/lang/String;
           16   57     5  serverPrivateKey  Ljava/security/PrivateKey;
           22   57     6       serverCerts  [Ljava/security/cert/X509Certificate;
           28   57     7   serverPublicKey  Ljava/security/PublicKey;
           45   56     8            params  Ljava/security/spec/ECParameterSpec;
           46   56     9        namedGroup  Lsun/security/ssl/SupportedGroupsExtension$NamedGroup;
    MethodParameters:
         Name  Flags
      shc      
      keyType  
}
SourceFile: "X509Authentication.java"
NestHost: sun.security.ssl.X509Authentication
InnerClasses:
  final NamedGroup = sun.security.ssl.SupportedGroupsExtension$NamedGroup of sun.security.ssl.SupportedGroupsExtension
  SupportedGroups = sun.security.ssl.SupportedGroupsExtension$SupportedGroups of sun.security.ssl.SupportedGroupsExtension
  final X509Possession = sun.security.ssl.X509Authentication$X509Possession of sun.security.ssl.X509Authentication
  private final X509PossessionGenerator = sun.security.ssl.X509Authentication$X509PossessionGenerator of sun.security.ssl.X509Authentication