abstract class io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier extends io.netty.internal.tcnative.CertificateVerifier
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier
  super_class: io.netty.internal.tcnative.CertificateVerifier
{
  private final io.netty.handler.ssl.OpenSslEngineMap engineMap;
    descriptor: Lio/netty/handler/ssl/OpenSslEngineMap;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  void <init>(io.netty.handler.ssl.OpenSslEngineMap);
    descriptor: (Lio/netty/handler/ssl/OpenSslEngineMap;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier this
        start local 1 // io.netty.handler.ssl.OpenSslEngineMap engineMap
         0: .line 615
            aload 0 /* this */
            invokespecial io.netty.internal.tcnative.CertificateVerifier.<init>:()V
         1: .line 616
            aload 0 /* this */
            aload 1 /* engineMap */
            putfield io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier.engineMap:Lio/netty/handler/ssl/OpenSslEngineMap;
         2: .line 617
            return
        end local 1 // io.netty.handler.ssl.OpenSslEngineMap engineMap
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lio/netty/handler/ssl/ReferenceCountedOpenSslContext$AbstractCertificateVerifier;
            0    3     1  engineMap  Lio/netty/handler/ssl/OpenSslEngineMap;
    MethodParameters:
           Name  Flags
      engineMap  

  public final int verify(long, byte[][], java.lang.String);
    descriptor: (J[[BLjava/lang/String;)I
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Code:
      stack=4, locals=12, args_size=4
        start local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier this
        start local 1 // long ssl
        start local 3 // byte[][] chain
        start local 4 // java.lang.String auth
         0: .line 621
            aload 3 /* chain */
            invokestatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.certificates:([[B)[Ljava/security/cert/X509Certificate;
            astore 5 /* peerCerts */
        start local 5 // java.security.cert.X509Certificate[] peerCerts
         1: .line 622
            aload 0 /* this */
            getfield io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier.engineMap:Lio/netty/handler/ssl/OpenSslEngineMap;
            lload 1 /* ssl */
            invokeinterface io.netty.handler.ssl.OpenSslEngineMap.get:(J)Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;
            astore 6 /* engine */
        start local 6 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
         2: .line 624
            aload 0 /* this */
            aload 6 /* engine */
            aload 5 /* peerCerts */
            aload 4 /* auth */
            invokevirtual io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier.verify:(Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;[Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
         3: .line 625
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_OK:I
         4: ireturn
         5: .line 626
      StackMap locals: io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier long byte[][] java.lang.String java.security.cert.X509Certificate[] io.netty.handler.ssl.ReferenceCountedOpenSslEngine
      StackMap stack: java.lang.Throwable
            astore 7 /* cause */
        start local 7 // java.lang.Throwable cause
         6: .line 627
            getstatic io.netty.handler.ssl.ReferenceCountedOpenSslContext.logger:Lio/netty/util/internal/logging/InternalLogger;
            ldc "verification of certificate failed"
            aload 7 /* cause */
            invokeinterface io.netty.util.internal.logging.InternalLogger.debug:(Ljava/lang/String;Ljava/lang/Throwable;)V
         7: .line 628
            new javax.net.ssl.SSLHandshakeException
            dup
            ldc "General OpenSslEngine problem"
            invokespecial javax.net.ssl.SSLHandshakeException.<init>:(Ljava/lang/String;)V
            astore 8 /* e */
        start local 8 // javax.net.ssl.SSLHandshakeException e
         8: .line 629
            aload 8 /* e */
            aload 7 /* cause */
            invokevirtual javax.net.ssl.SSLHandshakeException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
         9: .line 630
            aload 6 /* engine */
            aload 8 /* e */
            putfield io.netty.handler.ssl.ReferenceCountedOpenSslEngine.handshakeException:Ljavax/net/ssl/SSLHandshakeException;
        10: .line 633
            aload 7 /* cause */
            instanceof io.netty.handler.ssl.OpenSslCertificateException
            ifeq 12
        11: .line 636
            aload 7 /* cause */
            checkcast io.netty.handler.ssl.OpenSslCertificateException
            invokevirtual io.netty.handler.ssl.OpenSslCertificateException.errorCode:()I
            ireturn
        12: .line 638
      StackMap locals: java.lang.Throwable javax.net.ssl.SSLHandshakeException
      StackMap stack:
            aload 7 /* cause */
            instanceof java.security.cert.CertificateExpiredException
            ifeq 14
        13: .line 639
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_CERT_HAS_EXPIRED:I
            ireturn
        14: .line 641
      StackMap locals:
      StackMap stack:
            aload 7 /* cause */
            instanceof java.security.cert.CertificateNotYetValidException
            ifeq 16
        15: .line 642
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_CERT_NOT_YET_VALID:I
            ireturn
        16: .line 644
      StackMap locals:
      StackMap stack:
            invokestatic io.netty.util.internal.PlatformDependent.javaVersion:()I
            bipush 7
            if_icmplt 32
        17: .line 645
            aload 7 /* cause */
            instanceof java.security.cert.CertificateRevokedException
            ifeq 19
        18: .line 646
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_CERT_REVOKED:I
            ireturn
        19: .line 652
      StackMap locals:
      StackMap stack:
            aload 7 /* cause */
            invokevirtual java.lang.Throwable.getCause:()Ljava/lang/Throwable;
            astore 9 /* wrapped */
        start local 9 // java.lang.Throwable wrapped
        20: .line 653
            goto 31
        21: .line 654
      StackMap locals: java.lang.Throwable
      StackMap stack:
            aload 9 /* wrapped */
            instanceof java.security.cert.CertPathValidatorException
            ifeq 30
        22: .line 655
            aload 9 /* wrapped */
            checkcast java.security.cert.CertPathValidatorException
            astore 10 /* ex */
        start local 10 // java.security.cert.CertPathValidatorException ex
        23: .line 656
            aload 10 /* ex */
            invokevirtual java.security.cert.CertPathValidatorException.getReason:()Ljava/security/cert/CertPathValidatorException$Reason;
            astore 11 /* reason */
        start local 11 // java.security.cert.CertPathValidatorException$Reason reason
        24: .line 657
            aload 11 /* reason */
            getstatic java.security.cert.CertPathValidatorException$BasicReason.EXPIRED:Ljava/security/cert/CertPathValidatorException$BasicReason;
            if_acmpne 26
        25: .line 658
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_CERT_HAS_EXPIRED:I
            ireturn
        26: .line 660
      StackMap locals: java.security.cert.CertPathValidatorException java.security.cert.CertPathValidatorException$Reason
      StackMap stack:
            aload 11 /* reason */
            getstatic java.security.cert.CertPathValidatorException$BasicReason.NOT_YET_VALID:Ljava/security/cert/CertPathValidatorException$BasicReason;
            if_acmpne 28
        27: .line 661
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_CERT_NOT_YET_VALID:I
            ireturn
        28: .line 663
      StackMap locals:
      StackMap stack:
            aload 11 /* reason */
            getstatic java.security.cert.CertPathValidatorException$BasicReason.REVOKED:Ljava/security/cert/CertPathValidatorException$BasicReason;
            if_acmpne 30
        29: .line 664
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_CERT_REVOKED:I
            ireturn
        end local 11 // java.security.cert.CertPathValidatorException$Reason reason
        end local 10 // java.security.cert.CertPathValidatorException ex
        30: .line 667
      StackMap locals:
      StackMap stack:
            aload 9 /* wrapped */
            invokevirtual java.lang.Throwable.getCause:()Ljava/lang/Throwable;
            astore 9 /* wrapped */
        31: .line 653
      StackMap locals:
      StackMap stack:
            aload 9 /* wrapped */
            ifnonnull 21
        end local 9 // java.lang.Throwable wrapped
        32: .line 672
      StackMap locals:
      StackMap stack:
            getstatic io.netty.internal.tcnative.CertificateVerifier.X509_V_ERR_UNSPECIFIED:I
            ireturn
        end local 8 // javax.net.ssl.SSLHandshakeException e
        end local 7 // java.lang.Throwable cause
        end local 6 // io.netty.handler.ssl.ReferenceCountedOpenSslEngine engine
        end local 5 // java.security.cert.X509Certificate[] peerCerts
        end local 4 // java.lang.String auth
        end local 3 // byte[][] chain
        end local 1 // long ssl
        end local 0 // io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   33     0       this  Lio/netty/handler/ssl/ReferenceCountedOpenSslContext$AbstractCertificateVerifier;
            0   33     1        ssl  J
            0   33     3      chain  [[B
            0   33     4       auth  Ljava/lang/String;
            1   33     5  peerCerts  [Ljava/security/cert/X509Certificate;
            2   33     6     engine  Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;
            6   33     7      cause  Ljava/lang/Throwable;
            8   33     8          e  Ljavax/net/ssl/SSLHandshakeException;
           20   32     9    wrapped  Ljava/lang/Throwable;
           23   30    10         ex  Ljava/security/cert/CertPathValidatorException;
           24   30    11     reason  Ljava/security/cert/CertPathValidatorException$Reason;
      Exception table:
        from    to  target  type
           2     4       5  Class java.lang.Throwable
    MethodParameters:
       Name  Flags
      ssl    
      chain  
      auth   

  abstract void verify(io.netty.handler.ssl.ReferenceCountedOpenSslEngine, java.security.cert.X509Certificate[], java.lang.String);
    descriptor: (Lio/netty/handler/ssl/ReferenceCountedOpenSslEngine;[Ljava/security/cert/X509Certificate;Ljava/lang/String;)V
    flags: (0x0400) ACC_ABSTRACT
    Exceptions:
      throws java.lang.Exception
    MethodParameters:
           Name  Flags
      engine     
      peerCerts  
      auth       
}
SourceFile: "ReferenceCountedOpenSslContext.java"
NestHost: io.netty.handler.ssl.ReferenceCountedOpenSslContext
InnerClasses:
  abstract AbstractCertificateVerifier = io.netty.handler.ssl.ReferenceCountedOpenSslContext$AbstractCertificateVerifier of io.netty.handler.ssl.ReferenceCountedOpenSslContext
  public final BasicReason = java.security.cert.CertPathValidatorException$BasicReason of java.security.cert.CertPathValidatorException
  public abstract Reason = java.security.cert.CertPathValidatorException$Reason of java.security.cert.CertPathValidatorException