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 167
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 168
            aload 0 /* this */
            aload 1 /* keyTypes */
            putfield sun.security.ssl.X509Authentication$X509PossessionGenerator.keyTypes:[Ljava/lang/String;
         2: .line 169
            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 173
            aload 1 /* context */
            getfield sun.security.ssl.HandshakeContext.sslConfig:Lsun/security/ssl/SSLConfiguration;
            getfield sun.security.ssl.SSLConfiguration.isClientMode:Z
            ifeq 11
         1: .line 174
            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 175
            aload 0 /* this */
         4: .line 176
            aload 1 /* context */
            checkcast sun.security.ssl.ClientHandshakeContext
            aload 2 /* keyType */
         5: .line 175
            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 177
            aload 6 /* poss */
            ifnull 8
         7: .line 178
            aload 6 /* poss */
            areturn
        end local 6 // sun.security.ssl.SSLPossession poss
        end local 2 // java.lang.String keyType
         8: .line 174
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
         9: iload 3
            iload 4
            if_icmplt 2
        10: .line 181
            goto 20
        11: .line 182
      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 183
            aload 0 /* this */
        14: .line 184
            aload 1 /* context */
            checkcast sun.security.ssl.ServerHandshakeContext
            aload 2 /* keyType */
        15: .line 183
            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 185
            aload 6 /* poss */
            ifnull 18
        17: .line 186
            aload 6 /* poss */
            areturn
        end local 6 // sun.security.ssl.SSLPossession poss
        end local 2 // java.lang.String keyType
        18: .line 182
      StackMap locals:
      StackMap stack:
            iinc 3 1
      StackMap locals:
      StackMap stack:
        19: iload 3
            iload 4
            if_icmplt 12
        20: .line 191
      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 197
            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 198
            aconst_null
            astore 4 /* clientAlias */
        start local 4 // java.lang.String clientAlias
         2: .line 199
            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 200
            aload 3 /* km */
         4: .line 201
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 2 /* keyType */
            aastore
         5: .line 202
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.peerSupportedAuthorities:[Ljavax/security/auth/x500/X500Principal;
         6: .line 203
            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 200
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseClientAlias:([Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
            astore 4 /* clientAlias */
         8: .line 204
            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 205
            aload 3 /* km */
        11: .line 206
            iconst_1
            anewarray java.lang.String
            dup
            iconst_0
            aload 2 /* keyType */
            aastore
        12: .line 207
            aload 1 /* chc */
            getfield sun.security.ssl.ClientHandshakeContext.peerSupportedAuthorities:[Ljavax/security/auth/x500/X500Principal;
        13: .line 208
            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 205
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseEngineClientAlias:([Ljava/lang/String;[Ljava/security/Principal;Ljavax/net/ssl/SSLEngine;)Ljava/lang/String;
            astore 4 /* clientAlias */
        15: .line 211
      StackMap locals:
      StackMap stack:
            aload 4 /* clientAlias */
            ifnonnull 19
        16: .line 212
            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 213
            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 215
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        19: .line 218
      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 219
            aload 5 /* clientPrivateKey */
            ifnonnull 25
        21: .line 220
            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 222
            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 221
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        24: .line 224
      StackMap locals: java.security.PrivateKey
      StackMap stack:
            aconst_null
            areturn
        25: .line 227
      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 228
            aload 6 /* clientCerts */
            ifnull 27
            aload 6 /* clientCerts */
            arraylength
            ifne 32
        27: .line 229
      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 230
            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 231
            ldc " is a private key entry with no cert chain stored"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        30: .line 230
            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 233
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        32: .line 236
      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 237
            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 238
            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 239
      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 241
            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 242
            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 241
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        39: .line 240
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        40: .line 244
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        41: .line 247
      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 252
            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 253
            aconst_null
            astore 4 /* serverAlias */
        start local 4 // java.lang.String serverAlias
         2: .line 254
            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 255
            aload 3 /* km */
            aload 2 /* keyType */
         4: .line 256
            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 255
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseServerAlias:(Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
            astore 4 /* serverAlias */
         6: .line 257
            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 258
            aload 3 /* km */
            aload 2 /* keyType */
         9: .line 259
            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 258
            invokevirtual javax.net.ssl.X509ExtendedKeyManager.chooseEngineServerAlias:(Ljava/lang/String;[Ljava/security/Principal;Ljavax/net/ssl/SSLEngine;)Ljava/lang/String;
            astore 4 /* serverAlias */
        11: .line 262
      StackMap locals:
      StackMap stack:
            aload 4 /* serverAlias */
            ifnonnull 15
        12: .line 263
            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 264
            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 266
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        15: .line 269
      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 270
            aload 5 /* serverPrivateKey */
            ifnonnull 21
        17: .line 271
            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 273
            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 272
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        20: .line 275
      StackMap locals: java.security.PrivateKey
      StackMap stack:
            aconst_null
            areturn
        21: .line 278
      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 279
            aload 6 /* serverCerts */
            ifnull 23
            aload 6 /* serverCerts */
            arraylength
            ifne 27
        23: .line 280
      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 282
            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 281
            invokestatic sun.security.ssl.SSLLogger.finest:(Ljava/lang/String;[Ljava/lang/Object;)V
        26: .line 284
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        27: .line 287
      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 288
            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 289
            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 290
      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 292
            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 293
            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 292
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        34: .line 291
            invokestatic sun.security.ssl.SSLLogger.fine:(Ljava/lang/String;[Ljava/lang/Object;)V
        35: .line 295
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        36: .line 302
      StackMap locals:
      StackMap stack:
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.negotiatedProtocol:Lsun/security/ssl/ProtocolVersion;
            invokevirtual sun.security.ssl.ProtocolVersion.useTLS13PlusSpec:()Z
            ifne 57
        37: .line 303
            aload 2 /* keyType */
            ldc "EC"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 57
        38: .line 304
            aload 7 /* serverPublicKey */
            instanceof java.security.interfaces.ECPublicKey
            ifne 44
        39: .line 305
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 43
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 43
        40: .line 306
            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
        41: .line 307
            ldc " public key is not an instance of ECPublicKey"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        42: .line 306
            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
        43: .line 309
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        44: .line 317
      StackMap locals:
      StackMap stack:
            aload 7 /* serverPublicKey */
            checkcast java.security.interfaces.ECPublicKey
            invokeinterface java.security.interfaces.ECPublicKey.getParams:()Ljava/security/spec/ECParameterSpec;
        45: .line 316
            astore 8 /* params */
        start local 8 // java.security.spec.ECParameterSpec params
        46: .line 318
            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
        47: .line 319
            aload 9 /* namedGroup */
            ifnull 51
        48: .line 320
            aload 9 /* namedGroup */
            invokestatic sun.security.ssl.SupportedGroupsExtension$SupportedGroups.isSupported:(Lsun/security/ssl/SupportedGroupsExtension$NamedGroup;)Z
            ifeq 51
        49: .line 321
            aload 1 /* shc */
            getfield sun.security.ssl.ServerHandshakeContext.clientRequestedNamedGroups:Ljava/util/List;
            ifnull 57
        50: .line 322
            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 57
        51: .line 324
      StackMap locals: java.security.spec.ECParameterSpec sun.security.ssl.SupportedGroupsExtension$NamedGroup
      StackMap stack:
            getstatic sun.security.ssl.SSLLogger.isOn:Z
            ifeq 56
            ldc "ssl"
            invokestatic sun.security.ssl.SSLLogger.isOn:(Ljava/lang/String;)Z
            ifeq 56
        52: .line 326
            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;
        53: .line 327
            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;
        54: .line 326
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            iconst_0
            anewarray java.lang.Object
        55: .line 325
            invokestatic sun.security.ssl.SSLLogger.warning:(Ljava/lang/String;[Ljava/lang/Object;)V
        56: .line 330
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 9 // sun.security.ssl.SupportedGroupsExtension$NamedGroup namedGroup
        end local 8 // java.security.spec.ECParameterSpec params
        57: .line 334
      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   58     0              this  Lsun/security/ssl/X509Authentication$X509PossessionGenerator;
            0   58     1               shc  Lsun/security/ssl/ServerHandshakeContext;
            0   58     2           keyType  Ljava/lang/String;
            1   58     3                km  Ljavax/net/ssl/X509ExtendedKeyManager;
            2   58     4       serverAlias  Ljava/lang/String;
           16   58     5  serverPrivateKey  Ljava/security/PrivateKey;
           22   58     6       serverCerts  [Ljava/security/cert/X509Certificate;
           28   58     7   serverPublicKey  Ljava/security/PublicKey;
           46   57     8            params  Ljava/security/spec/ECParameterSpec;
           47   57     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