class io.netty.handler.ssl.OpenSslKeyMaterialManager
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: io.netty.handler.ssl.OpenSslKeyMaterialManager
  super_class: java.lang.Object
{
  static final java.lang.String KEY_TYPE_RSA;
    descriptor: Ljava/lang/String;
    flags: (0x0018) ACC_STATIC, ACC_FINAL
    ConstantValue: "RSA"

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

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

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

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

  private static final java.util.Map<java.lang.String, java.lang.String> KEY_TYPES;
    descriptor: Ljava/util/Map;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/lang/String;>;

  private final javax.net.ssl.X509KeyManager keyManager;
    descriptor: Ljavax/net/ssl/X509KeyManager;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final java.lang.String password;
    descriptor: Ljava/lang/String;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 54
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
         1: .line 56
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "RSA"
            ldc "RSA"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 57
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "DHE_RSA"
            ldc "RSA"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 58
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "ECDHE_RSA"
            ldc "RSA"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 59
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "ECDHE_ECDSA"
            ldc "EC"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         5: .line 60
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "ECDH_RSA"
            ldc "EC_RSA"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         6: .line 61
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "ECDH_ECDSA"
            ldc "EC_EC"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 62
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            ldc "DH_RSA"
            ldc "DH_RSA"
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         8: .line 63
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(javax.net.ssl.X509KeyManager, java.lang.String);
    descriptor: (Ljavax/net/ssl/X509KeyManager;Ljava/lang/String;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
        start local 1 // javax.net.ssl.X509KeyManager keyManager
        start local 2 // java.lang.String password
         0: .line 68
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 69
            aload 0 /* this */
            aload 1 /* keyManager */
            putfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
         2: .line 70
            aload 0 /* this */
            aload 2 /* password */
            putfield io.netty.handler.ssl.OpenSslKeyMaterialManager.password:Ljava/lang/String;
         3: .line 71
            return
        end local 2 // java.lang.String password
        end local 1 // javax.net.ssl.X509KeyManager keyManager
        end local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    4     0        this  Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            0    4     1  keyManager  Ljavax/net/ssl/X509KeyManager;
            0    4     2    password  Ljava/lang/String;
    MethodParameters:
            Name  Flags
      keyManager  
      password    

  void setKeyMaterial(io.netty.handler.ssl.ReferenceCountedOpenSslEngine);
    descriptor: (Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;)V
    flags: (0x0000) 
    Code:
      stack=4, locals=12, args_size=2
        start local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
        start local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
         0: .line 74
            aload 1 /* engine */
            invokevirtual io.netty.handler.ssl.ReferenceCountedOpenSslEngine.sslPointer:()J
            lstore 2 /* ssl */
        start local 2 // long ssl
         1: .line 75
            lload 2 /* ssl */
            invokestatic io.netty.internal.tcnative.SSL.authenticationMethods:(J)[Ljava/lang/String;
            astore 4 /* authMethods */
        start local 4 // java.lang.String[] authMethods
         2: .line 76
            new java.util.HashSet
            dup
            aload 4 /* authMethods */
            arraylength
            invokespecial java.util.HashSet.<init>:(I)V
            astore 5 /* aliases */
        start local 5 // java.util.Set aliases
         3: .line 77
            aload 4 /* authMethods */
            dup
            astore 9
            arraylength
            istore 8
            iconst_0
            istore 7
            goto 11
      StackMap locals: io.netty.handler.ssl.OpenSslKeyMaterialManager io.netty.handler.ssl.ReferenceCountedOpenSslEngine long java.lang.String[] java.util.Set top int int java.lang.String[]
      StackMap stack:
         4: aload 9
            iload 7
            aaload
            astore 6 /* authMethod */
        start local 6 // java.lang.String authMethod
         5: .line 78
            getstatic io.netty.handler.ssl.OpenSslKeyMaterialManager.KEY_TYPES:Ljava/util/Map;
            aload 6 /* authMethod */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 10 /* type */
        start local 10 // java.lang.String type
         6: .line 79
            aload 10 /* type */
            ifnull 10
         7: .line 80
            aload 0 /* this */
            aload 1 /* engine */
            aload 10 /* type */
            invokevirtual io.netty.handler.ssl.OpenSslKeyMaterialManager.chooseServerAlias:(Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;Ljava/lang/String;)Ljava/lang/String;
            astore 11 /* alias */
        start local 11 // java.lang.String alias
         8: .line 81
            aload 11 /* alias */
            ifnull 10
            aload 5 /* aliases */
            aload 11 /* alias */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            ifeq 10
         9: .line 82
            aload 0 /* this */
            lload 2 /* ssl */
            aload 11 /* alias */
            invokevirtual io.netty.handler.ssl.OpenSslKeyMaterialManager.setKeyMaterial:(JLjava/lang/String;)V
        end local 11 // java.lang.String alias
        end local 10 // java.lang.String type
        end local 6 // java.lang.String authMethod
        10: .line 77
      StackMap locals:
      StackMap stack:
            iinc 7 1
      StackMap locals:
      StackMap stack:
        11: iload 7
            iload 8
            if_icmplt 4
        12: .line 86
            return
        end local 5 // java.util.Set aliases
        end local 4 // java.lang.String[] authMethods
        end local 2 // long ssl
        end local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        end local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   13     0         this  Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            0   13     1       engine  Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;
            1   13     2          ssl  J
            2   13     4  authMethods  [Ljava/lang/String;
            3   13     5      aliases  Ljava/util/Set<Ljava/lang/String;>;
            5   10     6   authMethod  Ljava/lang/String;
            6   10    10         type  Ljava/lang/String;
            8   10    11        alias  Ljava/lang/String;
    Exceptions:
      throws javax.net.ssl.SSLException
    MethodParameters:
        Name  Flags
      engine  

  io.netty.internal.tcnative.CertificateRequestedCallback$KeyMaterial keyMaterial(io.netty.handler.ssl.ReferenceCountedOpenSslEngine, java.lang.String[], javax.security.auth.x500.X500Principal[]);
    descriptor: (Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;[Ljava/lang/String;[Ljavax/security/auth/x500/X500Principal;)Lio/netty/internal/tcnative/CertificateRequestedCallback$KeyMaterial;
    flags: (0x0000) 
    Code:
      stack=6, locals=18, args_size=4
        start local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
        start local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        start local 2 // java.lang.String[] keyTypes
        start local 3 // javax.security.auth.x500.X500Principal[] issuer
         0: .line 90
            aload 0 /* this */
            aload 1 /* engine */
            aload 2 /* keyTypes */
            aload 3 /* issuer */
            invokevirtual io.netty.handler.ssl.OpenSslKeyMaterialManager.chooseClientAlias:(Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;[Ljava/lang/String;[Ljavax/security/auth/x500/X500Principal;)Ljava/lang/String;
            astore 4 /* alias */
        start local 4 // java.lang.String alias
         1: .line 91
            lconst_0
            lstore 5 /* keyBio */
        start local 5 // long keyBio
         2: .line 92
            lconst_0
            lstore 7 /* keyCertChainBio */
        start local 7 // long keyCertChainBio
         3: .line 93
            lconst_0
            lstore 9 /* pkey */
        start local 9 // long pkey
         4: .line 94
            lconst_0
            lstore 11 /* certChain */
        start local 11 // long certChain
         5: .line 98
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
            aload 4 /* alias */
            invokeinterface javax.net.ssl.X509KeyManager.getCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 13 /* certificates */
        start local 13 // java.security.cert.X509Certificate[] certificates
         6: .line 99
            aload 13 /* certificates */
            ifnull 7
            aload 13 /* certificates */
            arraylength
            ifne 12
         7: .line 123
      StackMap locals: io.netty.handler.ssl.OpenSslKeyMaterialManager io.netty.handler.ssl.ReferenceCountedOpenSslEngine java.lang.String[] javax.security.auth.x500.X500Principal[] java.lang.String long long long long java.security.cert.X509Certificate[]
      StackMap stack:
            lload 5 /* keyBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
         8: .line 124
            lload 7 /* keyCertChainBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
         9: .line 125
            lload 9 /* pkey */
            invokestatic io.netty.internal.tcnative.SSL.freePrivateKey:(J)V
        10: .line 126
            lload 11 /* certChain */
            invokestatic io.netty.internal.tcnative.SSL.freeX509Chain:(J)V
        11: .line 100
            aconst_null
            areturn
        12: .line 103
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
            aload 4 /* alias */
            invokeinterface javax.net.ssl.X509KeyManager.getPrivateKey:(Ljava/lang/String;)Ljava/security/PrivateKey;
            astore 14 /* key */
        start local 14 // java.security.PrivateKey key
        13: .line 104
            aload 13 /* certificates */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.toBIO:([Ljava/security/cert/X509Certificate;)J
            lstore 7 /* keyCertChainBio */
        14: .line 105
            lload 7 /* keyCertChainBio */
            invokestatic io.netty.internal.tcnative.SSL.parseX509Chain:(J)J
            lstore 11 /* certChain */
        15: .line 106
            aload 14 /* key */
            ifnull 18
        16: .line 107
            aload 14 /* key */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.toBIO:(Ljava/security/PrivateKey;)J
            lstore 5 /* keyBio */
        17: .line 108
            lload 5 /* keyBio */
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.password:Ljava/lang/String;
            invokestatic io.netty.internal.tcnative.SSL.parsePrivateKey:(JLjava/lang/String;)J
            lstore 9 /* pkey */
        18: .line 110
      StackMap locals: java.security.PrivateKey
      StackMap stack:
            new io.netty.internal.tcnative.CertificateRequestedCallback$KeyMaterial
            dup
        19: .line 111
            lload 11 /* certChain */
            lload 9 /* pkey */
        20: .line 110
            invokespecial io.netty.internal.tcnative.CertificateRequestedCallback$KeyMaterial.<init>:(JJ)V
            astore 15 /* material */
        start local 15 // io.netty.internal.tcnative.CertificateRequestedCallback$KeyMaterial material
        21: .line 116
            lconst_0
            dup2
            lstore 9 /* pkey */
            lstore 11 /* certChain */
        22: .line 117
            aload 15 /* material */
            astore 17
        23: .line 123
            lload 5 /* keyBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        24: .line 124
            lload 7 /* keyCertChainBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        25: .line 125
            lload 9 /* pkey */
            invokestatic io.netty.internal.tcnative.SSL.freePrivateKey:(J)V
        26: .line 126
            lload 11 /* certChain */
            invokestatic io.netty.internal.tcnative.SSL.freeX509Chain:(J)V
        27: .line 117
            aload 17
            areturn
        end local 15 // io.netty.internal.tcnative.CertificateRequestedCallback$KeyMaterial material
        end local 14 // java.security.PrivateKey key
        end local 13 // java.security.cert.X509Certificate[] certificates
        28: .line 118
      StackMap locals: io.netty.handler.ssl.OpenSslKeyMaterialManager io.netty.handler.ssl.ReferenceCountedOpenSslEngine java.lang.String[] javax.security.auth.x500.X500Principal[] java.lang.String long long long long
      StackMap stack: javax.net.ssl.SSLException
            astore 13 /* e */
        start local 13 // javax.net.ssl.SSLException e
        29: .line 119
            aload 13 /* e */
            athrow
        end local 13 // javax.net.ssl.SSLException e
        30: .line 120
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 13 /* e */
        start local 13 // java.lang.Exception e
        31: .line 121
            new javax.net.ssl.SSLException
            dup
            aload 13 /* e */
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 13 // java.lang.Exception e
        32: .line 122
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 16
        33: .line 123
            lload 5 /* keyBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        34: .line 124
            lload 7 /* keyCertChainBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        35: .line 125
            lload 9 /* pkey */
            invokestatic io.netty.internal.tcnative.SSL.freePrivateKey:(J)V
        36: .line 126
            lload 11 /* certChain */
            invokestatic io.netty.internal.tcnative.SSL.freeX509Chain:(J)V
        37: .line 127
            aload 16
            athrow
        end local 11 // long certChain
        end local 9 // long pkey
        end local 7 // long keyCertChainBio
        end local 5 // long keyBio
        end local 4 // java.lang.String alias
        end local 3 // javax.security.auth.x500.X500Principal[] issuer
        end local 2 // java.lang.String[] keyTypes
        end local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        end local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   38     0             this  Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            0   38     1           engine  Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;
            0   38     2         keyTypes  [Ljava/lang/String;
            0   38     3           issuer  [Ljavax/security/auth/x500/X500Principal;
            1   38     4            alias  Ljava/lang/String;
            2   38     5           keyBio  J
            3   38     7  keyCertChainBio  J
            4   38     9             pkey  J
            5   38    11        certChain  J
            6   28    13     certificates  [Ljava/security/cert/X509Certificate;
           13   28    14              key  Ljava/security/PrivateKey;
           21   28    15         material  Lio/netty/internal/tcnative/CertificateRequestedCallback$KeyMaterial;
           29   30    13                e  Ljavax/net/ssl/SSLException;
           31   32    13                e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           5     7      28  Class javax.net.ssl.SSLException
          12    23      28  Class javax.net.ssl.SSLException
           5     7      30  Class java.lang.Exception
          12    23      30  Class java.lang.Exception
           5     7      32  any
          12    23      32  any
          28    32      32  any
    Exceptions:
      throws javax.net.ssl.SSLException
    MethodParameters:
          Name  Flags
      engine    
      keyTypes  
      issuer    

  private void setKeyMaterial(long, java.lang.String);
    descriptor: (JLjava/lang/String;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=15, args_size=3
        start local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
        start local 1 // long ssl
        start local 3 // java.lang.String alias
         0: .line 131
            lconst_0
            lstore 4 /* keyBio */
        start local 4 // long keyBio
         1: .line 132
            lconst_0
            lstore 6 /* keyCertChainBio */
        start local 6 // long keyCertChainBio
         2: .line 133
            lconst_0
            lstore 8 /* keyCertChainBio2 */
        start local 8 // long keyCertChainBio2
         3: .line 137
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
            aload 3 /* alias */
            invokeinterface javax.net.ssl.X509KeyManager.getCertificateChain:(Ljava/lang/String;)[Ljava/security/cert/X509Certificate;
            astore 10 /* certificates */
        start local 10 // java.security.cert.X509Certificate[] certificates
         4: .line 138
            aload 10 /* certificates */
            ifnull 5
            aload 10 /* certificates */
            arraylength
            ifne 9
         5: .line 165
      StackMap locals: io.netty.handler.ssl.OpenSslKeyMaterialManager long java.lang.String long long long java.security.cert.X509Certificate[]
      StackMap stack:
            lload 4 /* keyBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
         6: .line 166
            lload 6 /* keyCertChainBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
         7: .line 167
            lload 8 /* keyCertChainBio2 */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
         8: .line 139
            return
         9: .line 142
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
            aload 3 /* alias */
            invokeinterface javax.net.ssl.X509KeyManager.getPrivateKey:(Ljava/lang/String;)Ljava/security/PrivateKey;
            astore 11 /* key */
        start local 11 // java.security.PrivateKey key
        10: .line 145
            getstatic io.netty.buffer.ByteBufAllocator.DEFAULT:Lio/netty/buffer/ByteBufAllocator;
            iconst_1
            aload 10 /* certificates */
            invokestatic io.netty.handler.ssl.PemX509Certificate.toPEM:(Lio/netty/buffer/ByteBufAllocator;Z[Ljava/security/cert/X509Certificate;)Lio/netty/handler/ssl/PemEncoded;
            astore 12 /* encoded */
        start local 12 // io.netty.handler.ssl.PemEncoded encoded
        11: .line 147
            getstatic io.netty.buffer.ByteBufAllocator.DEFAULT:Lio/netty/buffer/ByteBufAllocator;
            aload 12 /* encoded */
            invokeinterface io.netty.handler.ssl.PemEncoded.retain:()Lio/netty/handler/ssl/PemEncoded;
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.toBIO:(Lio/netty/buffer/ByteBufAllocator;Lio/netty/handler/ssl/PemEncoded;)J
            lstore 6 /* keyCertChainBio */
        12: .line 148
            getstatic io.netty.buffer.ByteBufAllocator.DEFAULT:Lio/netty/buffer/ByteBufAllocator;
            aload 12 /* encoded */
            invokeinterface io.netty.handler.ssl.PemEncoded.retain:()Lio/netty/handler/ssl/PemEncoded;
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.toBIO:(Lio/netty/buffer/ByteBufAllocator;Lio/netty/handler/ssl/PemEncoded;)J
            lstore 8 /* keyCertChainBio2 */
        13: .line 150
            aload 11 /* key */
            ifnull 15
        14: .line 151
            aload 11 /* key */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.toBIO:(Ljava/security/PrivateKey;)J
            lstore 4 /* keyBio */
        15: .line 153
      StackMap locals: java.security.PrivateKey io.netty.handler.ssl.PemEncoded
      StackMap stack:
            lload 1 /* ssl */
            lload 6 /* keyCertChainBio */
            lload 4 /* keyBio */
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.password:Ljava/lang/String;
            invokestatic io.netty.internal.tcnative.SSL.setCertificateBio:(JJJLjava/lang/String;)V
        16: .line 156
            lload 1 /* ssl */
            lload 8 /* keyCertChainBio2 */
            iconst_1
            invokestatic io.netty.internal.tcnative.SSL.setCertificateChainBio:(JJZ)V
        17: .line 157
            goto 21
      StackMap locals:
      StackMap stack: java.lang.Throwable
        18: astore 13
        19: .line 158
            aload 12 /* encoded */
            invokeinterface io.netty.handler.ssl.PemEncoded.release:()Z
            pop
        20: .line 159
            aload 13
            athrow
        21: .line 158
      StackMap locals:
      StackMap stack:
            aload 12 /* encoded */
            invokeinterface io.netty.handler.ssl.PemEncoded.release:()Z
            pop
        end local 12 // io.netty.handler.ssl.PemEncoded encoded
        end local 11 // java.security.PrivateKey key
        end local 10 // java.security.cert.X509Certificate[] certificates
        22: .line 160
            goto 32
      StackMap locals: io.netty.handler.ssl.OpenSslKeyMaterialManager long java.lang.String long long long
      StackMap stack: javax.net.ssl.SSLException
        23: astore 10 /* e */
        start local 10 // javax.net.ssl.SSLException e
        24: .line 161
            aload 10 /* e */
            athrow
        end local 10 // javax.net.ssl.SSLException e
        25: .line 162
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 10 /* e */
        start local 10 // java.lang.Exception e
        26: .line 163
            new javax.net.ssl.SSLException
            dup
            aload 10 /* e */
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/Throwable;)V
            athrow
        end local 10 // java.lang.Exception e
        27: .line 164
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 14
        28: .line 165
            lload 4 /* keyBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        29: .line 166
            lload 6 /* keyCertChainBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        30: .line 167
            lload 8 /* keyCertChainBio2 */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        31: .line 168
            aload 14
            athrow
        32: .line 165
      StackMap locals:
      StackMap stack:
            lload 4 /* keyBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        33: .line 166
            lload 6 /* keyCertChainBio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        34: .line 167
            lload 8 /* keyCertChainBio2 */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.freeBio:(J)V
        35: .line 169
            return
        end local 8 // long keyCertChainBio2
        end local 6 // long keyCertChainBio
        end local 4 // long keyBio
        end local 3 // java.lang.String alias
        end local 1 // long ssl
        end local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   36     0              this  Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            0   36     1               ssl  J
            0   36     3             alias  Ljava/lang/String;
            1   36     4            keyBio  J
            2   36     6   keyCertChainBio  J
            3   36     8  keyCertChainBio2  J
            4   22    10      certificates  [Ljava/security/cert/X509Certificate;
           10   22    11               key  Ljava/security/PrivateKey;
           11   22    12           encoded  Lio/netty/handler/ssl/PemEncoded;
           24   25    10                 e  Ljavax/net/ssl/SSLException;
           26   27    10                 e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          11    18      18  any
           3     5      23  Class javax.net.ssl.SSLException
           9    22      23  Class javax.net.ssl.SSLException
           3     5      25  Class java.lang.Exception
           9    22      25  Class java.lang.Exception
           3     5      27  any
           9    27      27  any
    Exceptions:
      throws javax.net.ssl.SSLException
    MethodParameters:
       Name  Flags
      ssl    
      alias  

  protected java.lang.String chooseClientAlias(io.netty.handler.ssl.ReferenceCountedOpenSslEngine, java.lang.String[], javax.security.auth.x500.X500Principal[]);
    descriptor: (Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;[Ljava/lang/String;[Ljavax/security/auth/x500/X500Principal;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
        start local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        start local 2 // java.lang.String[] keyTypes
        start local 3 // javax.security.auth.x500.X500Principal[] issuer
         0: .line 173
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
            aload 2 /* keyTypes */
            aload 3 /* issuer */
            aconst_null
            invokeinterface javax.net.ssl.X509KeyManager.chooseClientAlias:([Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
            areturn
        end local 3 // javax.security.auth.x500.X500Principal[] issuer
        end local 2 // java.lang.String[] keyTypes
        end local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        end local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            0    1     1    engine  Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;
            0    1     2  keyTypes  [Ljava/lang/String;
            0    1     3    issuer  [Ljavax/security/auth/x500/X500Principal;
    MethodParameters:
          Name  Flags
      engine    
      keyTypes  
      issuer    

  protected java.lang.String chooseServerAlias(io.netty.handler.ssl.ReferenceCountedOpenSslEngine, java.lang.String);
    descriptor: (Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
        start local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        start local 2 // java.lang.String type
         0: .line 177
            aload 0 /* this */
            getfield io.netty.handler.ssl.OpenSslKeyMaterialManager.keyManager:Ljavax/net/ssl/X509KeyManager;
            aload 2 /* type */
            aconst_null
            aconst_null
            invokeinterface javax.net.ssl.X509KeyManager.chooseServerAlias:(Ljava/lang/String;[Ljava/security/Principal;Ljava/net/Socket;)Ljava/lang/String;
            areturn
        end local 2 // java.lang.String type
        end local 1 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        end local 0 // io.netty.handler.ssl.OpenSslKeyMaterialManager this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    1     0    this  Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            0    1     1  engine  Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;
            0    1     2    type  Ljava/lang/String;
    MethodParameters:
        Name  Flags
      engine  
      type    
}
SourceFile: "OpenSslKeyMaterialManager.java"
InnerClasses:
  public KeyMaterial = io.netty.internal.tcnative.CertificateRequestedCallback$KeyMaterial of io.netty.internal.tcnative.CertificateRequestedCallback