public final class io.netty.handler.ssl.ReferenceCountedOpenSslServerContext extends io.netty.handler.ssl.ReferenceCountedOpenSslContext
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext
  super_class: io.netty.handler.ssl.ReferenceCountedOpenSslContext
{
  private static final io.netty.util.internal.logging.InternalLogger logger;
    descriptor: Lio/netty/util/internal/logging/InternalLogger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final byte[] ID;
    descriptor: [B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final io.netty.handler.ssl.OpenSslServerSessionContext sessionContext;
    descriptor: Lio/netty/handler/ssl/OpenSslServerSessionContext;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final io.netty.handler.ssl.OpenSslKeyMaterialManager keyMaterialManager;
    descriptor: Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 48
            ldc Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext;
            invokestatic io.netty.util.internal.logging.InternalLoggerFactory.getInstance:(Ljava/lang/Class;)Lio/netty/util/internal/logging/InternalLogger;
         1: .line 47
            putstatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.logger:Lio/netty/util/internal/logging/InternalLogger;
         2: .line 49
            iconst_5
            newarray 8
            dup
            iconst_0
            bipush 110
            bastore
            dup
            iconst_1
            bipush 101
            bastore
            dup
            iconst_2
            bipush 116
            bastore
            dup
            iconst_3
            bipush 116
            bastore
            dup
            iconst_4
            bipush 121
            bastore
            putstatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.ID:[B
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.security.cert.X509Certificate[], javax.net.ssl.TrustManagerFactory, java.security.cert.X509Certificate[], java.security.PrivateKey, java.lang.String, javax.net.ssl.KeyManagerFactory, java.lang.Iterable<java.lang.String>, io.netty.handler.ssl.CipherSuiteFilter, io.netty.handler.ssl.ApplicationProtocolConfig, long, long, io.netty.handler.ssl.ClientAuth, java.lang.String[], boolean, );
    descriptor: ([Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;Ljava/lang/Iterable;Lio/netty/handler/ssl/CipherSuiteFilter;Lio/netty/handler/ssl/ApplicationProtocolConfig;JJLio/netty/handler/ssl/ClientAuth;[Ljava/lang/String;ZZ)V
    flags: (0x0000) 
    Code:
      stack=18, locals=18, args_size=16
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
        start local 1 // java.security.cert.X509Certificate[] trustCertCollection
        start local 2 // javax.net.ssl.TrustManagerFactory trustManagerFactory
        start local 3 // java.security.cert.X509Certificate[] keyCertChain
        start local 4 // java.security.PrivateKey key
        start local 5 // java.lang.String keyPassword
        start local 6 // javax.net.ssl.KeyManagerFactory keyManagerFactory
        start local 7 // java.lang.Iterable ciphers
        start local 8 // io.netty.handler.ssl.CipherSuiteFilter cipherFilter
        start local 9 // io.netty.handler.ssl.ApplicationProtocolConfig apn
        start local 10 // long sessionCacheSize
        start local 12 // long sessionTimeout
        start local 14 // io.netty.handler.ssl.ClientAuth clientAuth
        start local 15 // java.lang.String[] protocols
        start local 16 // boolean startTls
        start local 17 // boolean enableOcsp
         0: .line 59
            aload 0 /* this */
            aload 1 /* trustCertCollection */
            aload 2 /* trustManagerFactory */
            aload 3 /* keyCertChain */
            aload 4 /* key */
            aload 5 /* keyPassword */
            aload 6 /* keyManagerFactory */
            aload 7 /* ciphers */
         1: .line 60
            aload 8 /* cipherFilter */
            aload 9 /* apn */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.toNegotiator:(Lio/netty/handler/ssl/ApplicationProtocolConfig;)Lio/netty/handler/ssl/OpenSslApplicationProtocolNegotiator;
            lload 10 /* sessionCacheSize */
            lload 12 /* sessionTimeout */
            aload 14 /* clientAuth */
            aload 15 /* protocols */
            iload 16 /* startTls */
         2: .line 61
            iload 17 /* enableOcsp */
            invokespecial io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.<init>:([Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;Ljava/lang/Iterable;Lio/netty/handler/ssl/CipherSuiteFilter;Lio/netty/handler/ssl/OpenSslApplicationProtocolNegotiator;JJLio/netty/handler/ssl/ClientAuth;[Ljava/lang/String;ZZ)V
         3: .line 62
            return
        end local 17 // boolean enableOcsp
        end local 16 // boolean startTls
        end local 15 // java.lang.String[] protocols
        end local 14 // io.netty.handler.ssl.ClientAuth clientAuth
        end local 12 // long sessionTimeout
        end local 10 // long sessionCacheSize
        end local 9 // io.netty.handler.ssl.ApplicationProtocolConfig apn
        end local 8 // io.netty.handler.ssl.CipherSuiteFilter cipherFilter
        end local 7 // java.lang.Iterable ciphers
        end local 6 // javax.net.ssl.KeyManagerFactory keyManagerFactory
        end local 5 // java.lang.String keyPassword
        end local 4 // java.security.PrivateKey key
        end local 3 // java.security.cert.X509Certificate[] keyCertChain
        end local 2 // javax.net.ssl.TrustManagerFactory trustManagerFactory
        end local 1 // java.security.cert.X509Certificate[] trustCertCollection
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    4     0                 this  Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext;
            0    4     1  trustCertCollection  [Ljava/security/cert/X509Certificate;
            0    4     2  trustManagerFactory  Ljavax/net/ssl/TrustManagerFactory;
            0    4     3         keyCertChain  [Ljava/security/cert/X509Certificate;
            0    4     4                  key  Ljava/security/PrivateKey;
            0    4     5          keyPassword  Ljava/lang/String;
            0    4     6    keyManagerFactory  Ljavax/net/ssl/KeyManagerFactory;
            0    4     7              ciphers  Ljava/lang/Iterable<Ljava/lang/String;>;
            0    4     8         cipherFilter  Lio/netty/handler/ssl/CipherSuiteFilter;
            0    4     9                  apn  Lio/netty/handler/ssl/ApplicationProtocolConfig;
            0    4    10     sessionCacheSize  J
            0    4    12       sessionTimeout  J
            0    4    14           clientAuth  Lio/netty/handler/ssl/ClientAuth;
            0    4    15            protocols  [Ljava/lang/String;
            0    4    16             startTls  Z
            0    4    17           enableOcsp  Z
    Exceptions:
      throws javax.net.ssl.SSLException
    Signature: ([Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;Ljava/lang/Iterable<Ljava/lang/String;>;Lio/netty/handler/ssl/CipherSuiteFilter;Lio/netty/handler/ssl/ApplicationProtocolConfig;JJLio/netty/handler/ssl/ClientAuth;[Ljava/lang/String;ZZ)V
    MethodParameters:
                     Name  Flags
      trustCertCollection  
      trustManagerFactory  
      keyCertChain         
      key                  
      keyPassword          
      keyManagerFactory    
      ciphers              
      cipherFilter         
      apn                  
      sessionCacheSize     
      sessionTimeout       
      clientAuth           
      protocols            
      startTls             
      enableOcsp           

  private void <init>(java.security.cert.X509Certificate[], javax.net.ssl.TrustManagerFactory, java.security.cert.X509Certificate[], java.security.PrivateKey, java.lang.String, javax.net.ssl.KeyManagerFactory, java.lang.Iterable<java.lang.String>, io.netty.handler.ssl.CipherSuiteFilter, io.netty.handler.ssl.OpenSslApplicationProtocolNegotiator, long, long, io.netty.handler.ssl.ClientAuth, java.lang.String[], boolean, );
    descriptor: ([Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;Ljava/lang/Iterable;Lio/netty/handler/ssl/CipherSuiteFilter;Lio/netty/handler/ssl/OpenSslApplicationProtocolNegotiator;JJLio/netty/handler/ssl/ClientAuth;[Ljava/lang/String;ZZ)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=15, locals=21, args_size=16
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
        start local 1 // java.security.cert.X509Certificate[] trustCertCollection
        start local 2 // javax.net.ssl.TrustManagerFactory trustManagerFactory
        start local 3 // java.security.cert.X509Certificate[] keyCertChain
        start local 4 // java.security.PrivateKey key
        start local 5 // java.lang.String keyPassword
        start local 6 // javax.net.ssl.KeyManagerFactory keyManagerFactory
        start local 7 // java.lang.Iterable ciphers
        start local 8 // io.netty.handler.ssl.CipherSuiteFilter cipherFilter
        start local 9 // io.netty.handler.ssl.OpenSslApplicationProtocolNegotiator apn
        start local 10 // long sessionCacheSize
        start local 12 // long sessionTimeout
        start local 14 // io.netty.handler.ssl.ClientAuth clientAuth
        start local 15 // java.lang.String[] protocols
        start local 16 // boolean startTls
        start local 17 // boolean enableOcsp
         0: .line 70
            aload 0 /* this */
            aload 7 /* ciphers */
            aload 8 /* cipherFilter */
            aload 9 /* apn */
            lload 10 /* sessionCacheSize */
            lload 12 /* sessionTimeout */
            iconst_1
            aload 3 /* keyCertChain */
         1: .line 71
            aload 14 /* clientAuth */
            aload 15 /* protocols */
            iload 16 /* startTls */
            iload 17 /* enableOcsp */
            iconst_1
            invokespecial io.netty.handler.ssl.ReferenceCountedOpenSslContext.<init>:(Ljava/lang/Iterable;Lio/netty/handler/ssl/CipherSuiteFilter;Lio/netty/handler/ssl/OpenSslApplicationProtocolNegotiator;JJI[Ljava/security/cert/Certificate;Lio/netty/handler/ssl/ClientAuth;[Ljava/lang/String;ZZZ)V
         2: .line 73
            iconst_0
            istore 18 /* success */
        start local 18 // boolean success
         3: .line 75
            aload 0 /* this */
            aload 0 /* this */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.ctx:J
            aload 0 /* this */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.engineMap:Lio/netty/handler/ssl/OpenSslEngineMap;
            aload 1 /* trustCertCollection */
            aload 2 /* trustManagerFactory */
         4: .line 76
            aload 3 /* keyCertChain */
            aload 4 /* key */
            aload 5 /* keyPassword */
            aload 6 /* keyManagerFactory */
         5: .line 75
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.newSessionContext:(Lio/netty/handler/ssl/ReferenceCountedOpenSslContext;JLio/netty/handler/ssl/OpenSslEngineMap;[Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;)Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext$ServerContext;
            astore 19 /* context */
        start local 19 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext context
         6: .line 77
            aload 0 /* this */
            aload 19 /* context */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext.sessionContext:Lio/netty/handler/ssl/OpenSslServerSessionContext;
            putfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.sessionContext:Lio/netty/handler/ssl/OpenSslServerSessionContext;
         7: .line 78
            aload 0 /* this */
            aload 19 /* context */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext.keyMaterialManager:Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            putfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.keyMaterialManager:Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
         8: .line 79
            iconst_1
            istore 18 /* success */
        end local 19 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext context
         9: .line 80
            goto 14
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory java.lang.Iterable io.netty.handler.ssl.CipherSuiteFilter io.netty.handler.ssl.OpenSslApplicationProtocolNegotiator long long io.netty.handler.ssl.ClientAuth java.lang.String[] int int int
      StackMap stack: java.lang.Throwable
        10: astore 20
        11: .line 81
            iload 18 /* success */
            ifne 13
        12: .line 82
            aload 0 /* this */
            invokevirtual io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.release:()Z
            pop
        13: .line 84
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory java.lang.Iterable io.netty.handler.ssl.CipherSuiteFilter io.netty.handler.ssl.OpenSslApplicationProtocolNegotiator long long io.netty.handler.ssl.ClientAuth java.lang.String[] int int int top java.lang.Throwable
      StackMap stack:
            aload 20
            athrow
        14: .line 81
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory java.lang.Iterable io.netty.handler.ssl.CipherSuiteFilter io.netty.handler.ssl.OpenSslApplicationProtocolNegotiator long long io.netty.handler.ssl.ClientAuth java.lang.String[] int int int
      StackMap stack:
            iload 18 /* success */
            ifne 16
        15: .line 82
            aload 0 /* this */
            invokevirtual io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.release:()Z
            pop
        16: .line 85
      StackMap locals:
      StackMap stack:
            return
        end local 18 // boolean success
        end local 17 // boolean enableOcsp
        end local 16 // boolean startTls
        end local 15 // java.lang.String[] protocols
        end local 14 // io.netty.handler.ssl.ClientAuth clientAuth
        end local 12 // long sessionTimeout
        end local 10 // long sessionCacheSize
        end local 9 // io.netty.handler.ssl.OpenSslApplicationProtocolNegotiator apn
        end local 8 // io.netty.handler.ssl.CipherSuiteFilter cipherFilter
        end local 7 // java.lang.Iterable ciphers
        end local 6 // javax.net.ssl.KeyManagerFactory keyManagerFactory
        end local 5 // java.lang.String keyPassword
        end local 4 // java.security.PrivateKey key
        end local 3 // java.security.cert.X509Certificate[] keyCertChain
        end local 2 // javax.net.ssl.TrustManagerFactory trustManagerFactory
        end local 1 // java.security.cert.X509Certificate[] trustCertCollection
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   17     0                 this  Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext;
            0   17     1  trustCertCollection  [Ljava/security/cert/X509Certificate;
            0   17     2  trustManagerFactory  Ljavax/net/ssl/TrustManagerFactory;
            0   17     3         keyCertChain  [Ljava/security/cert/X509Certificate;
            0   17     4                  key  Ljava/security/PrivateKey;
            0   17     5          keyPassword  Ljava/lang/String;
            0   17     6    keyManagerFactory  Ljavax/net/ssl/KeyManagerFactory;
            0   17     7              ciphers  Ljava/lang/Iterable<Ljava/lang/String;>;
            0   17     8         cipherFilter  Lio/netty/handler/ssl/CipherSuiteFilter;
            0   17     9                  apn  Lio/netty/handler/ssl/OpenSslApplicationProtocolNegotiator;
            0   17    10     sessionCacheSize  J
            0   17    12       sessionTimeout  J
            0   17    14           clientAuth  Lio/netty/handler/ssl/ClientAuth;
            0   17    15            protocols  [Ljava/lang/String;
            0   17    16             startTls  Z
            0   17    17           enableOcsp  Z
            3   17    18              success  Z
            6    9    19              context  Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext$ServerContext;
      Exception table:
        from    to  target  type
           3    10      10  any
    Exceptions:
      throws javax.net.ssl.SSLException
    Signature: ([Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;Ljava/lang/Iterable<Ljava/lang/String;>;Lio/netty/handler/ssl/CipherSuiteFilter;Lio/netty/handler/ssl/OpenSslApplicationProtocolNegotiator;JJLio/netty/handler/ssl/ClientAuth;[Ljava/lang/String;ZZ)V
    MethodParameters:
                     Name  Flags
      trustCertCollection  
      trustManagerFactory  
      keyCertChain         
      key                  
      keyPassword          
      keyManagerFactory    
      ciphers              
      cipherFilter         
      apn                  
      sessionCacheSize     
      sessionTimeout       
      clientAuth           
      protocols            
      startTls             
      enableOcsp           

  public io.netty.handler.ssl.OpenSslServerSessionContext sessionContext();
    descriptor: ()Lio/netty/handler/ssl/OpenSslServerSessionContext;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
         0: .line 89
            aload 0 /* this */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.sessionContext:Lio/netty/handler/ssl/OpenSslServerSessionContext;
            areturn
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext;

  io.netty.handler.ssl.OpenSslKeyMaterialManager keyMaterialManager();
    descriptor: ()Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
         0: .line 94
            aload 0 /* this */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.keyMaterialManager:Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
            areturn
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext;

  static io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext newSessionContext(io.netty.handler.ssl.ReferenceCountedOpenSslContext, long, io.netty.handler.ssl.OpenSslEngineMap, java.security.cert.X509Certificate[], javax.net.ssl.TrustManagerFactory, java.security.cert.X509Certificate[], java.security.PrivateKey, java.lang.String, javax.net.ssl.KeyManagerFactory);
    descriptor: (Lio/netty/handler/ssl/ReferenceCountedOpenSslContext;JLio/netty/handler/ssl/OpenSslEngineMap;[Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;)Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext$ServerContext;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=6, locals=16, args_size=9
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslContext thiz
        start local 1 // long ctx
        start local 3 // io.netty.handler.ssl.OpenSslEngineMap engineMap
        start local 4 // java.security.cert.X509Certificate[] trustCertCollection
        start local 5 // javax.net.ssl.TrustManagerFactory trustManagerFactory
        start local 6 // java.security.cert.X509Certificate[] keyCertChain
        start local 7 // java.security.PrivateKey key
        start local 8 // java.lang.String keyPassword
        start local 9 // javax.net.ssl.KeyManagerFactory keyManagerFactory
         0: .line 108
            new io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext
            dup
            invokespecial io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext.<init>:()V
            astore 10 /* result */
        start local 10 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext result
         1: .line 110
            lload 1 /* ctx */
            iconst_0
            bipush 10
            invokestatic io.netty.internal.tcnative.SSLContext.setVerify:(JII)V
         2: .line 111
            invokestatic io.netty.handler.ssl.OpenSsl.useKeyManagerFactory:()Z
            ifne 10
         3: .line 112
            aload 9 /* keyManagerFactory */
            ifnull 7
         4: .line 113
            new java.lang.IllegalArgumentException
            dup
         5: .line 114
            ldc "KeyManagerFactory not supported"
         6: .line 113
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         7: .line 116
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext
      StackMap stack:
            aload 6 /* keyCertChain */
            ldc "keyCertChain"
            invokestatic io.netty.util.internal.ObjectUtil.checkNotNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         8: .line 118
            lload 1 /* ctx */
            aload 6 /* keyCertChain */
            aload 7 /* key */
            aload 8 /* keyPassword */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.setKeyMaterial:(J[Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;)V
         9: .line 119
            goto 24
        10: .line 122
      StackMap locals:
      StackMap stack:
            aload 9 /* keyManagerFactory */
            ifnonnull 13
        11: .line 124
            aload 6 /* keyCertChain */
            aload 7 /* key */
            aload 8 /* keyPassword */
            aload 9 /* keyManagerFactory */
        12: .line 123
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.buildKeyManagerFactory:([Ljava/security/cert/X509Certificate;Ljava/security/PrivateKey;Ljava/lang/String;Ljavax/net/ssl/KeyManagerFactory;)Ljavax/net/ssl/KeyManagerFactory;
            astore 9 /* keyManagerFactory */
        13: .line 126
      StackMap locals:
      StackMap stack:
            aload 9 /* keyManagerFactory */
            invokevirtual javax.net.ssl.KeyManagerFactory.getKeyManagers:()[Ljavax/net/ssl/KeyManager;
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.chooseX509KeyManager:([Ljavax/net/ssl/KeyManager;)Ljavax/net/ssl/X509KeyManager;
            astore 11 /* keyManager */
        start local 11 // javax.net.ssl.X509KeyManager keyManager
        14: .line 127
            aload 10 /* result */
            aload 11 /* keyManager */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.useExtendedKeyManager:(Ljavax/net/ssl/X509KeyManager;)Z
            ifeq 19
        15: .line 128
            new io.netty.handler.ssl.OpenSslExtendedKeyMaterialManager
            dup
        16: .line 129
            aload 11 /* keyManager */
            checkcast javax.net.ssl.X509ExtendedKeyManager
            aload 8 /* keyPassword */
        17: .line 128
            invokespecial io.netty.handler.ssl.OpenSslExtendedKeyMaterialManager.<init>:(Ljavax/net/ssl/X509ExtendedKeyManager;Ljava/lang/String;)V
        18: .line 129
            goto 20
        19: .line 130
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslContext long io.netty.handler.ssl.OpenSslEngineMap java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext javax.net.ssl.X509KeyManager
      StackMap stack: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext
            new io.netty.handler.ssl.OpenSslKeyMaterialManager
            dup
            aload 11 /* keyManager */
            aload 8 /* keyPassword */
            invokespecial io.netty.handler.ssl.OpenSslKeyMaterialManager.<init>:(Ljavax/net/ssl/X509KeyManager;Ljava/lang/String;)V
        20: .line 127
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslContext long io.netty.handler.ssl.OpenSslEngineMap java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext javax.net.ssl.X509KeyManager
      StackMap stack: io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext io.netty.handler.ssl.OpenSslKeyMaterialManager
            putfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext.keyMaterialManager:Lio/netty/handler/ssl/OpenSslKeyMaterialManager;
        end local 11 // javax.net.ssl.X509KeyManager keyManager
        21: .line 132
            goto 24
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslContext long io.netty.handler.ssl.OpenSslEngineMap java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext
      StackMap stack: java.lang.Exception
        22: astore 11 /* e */
        start local 11 // java.lang.Exception e
        23: .line 133
            new javax.net.ssl.SSLException
            dup
            ldc "failed to set certificate and key"
            aload 11 /* e */
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 11 // java.lang.Exception e
        24: .line 136
      StackMap locals:
      StackMap stack:
            aload 4 /* trustCertCollection */
            ifnull 27
        25: .line 137
            aload 4 /* trustCertCollection */
            aload 5 /* trustManagerFactory */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.buildTrustManagerFactory:([Ljava/security/cert/X509Certificate;Ljavax/net/ssl/TrustManagerFactory;)Ljavax/net/ssl/TrustManagerFactory;
            astore 5 /* trustManagerFactory */
        26: .line 138
            goto 31
      StackMap locals:
      StackMap stack:
        27: aload 5 /* trustManagerFactory */
            ifnonnull 31
        28: .line 141
            invokestatic javax.net.ssl.TrustManagerFactory.getDefaultAlgorithm:()Ljava/lang/String;
        29: .line 140
            invokestatic javax.net.ssl.TrustManagerFactory.getInstance:(Ljava/lang/String;)Ljavax/net/ssl/TrustManagerFactory;
            astore 5 /* trustManagerFactory */
        30: .line 142
            aload 5 /* trustManagerFactory */
            aconst_null
            invokevirtual javax.net.ssl.TrustManagerFactory.init:(Ljava/security/KeyStore;)V
        31: .line 145
      StackMap locals:
      StackMap stack:
            aload 5 /* trustManagerFactory */
            invokevirtual javax.net.ssl.TrustManagerFactory.getTrustManagers:()[Ljavax/net/ssl/TrustManager;
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.chooseTrustManager:([Ljavax/net/ssl/TrustManager;)Ljavax/net/ssl/X509TrustManager;
            astore 11 /* manager */
        start local 11 // javax.net.ssl.X509TrustManager manager
        32: .line 154
            aload 11 /* manager */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.useExtendedTrustManager:(Ljavax/net/ssl/X509TrustManager;)Z
            ifeq 37
        33: .line 155
            lload 1 /* ctx */
        34: .line 156
            new io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ExtendedTrustManagerVerifyCallback
            dup
            aload 3 /* engineMap */
            aload 11 /* manager */
            checkcast javax.net.ssl.X509ExtendedTrustManager
            invokespecial io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ExtendedTrustManagerVerifyCallback.<init>:(Lio/netty/handler/ssl/OpenSslEngineMap;Ljavax/net/ssl/X509ExtendedTrustManager;)V
        35: .line 155
            invokestatic io.netty.internal.tcnative.SSLContext.setCertVerifyCallback:(JLio/netty/internal/tcnative/CertificateVerifier;)V
        36: .line 157
            goto 38
        37: .line 158
      StackMap locals: javax.net.ssl.X509TrustManager
      StackMap stack:
            lload 1 /* ctx */
            new io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$TrustManagerVerifyCallback
            dup
            aload 3 /* engineMap */
            aload 11 /* manager */
            invokespecial io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$TrustManagerVerifyCallback.<init>:(Lio/netty/handler/ssl/OpenSslEngineMap;Ljavax/net/ssl/X509TrustManager;)V
            invokestatic io.netty.internal.tcnative.SSLContext.setCertVerifyCallback:(JLio/netty/internal/tcnative/CertificateVerifier;)V
        38: .line 161
      StackMap locals:
      StackMap stack:
            aload 11 /* manager */
            invokeinterface javax.net.ssl.X509TrustManager.getAcceptedIssuers:()[Ljava/security/cert/X509Certificate;
            astore 12 /* issuers */
        start local 12 // java.security.cert.X509Certificate[] issuers
        39: .line 162
            aload 12 /* issuers */
            ifnull 48
            aload 12 /* issuers */
            arraylength
            ifle 48
        40: .line 163
            lconst_0
            lstore 13 /* bio */
        start local 13 // long bio
        41: .line 165
            aload 12 /* issuers */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.toBIO:([Ljava/security/cert/X509Certificate;)J
            lstore 13 /* bio */
        42: .line 166
            lload 1 /* ctx */
            lload 13 /* bio */
            invokestatic io.netty.internal.tcnative.SSLContext.setCACertificateBio:(JJ)Z
            ifne 47
        43: .line 167
            new javax.net.ssl.SSLException
            dup
            new java.lang.StringBuilder
            dup
            ldc "unable to setup accepted issuers for trustmanager "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 11 /* manager */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;)V
            athrow
        44: .line 169
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslContext long io.netty.handler.ssl.OpenSslEngineMap java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext javax.net.ssl.X509TrustManager java.security.cert.X509Certificate[] long
      StackMap stack: java.lang.Throwable
            astore 15
        45: .line 170
            lload 13 /* bio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.freeBio:(J)V
        46: .line 171
            aload 15
            athrow
        47: .line 170
      StackMap locals:
      StackMap stack:
            lload 13 /* bio */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.freeBio:(J)V
        end local 13 // long bio
        48: .line 174
      StackMap locals:
      StackMap stack:
            invokestatic io.netty.util.internal.PlatformDependent.javaVersion:()I
            bipush 8
            if_icmplt 55
        49: .line 179
            lload 1 /* ctx */
            new io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$OpenSslSniHostnameMatcher
            dup
            aload 3 /* engineMap */
            invokespecial io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$OpenSslSniHostnameMatcher.<init>:(Lio/netty/handler/ssl/OpenSslEngineMap;)V
            invokestatic io.netty.internal.tcnative.SSLContext.setSniHostnameMatcher:(JLio/netty/internal/tcnative/SniHostNameMatcher;)V
        end local 12 // java.security.cert.X509Certificate[] issuers
        end local 11 // javax.net.ssl.X509TrustManager manager
        50: .line 181
            goto 55
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslContext long io.netty.handler.ssl.OpenSslEngineMap java.security.cert.X509Certificate[] javax.net.ssl.TrustManagerFactory java.security.cert.X509Certificate[] java.security.PrivateKey java.lang.String javax.net.ssl.KeyManagerFactory io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext
      StackMap stack: javax.net.ssl.SSLException
        51: astore 11 /* e */
        start local 11 // javax.net.ssl.SSLException e
        52: .line 182
            aload 11 /* e */
            athrow
        end local 11 // javax.net.ssl.SSLException e
        53: .line 183
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 11 /* e */
        start local 11 // java.lang.Exception e
        54: .line 184
            new javax.net.ssl.SSLException
            dup
            ldc "unable to setup trustmanager"
            aload 11 /* e */
            invokespecial javax.net.ssl.SSLException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 11 // java.lang.Exception e
        55: .line 187
      StackMap locals:
      StackMap stack:
            aload 10 /* result */
            new io.netty.handler.ssl.OpenSslServerSessionContext
            dup
            aload 0 /* thiz */
            invokespecial io.netty.handler.ssl.OpenSslServerSessionContext.<init>:(Lio/netty/handler/ssl/ReferenceCountedOpenSslContext;)V
            putfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext.sessionContext:Lio/netty/handler/ssl/OpenSslServerSessionContext;
        56: .line 188
            aload 10 /* result */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext.sessionContext:Lio/netty/handler/ssl/OpenSslServerSessionContext;
            getstatic io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.ID:[B
            invokevirtual io.netty.handler.ssl.OpenSslServerSessionContext.setSessionIdContext:([B)Z
            pop
        57: .line 189
            aload 10 /* result */
            areturn
        end local 10 // io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext result
        end local 9 // javax.net.ssl.KeyManagerFactory keyManagerFactory
        end local 8 // java.lang.String keyPassword
        end local 7 // java.security.PrivateKey key
        end local 6 // java.security.cert.X509Certificate[] keyCertChain
        end local 5 // javax.net.ssl.TrustManagerFactory trustManagerFactory
        end local 4 // java.security.cert.X509Certificate[] trustCertCollection
        end local 3 // io.netty.handler.ssl.OpenSslEngineMap engineMap
        end local 1 // long ctx
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslContext thiz
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   58     0                 thiz  Lio/netty/handler/ssl/ReferenceCountedOpenSslContext;
            0   58     1                  ctx  J
            0   58     3            engineMap  Lio/netty/handler/ssl/OpenSslEngineMap;
            0   58     4  trustCertCollection  [Ljava/security/cert/X509Certificate;
            0   58     5  trustManagerFactory  Ljavax/net/ssl/TrustManagerFactory;
            0   58     6         keyCertChain  [Ljava/security/cert/X509Certificate;
            0   58     7                  key  Ljava/security/PrivateKey;
            0   58     8          keyPassword  Ljava/lang/String;
            0   58     9    keyManagerFactory  Ljavax/net/ssl/KeyManagerFactory;
            1   58    10               result  Lio/netty/handler/ssl/ReferenceCountedOpenSslServerContext$ServerContext;
           14   21    11           keyManager  Ljavax/net/ssl/X509KeyManager;
           23   24    11                    e  Ljava/lang/Exception;
           32   50    11              manager  Ljavax/net/ssl/X509TrustManager;
           39   50    12              issuers  [Ljava/security/cert/X509Certificate;
           41   48    13                  bio  J
           52   53    11                    e  Ljavax/net/ssl/SSLException;
           54   55    11                    e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           1    21      22  Class java.lang.Exception
          41    44      44  any
          24    50      51  Class javax.net.ssl.SSLException
          24    50      53  Class java.lang.Exception
    Exceptions:
      throws javax.net.ssl.SSLException
    MethodParameters:
                     Name  Flags
      thiz                 
      ctx                  
      engineMap            
      trustCertCollection  
      trustManagerFactory  
      keyCertChain         
      key                  
      keyPassword          
      keyManagerFactory    

  public io.netty.handler.ssl.OpenSslSessionContext sessionContext();
    descriptor: ()Lio/netty/handler/ssl/OpenSslSessionContext;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.sessionContext:()Lio/netty/handler/ssl/OpenSslServerSessionContext;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public javax.net.ssl.SSLSessionContext sessionContext();
    descriptor: ()Ljavax/net/ssl/SSLSessionContext;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokevirtual io.netty.handler.ssl.ReferenceCountedOpenSslServerContext.sessionContext:()Lio/netty/handler/ssl/OpenSslServerSessionContext;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "ReferenceCountedOpenSslServerContext.java"
NestMembers:
  io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ExtendedTrustManagerVerifyCallback  io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$OpenSslSniHostnameMatcher  io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext  io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$TrustManagerVerifyCallback
InnerClasses:
  private final ExtendedTrustManagerVerifyCallback = io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ExtendedTrustManagerVerifyCallback of io.netty.handler.ssl.ReferenceCountedOpenSslServerContext
  private final OpenSslSniHostnameMatcher = io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$OpenSslSniHostnameMatcher of io.netty.handler.ssl.ReferenceCountedOpenSslServerContext
  final ServerContext = io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$ServerContext of io.netty.handler.ssl.ReferenceCountedOpenSslServerContext
  private final TrustManagerVerifyCallback = io.netty.handler.ssl.ReferenceCountedOpenSslServerContext$TrustManagerVerifyCallback of io.netty.handler.ssl.ReferenceCountedOpenSslServerContext