public final class sun.security.provider.certpath.OCSP
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: sun.security.provider.certpath.OCSP
  super_class: java.lang.Object
{
  private static final sun.security.util.Debug debug;
    descriptor: Lsun/security/util/Debug;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final int DEFAULT_CONNECT_TIMEOUT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 15000

  private static final int CONNECT_TIMEOUT;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 70
            ldc "certpath"
            invokestatic sun.security.util.Debug.getInstance:(Ljava/lang/String;)Lsun/security/util/Debug;
            putstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
         1: .line 79
            invokestatic sun.security.provider.certpath.OCSP.initializeTimeout:()I
            putstatic sun.security.provider.certpath.OCSP.CONNECT_TIMEOUT:I
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private static int initializeTimeout();
    descriptor: ()I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 88
            new sun.security.action.GetIntegerAction
            dup
            ldc "com.sun.security.ocsp.timeout"
            invokespecial sun.security.action.GetIntegerAction.<init>:(Ljava/lang/String;)V
         1: .line 87
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.Integer
            astore 0 /* tmp */
        start local 0 // java.lang.Integer tmp
         2: .line 89
            aload 0 /* tmp */
            ifnull 3
            aload 0 /* tmp */
            invokevirtual java.lang.Integer.intValue:()I
            ifge 4
         3: .line 90
      StackMap locals: java.lang.Integer
      StackMap stack:
            sipush 15000
            ireturn
         4: .line 94
      StackMap locals:
      StackMap stack:
            aload 0 /* tmp */
            invokevirtual java.lang.Integer.intValue:()I
            sipush 1000
            imul
            ireturn
        end local 0 // java.lang.Integer tmp
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            2    5     0   tmp  Ljava/lang/Integer;

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.provider.certpath.OCSP this
         0: .line 97
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.provider.certpath.OCSP this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/provider/certpath/OCSP;

  public static sun.security.provider.certpath.OCSP$RevocationStatus check(java.security.cert.X509Certificate, java.security.cert.X509Certificate, java.net.URI, java.security.cert.X509Certificate, java.util.Date);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/X509Certificate;Ljava/util/Date;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=7, locals=5, args_size=5
        start local 0 // java.security.cert.X509Certificate cert
        start local 1 // java.security.cert.X509Certificate issuerCert
        start local 2 // java.net.URI responderURI
        start local 3 // java.security.cert.X509Certificate responderCert
        start local 4 // java.util.Date date
         0: .line 124
            aload 0 /* cert */
            aload 1 /* issuerCert */
            aload 2 /* responderURI */
            aload 3 /* responderCert */
            aload 4 /* date */
         1: .line 125
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            ldc "generic"
         2: .line 124
            invokestatic sun.security.provider.certpath.OCSP.check:(Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
            areturn
        end local 4 // java.util.Date date
        end local 3 // java.security.cert.X509Certificate responderCert
        end local 2 // java.net.URI responderURI
        end local 1 // java.security.cert.X509Certificate issuerCert
        end local 0 // java.security.cert.X509Certificate cert
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0           cert  Ljava/security/cert/X509Certificate;
            0    3     1     issuerCert  Ljava/security/cert/X509Certificate;
            0    3     2   responderURI  Ljava/net/URI;
            0    3     3  responderCert  Ljava/security/cert/X509Certificate;
            0    3     4           date  Ljava/util/Date;
    Exceptions:
      throws java.io.IOException, java.security.cert.CertPathValidatorException
    MethodParameters:
               Name  Flags
      cert           
      issuerCert     
      responderURI   
      responderCert  
      date           

  public static sun.security.provider.certpath.OCSP$RevocationStatus check(java.security.cert.X509Certificate, java.security.cert.X509Certificate, java.net.URI, java.security.cert.X509Certificate, java.util.Date, java.util.List<java.security.cert.Extension>, java.lang.String);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=8, locals=7, args_size=7
        start local 0 // java.security.cert.X509Certificate cert
        start local 1 // java.security.cert.X509Certificate issuerCert
        start local 2 // java.net.URI responderURI
        start local 3 // java.security.cert.X509Certificate responderCert
        start local 4 // java.util.Date date
        start local 5 // java.util.List extensions
        start local 6 // java.lang.String variant
         0: .line 135
            aload 0 /* cert */
            aload 2 /* responderURI */
            aconst_null
            aload 1 /* issuerCert */
            aload 3 /* responderCert */
            aload 4 /* date */
         1: .line 136
            aload 5 /* extensions */
            aload 6 /* variant */
         2: .line 135
            invokestatic sun.security.provider.certpath.OCSP.check:(Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/TrustAnchor;Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
            areturn
        end local 6 // java.lang.String variant
        end local 5 // java.util.List extensions
        end local 4 // java.util.Date date
        end local 3 // java.security.cert.X509Certificate responderCert
        end local 2 // java.net.URI responderURI
        end local 1 // java.security.cert.X509Certificate issuerCert
        end local 0 // java.security.cert.X509Certificate cert
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0           cert  Ljava/security/cert/X509Certificate;
            0    3     1     issuerCert  Ljava/security/cert/X509Certificate;
            0    3     2   responderURI  Ljava/net/URI;
            0    3     3  responderCert  Ljava/security/cert/X509Certificate;
            0    3     4           date  Ljava/util/Date;
            0    3     5     extensions  Ljava/util/List<Ljava/security/cert/Extension;>;
            0    3     6        variant  Ljava/lang/String;
    Exceptions:
      throws java.io.IOException, java.security.cert.CertPathValidatorException
    Signature: (Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List<Ljava/security/cert/Extension;>;Ljava/lang/String;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
    MethodParameters:
               Name  Flags
      cert           
      issuerCert     
      responderURI   
      responderCert  
      date           
      extensions     
      variant        

  public static sun.security.provider.certpath.OCSP$RevocationStatus check(java.security.cert.X509Certificate, java.net.URI, java.security.cert.TrustAnchor, java.security.cert.X509Certificate, java.security.cert.X509Certificate, java.util.Date, java.util.List<java.security.cert.Extension>, java.lang.String);
    descriptor: (Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/TrustAnchor;Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=7, locals=10, args_size=8
        start local 0 // java.security.cert.X509Certificate cert
        start local 1 // java.net.URI responderURI
        start local 2 // java.security.cert.TrustAnchor anchor
        start local 3 // java.security.cert.X509Certificate issuerCert
        start local 4 // java.security.cert.X509Certificate responderCert
        start local 5 // java.util.Date date
        start local 6 // java.util.List extensions
        start local 7 // java.lang.String variant
         0: .line 147
            aload 0 /* cert */
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            astore 9 /* certImpl */
        start local 9 // sun.security.x509.X509CertImpl certImpl
         1: .line 148
            new sun.security.provider.certpath.CertId
            dup
            aload 3 /* issuerCert */
            aload 9 /* certImpl */
            invokevirtual sun.security.x509.X509CertImpl.getSerialNumberObject:()Lsun/security/x509/SerialNumber;
            invokespecial sun.security.provider.certpath.CertId.<init>:(Ljava/security/cert/X509Certificate;Lsun/security/x509/SerialNumber;)V
            astore 8 /* certId */
        end local 9 // sun.security.x509.X509CertImpl certImpl
        start local 8 // sun.security.provider.certpath.CertId certId
         2: .line 149
            goto 7
        end local 8 // sun.security.provider.certpath.CertId certId
      StackMap locals:
      StackMap stack: java.lang.Exception
         3: astore 9 /* e */
        start local 9 // java.lang.Exception e
         4: .line 150
            new java.security.cert.CertPathValidatorException
            dup
         5: .line 151
            ldc "Exception while encoding OCSPRequest"
            aload 9 /* e */
         6: .line 150
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 9 // java.lang.Exception e
        start local 8 // sun.security.provider.certpath.CertId certId
         7: .line 153
      StackMap locals: sun.security.provider.certpath.CertId
      StackMap stack:
            aload 8 /* certId */
            invokestatic java.util.Collections.singletonList:(Ljava/lang/Object;)Ljava/util/List;
         8: .line 154
            aload 1 /* responderURI */
            new sun.security.provider.certpath.OCSPResponse$IssuerInfo
            dup
            aload 2 /* anchor */
            aload 3 /* issuerCert */
            invokespecial sun.security.provider.certpath.OCSPResponse$IssuerInfo.<init>:(Ljava/security/cert/TrustAnchor;Ljava/security/cert/X509Certificate;)V
         9: .line 155
            aload 4 /* responderCert */
            aload 5 /* date */
            aload 6 /* extensions */
            aload 7 /* variant */
        10: .line 153
            invokestatic sun.security.provider.certpath.OCSP.check:(Ljava/util/List;Ljava/net/URI;Lsun/security/provider/certpath/OCSPResponse$IssuerInfo;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/provider/certpath/OCSPResponse;
            astore 9 /* ocspResponse */
        start local 9 // sun.security.provider.certpath.OCSPResponse ocspResponse
        11: .line 156
            aload 9 /* ocspResponse */
            aload 8 /* certId */
            invokevirtual sun.security.provider.certpath.OCSPResponse.getSingleResponse:(Lsun/security/provider/certpath/CertId;)Lsun/security/provider/certpath/OCSPResponse$SingleResponse;
            areturn
        end local 9 // sun.security.provider.certpath.OCSPResponse ocspResponse
        end local 8 // sun.security.provider.certpath.CertId certId
        end local 7 // java.lang.String variant
        end local 6 // java.util.List extensions
        end local 5 // java.util.Date date
        end local 4 // java.security.cert.X509Certificate responderCert
        end local 3 // java.security.cert.X509Certificate issuerCert
        end local 2 // java.security.cert.TrustAnchor anchor
        end local 1 // java.net.URI responderURI
        end local 0 // java.security.cert.X509Certificate cert
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   12     0           cert  Ljava/security/cert/X509Certificate;
            0   12     1   responderURI  Ljava/net/URI;
            0   12     2         anchor  Ljava/security/cert/TrustAnchor;
            0   12     3     issuerCert  Ljava/security/cert/X509Certificate;
            0   12     4  responderCert  Ljava/security/cert/X509Certificate;
            0   12     5           date  Ljava/util/Date;
            0   12     6     extensions  Ljava/util/List<Ljava/security/cert/Extension;>;
            0   12     7        variant  Ljava/lang/String;
            2    3     8         certId  Lsun/security/provider/certpath/CertId;
            7   12     8         certId  Lsun/security/provider/certpath/CertId;
            1    2     9       certImpl  Lsun/security/x509/X509CertImpl;
            4    7     9              e  Ljava/lang/Exception;
           11   12     9   ocspResponse  Lsun/security/provider/certpath/OCSPResponse;
      Exception table:
        from    to  target  type
           0     2       3  Class java.security.cert.CertificateException
           0     2       3  Class java.io.IOException
    Exceptions:
      throws java.io.IOException, java.security.cert.CertPathValidatorException
    Signature: (Ljava/security/cert/X509Certificate;Ljava/net/URI;Ljava/security/cert/TrustAnchor;Ljava/security/cert/X509Certificate;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List<Ljava/security/cert/Extension;>;Ljava/lang/String;)Lsun/security/provider/certpath/OCSP$RevocationStatus;
    MethodParameters:
               Name  Flags
      cert           
      responderURI   
      anchor         
      issuerCert     
      responderCert  
      date           
      extensions     
      variant        

  static sun.security.provider.certpath.OCSPResponse check(java.util.List<sun.security.provider.certpath.CertId>, java.net.URI, sun.security.provider.certpath.OCSPResponse$IssuerInfo, java.security.cert.X509Certificate, java.util.Date, java.util.List<java.security.cert.Extension>, java.lang.String);
    descriptor: (Ljava/util/List;Ljava/net/URI;Lsun/security/provider/certpath/OCSPResponse$IssuerInfo;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List;Ljava/lang/String;)Lsun/security/provider/certpath/OCSPResponse;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=7, locals=10, args_size=7
        start local 0 // java.util.List certIds
        start local 1 // java.net.URI responderURI
        start local 2 // sun.security.provider.certpath.OCSPResponse$IssuerInfo issuerInfo
        start local 3 // java.security.cert.X509Certificate responderCert
        start local 4 // java.util.Date date
        start local 5 // java.util.List extensions
        start local 6 // java.lang.String variant
         0: .line 183
            aconst_null
            astore 7 /* nonce */
        start local 7 // byte[] nonce
         1: .line 184
            aload 5 /* extensions */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 9
            goto 5
      StackMap locals: java.util.List java.net.URI sun.security.provider.certpath.OCSPResponse$IssuerInfo java.security.cert.X509Certificate java.util.Date java.util.List java.lang.String byte[] top java.util.Iterator
      StackMap stack:
         2: aload 9
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.security.cert.Extension
            astore 8 /* ext */
        start local 8 // java.security.cert.Extension ext
         3: .line 185
            aload 8 /* ext */
            invokeinterface java.security.cert.Extension.getId:()Ljava/lang/String;
            getstatic sun.security.x509.PKIXExtensions.OCSPNonce_Id:Lsun/security/util/ObjectIdentifier;
            invokevirtual sun.security.util.ObjectIdentifier.toString:()Ljava/lang/String;
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 186
            aload 8 /* ext */
            invokeinterface java.security.cert.Extension.getValue:()[B
            astore 7 /* nonce */
        end local 8 // java.security.cert.Extension ext
         5: .line 184
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 190
            aconst_null
            astore 8 /* ocspResponse */
        start local 8 // sun.security.provider.certpath.OCSPResponse ocspResponse
         7: .line 192
            aload 0 /* certIds */
            aload 1 /* responderURI */
            aload 5 /* extensions */
            invokestatic sun.security.provider.certpath.OCSP.getOCSPBytes:(Ljava/util/List;Ljava/net/URI;Ljava/util/List;)[B
            astore 9 /* response */
        start local 9 // byte[] response
         8: .line 193
            new sun.security.provider.certpath.OCSPResponse
            dup
            aload 9 /* response */
            invokespecial sun.security.provider.certpath.OCSPResponse.<init>:([B)V
            astore 8 /* ocspResponse */
         9: .line 196
            aload 8 /* ocspResponse */
            aload 0 /* certIds */
            aload 2 /* issuerInfo */
            aload 3 /* responderCert */
            aload 4 /* date */
        10: .line 197
            aload 7 /* nonce */
            aload 6 /* variant */
        11: .line 196
            invokevirtual sun.security.provider.certpath.OCSPResponse.verify:(Ljava/util/List;Lsun/security/provider/certpath/OCSPResponse$IssuerInfo;Ljava/security/cert/X509Certificate;Ljava/util/Date;[BLjava/lang/String;)V
        end local 9 // byte[] response
        12: .line 198
            goto 18
      StackMap locals: java.util.List java.net.URI sun.security.provider.certpath.OCSPResponse$IssuerInfo java.security.cert.X509Certificate java.util.Date java.util.List java.lang.String byte[] sun.security.provider.certpath.OCSPResponse
      StackMap stack: java.io.IOException
        13: astore 9 /* ioe */
        start local 9 // java.io.IOException ioe
        14: .line 199
            new java.security.cert.CertPathValidatorException
            dup
        15: .line 200
            ldc "Unable to determine revocation status due to network error"
        16: .line 201
            aload 9 /* ioe */
            aconst_null
            iconst_m1
            getstatic java.security.cert.CertPathValidatorException$BasicReason.UNDETERMINED_REVOCATION_STATUS:Ljava/security/cert/CertPathValidatorException$BasicReason;
        17: .line 199
            invokespecial java.security.cert.CertPathValidatorException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;Ljava/security/cert/CertPath;ILjava/security/cert/CertPathValidatorException$Reason;)V
            athrow
        end local 9 // java.io.IOException ioe
        18: .line 204
      StackMap locals:
      StackMap stack:
            aload 8 /* ocspResponse */
            areturn
        end local 8 // sun.security.provider.certpath.OCSPResponse ocspResponse
        end local 7 // byte[] nonce
        end local 6 // java.lang.String variant
        end local 5 // java.util.List extensions
        end local 4 // java.util.Date date
        end local 3 // java.security.cert.X509Certificate responderCert
        end local 2 // sun.security.provider.certpath.OCSPResponse$IssuerInfo issuerInfo
        end local 1 // java.net.URI responderURI
        end local 0 // java.util.List certIds
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   19     0        certIds  Ljava/util/List<Lsun/security/provider/certpath/CertId;>;
            0   19     1   responderURI  Ljava/net/URI;
            0   19     2     issuerInfo  Lsun/security/provider/certpath/OCSPResponse$IssuerInfo;
            0   19     3  responderCert  Ljava/security/cert/X509Certificate;
            0   19     4           date  Ljava/util/Date;
            0   19     5     extensions  Ljava/util/List<Ljava/security/cert/Extension;>;
            0   19     6        variant  Ljava/lang/String;
            1   19     7          nonce  [B
            3    5     8            ext  Ljava/security/cert/Extension;
            7   19     8   ocspResponse  Lsun/security/provider/certpath/OCSPResponse;
            8   12     9       response  [B
           14   18     9            ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           7    12      13  Class java.io.IOException
    Exceptions:
      throws java.io.IOException, java.security.cert.CertPathValidatorException
    Signature: (Ljava/util/List<Lsun/security/provider/certpath/CertId;>;Ljava/net/URI;Lsun/security/provider/certpath/OCSPResponse$IssuerInfo;Ljava/security/cert/X509Certificate;Ljava/util/Date;Ljava/util/List<Ljava/security/cert/Extension;>;Ljava/lang/String;)Lsun/security/provider/certpath/OCSPResponse;
    MethodParameters:
               Name  Flags
      certIds        
      responderURI   
      issuerInfo     
      responderCert  
      date           
      extensions     
      variant        

  public static byte[] getOCSPBytes(java.util.List<sun.security.provider.certpath.CertId>, java.net.URI, java.util.List<java.security.cert.Extension>);
    descriptor: (Ljava/util/List;Ljava/net/URI;Ljava/util/List;)[B
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=15, args_size=3
        start local 0 // java.util.List certIds
        start local 1 // java.net.URI responderURI
        start local 2 // java.util.List extensions
         0: .line 224
            new sun.security.provider.certpath.OCSPRequest
            dup
            aload 0 /* certIds */
            aload 2 /* extensions */
            invokespecial sun.security.provider.certpath.OCSPRequest.<init>:(Ljava/util/List;Ljava/util/List;)V
            astore 3 /* request */
        start local 3 // sun.security.provider.certpath.OCSPRequest request
         1: .line 225
            aload 3 /* request */
            invokevirtual sun.security.provider.certpath.OCSPRequest.encodeBytes:()[B
            astore 4 /* bytes */
        start local 4 // byte[] bytes
         2: .line 227
            aconst_null
            astore 5 /* in */
        start local 5 // java.io.InputStream in
         3: .line 228
            aconst_null
            astore 6 /* out */
        start local 6 // java.io.OutputStream out
         4: .line 229
            aconst_null
            astore 7 /* response */
        start local 7 // byte[] response
         5: .line 232
            aload 1 /* responderURI */
            invokevirtual java.net.URI.toURL:()Ljava/net/URL;
            astore 8 /* url */
        start local 8 // java.net.URL url
         6: .line 233
            getstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
            ifnull 8
         7: .line 234
            getstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "connecting to OCSP service at: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 8 /* url */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
         8: .line 237
      StackMap locals: java.util.List java.net.URI java.util.List sun.security.provider.certpath.OCSPRequest byte[] java.io.InputStream java.io.OutputStream byte[] java.net.URL
      StackMap stack:
            ldc "event.ocsp.check"
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            aload 8 /* url */
            invokevirtual java.net.URL.toString:()Ljava/lang/String;
            aastore
            invokestatic sun.security.util.Event.report:(Ljava/lang/String;[Ljava/lang/Object;)V
         9: .line 238
            aload 8 /* url */
            invokevirtual java.net.URL.openConnection:()Ljava/net/URLConnection;
            checkcast java.net.HttpURLConnection
            astore 9 /* con */
        start local 9 // java.net.HttpURLConnection con
        10: .line 239
            aload 9 /* con */
            getstatic sun.security.provider.certpath.OCSP.CONNECT_TIMEOUT:I
            invokevirtual java.net.HttpURLConnection.setConnectTimeout:(I)V
        11: .line 240
            aload 9 /* con */
            getstatic sun.security.provider.certpath.OCSP.CONNECT_TIMEOUT:I
            invokevirtual java.net.HttpURLConnection.setReadTimeout:(I)V
        12: .line 241
            aload 9 /* con */
            iconst_1
            invokevirtual java.net.HttpURLConnection.setDoOutput:(Z)V
        13: .line 242
            aload 9 /* con */
            iconst_1
            invokevirtual java.net.HttpURLConnection.setDoInput:(Z)V
        14: .line 243
            aload 9 /* con */
            ldc "POST"
            invokevirtual java.net.HttpURLConnection.setRequestMethod:(Ljava/lang/String;)V
        15: .line 244
            aload 9 /* con */
        16: .line 245
            ldc "Content-type"
            ldc "application/ocsp-request"
        17: .line 244
            invokevirtual java.net.HttpURLConnection.setRequestProperty:(Ljava/lang/String;Ljava/lang/String;)V
        18: .line 246
            aload 9 /* con */
        19: .line 247
            ldc "Content-length"
            aload 4 /* bytes */
            arraylength
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
        20: .line 246
            invokevirtual java.net.HttpURLConnection.setRequestProperty:(Ljava/lang/String;Ljava/lang/String;)V
        21: .line 248
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getOutputStream:()Ljava/io/OutputStream;
            astore 6 /* out */
        22: .line 249
            aload 6 /* out */
            aload 4 /* bytes */
            invokevirtual java.io.OutputStream.write:([B)V
        23: .line 250
            aload 6 /* out */
            invokevirtual java.io.OutputStream.flush:()V
        24: .line 252
            getstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
            ifnull 29
        25: .line 253
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getResponseCode:()I
            sipush 200
            if_icmpeq 29
        26: .line 254
            getstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
            new java.lang.StringBuilder
            dup
            ldc "Received HTTP error: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getResponseCode:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
        27: .line 255
            ldc " - "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getResponseMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        28: .line 254
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        29: .line 257
      StackMap locals: java.net.HttpURLConnection
      StackMap stack:
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getInputStream:()Ljava/io/InputStream;
            astore 5 /* in */
        30: .line 258
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getContentLength:()I
            istore 10 /* contentLength */
        start local 10 // int contentLength
        31: .line 259
            iload 10 /* contentLength */
            iconst_m1
            if_icmpne 33
        32: .line 260
            ldc 2147483647
            istore 10 /* contentLength */
        33: .line 262
      StackMap locals: int
      StackMap stack:
            iload 10 /* contentLength */
            sipush 2048
            if_icmple 34
            sipush 2048
            goto 35
      StackMap locals:
      StackMap stack:
        34: iload 10 /* contentLength */
      StackMap locals:
      StackMap stack: int
        35: newarray 8
            astore 7 /* response */
        36: .line 263
            iconst_0
            istore 11 /* total */
        start local 11 // int total
        37: .line 264
            goto 44
        38: .line 265
      StackMap locals: int
      StackMap stack:
            aload 5 /* in */
            aload 7 /* response */
            iload 11 /* total */
            aload 7 /* response */
            arraylength
            iload 11 /* total */
            isub
            invokevirtual java.io.InputStream.read:([BII)I
            istore 12 /* count */
        start local 12 // int count
        39: .line 266
            iload 12 /* count */
            ifge 41
        40: .line 267
            goto 45
        41: .line 269
      StackMap locals: int
      StackMap stack:
            iload 11 /* total */
            iload 12 /* count */
            iadd
            istore 11 /* total */
        42: .line 270
            iload 11 /* total */
            aload 7 /* response */
            arraylength
            if_icmplt 44
            iload 11 /* total */
            iload 10 /* contentLength */
            if_icmpge 44
        43: .line 271
            aload 7 /* response */
            iload 11 /* total */
            iconst_2
            imul
            invokestatic java.util.Arrays.copyOf:([BI)[B
            astore 7 /* response */
        end local 12 // int count
        44: .line 264
      StackMap locals:
      StackMap stack:
            iload 11 /* total */
            iload 10 /* contentLength */
            if_icmplt 38
        45: .line 274
      StackMap locals:
      StackMap stack:
            aload 7 /* response */
            iload 11 /* total */
            invokestatic java.util.Arrays.copyOf:([BI)[B
            astore 7 /* response */
        end local 11 // int total
        end local 10 // int contentLength
        end local 9 // java.net.HttpURLConnection con
        end local 8 // java.net.URL url
        46: .line 275
            goto 59
      StackMap locals: java.util.List java.net.URI java.util.List sun.security.provider.certpath.OCSPRequest byte[] java.io.InputStream java.io.OutputStream byte[]
      StackMap stack: java.lang.Throwable
        47: astore 13
        48: .line 276
            aload 5 /* in */
            ifnull 53
        49: .line 278
            aload 5 /* in */
            invokevirtual java.io.InputStream.close:()V
        50: .line 279
            goto 53
      StackMap locals: java.util.List java.net.URI java.util.List sun.security.provider.certpath.OCSPRequest byte[] java.io.InputStream java.io.OutputStream byte[] top top top top top java.lang.Throwable
      StackMap stack: java.io.IOException
        51: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        52: .line 280
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        53: .line 283
      StackMap locals:
      StackMap stack:
            aload 6 /* out */
            ifnull 58
        54: .line 285
            aload 6 /* out */
            invokevirtual java.io.OutputStream.close:()V
        55: .line 286
            goto 58
      StackMap locals:
      StackMap stack: java.io.IOException
        56: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        57: .line 287
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        58: .line 290
      StackMap locals:
      StackMap stack:
            aload 13
            athrow
        59: .line 276
      StackMap locals: java.util.List java.net.URI java.util.List sun.security.provider.certpath.OCSPRequest byte[] java.io.InputStream java.io.OutputStream byte[]
      StackMap stack:
            aload 5 /* in */
            ifnull 64
        60: .line 278
            aload 5 /* in */
            invokevirtual java.io.InputStream.close:()V
        61: .line 279
            goto 64
      StackMap locals:
      StackMap stack: java.io.IOException
        62: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        63: .line 280
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        64: .line 283
      StackMap locals:
      StackMap stack:
            aload 6 /* out */
            ifnull 69
        65: .line 285
            aload 6 /* out */
            invokevirtual java.io.OutputStream.close:()V
        66: .line 286
            goto 69
      StackMap locals:
      StackMap stack: java.io.IOException
        67: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        68: .line 287
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        69: .line 291
      StackMap locals:
      StackMap stack:
            aload 7 /* response */
            areturn
        end local 7 // byte[] response
        end local 6 // java.io.OutputStream out
        end local 5 // java.io.InputStream in
        end local 4 // byte[] bytes
        end local 3 // sun.security.provider.certpath.OCSPRequest request
        end local 2 // java.util.List extensions
        end local 1 // java.net.URI responderURI
        end local 0 // java.util.List certIds
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   70     0        certIds  Ljava/util/List<Lsun/security/provider/certpath/CertId;>;
            0   70     1   responderURI  Ljava/net/URI;
            0   70     2     extensions  Ljava/util/List<Ljava/security/cert/Extension;>;
            1   70     3        request  Lsun/security/provider/certpath/OCSPRequest;
            2   70     4          bytes  [B
            3   70     5             in  Ljava/io/InputStream;
            4   70     6            out  Ljava/io/OutputStream;
            5   70     7       response  [B
            6   46     8            url  Ljava/net/URL;
           10   46     9            con  Ljava/net/HttpURLConnection;
           31   46    10  contentLength  I
           37   46    11          total  I
           39   44    12          count  I
           52   53    14            ioe  Ljava/io/IOException;
           63   64    14            ioe  Ljava/io/IOException;
           57   58    14            ioe  Ljava/io/IOException;
           68   69    14            ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           5    47      47  any
          49    50      51  Class java.io.IOException
          54    55      56  Class java.io.IOException
          60    61      62  Class java.io.IOException
          65    66      67  Class java.io.IOException
    Exceptions:
      throws java.io.IOException
    Signature: (Ljava/util/List<Lsun/security/provider/certpath/CertId;>;Ljava/net/URI;Ljava/util/List<Ljava/security/cert/Extension;>;)[B
    MethodParameters:
              Name  Flags
      certIds       
      responderURI  
      extensions    

  public static java.net.URI getResponderURI(java.security.cert.X509Certificate);
    descriptor: (Ljava/security/cert/X509Certificate;)Ljava/net/URI;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // java.security.cert.X509Certificate cert
         0: .line 305
            aload 0 /* cert */
            invokestatic sun.security.x509.X509CertImpl.toImpl:(Ljava/security/cert/X509Certificate;)Lsun/security/x509/X509CertImpl;
            invokestatic sun.security.provider.certpath.OCSP.getResponderURI:(Lsun/security/x509/X509CertImpl;)Ljava/net/URI;
         1: areturn
         2: .line 306
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            pop
         3: .line 308
            aconst_null
            areturn
        end local 0 // java.security.cert.X509Certificate cert
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  cert  Ljava/security/cert/X509Certificate;
      Exception table:
        from    to  target  type
           0     1       2  Class java.security.cert.CertificateException
    MethodParameters:
      Name  Flags
      cert  

  static java.net.URI getResponderURI(sun.security.x509.X509CertImpl);
    descriptor: (Lsun/security/x509/X509CertImpl;)Ljava/net/URI;
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=7, args_size=1
        start local 0 // sun.security.x509.X509CertImpl certImpl
         0: .line 316
            aload 0 /* certImpl */
            invokevirtual sun.security.x509.X509CertImpl.getAuthorityInfoAccessExtension:()Lsun/security/x509/AuthorityInfoAccessExtension;
         1: .line 315
            astore 1 /* aia */
        start local 1 // sun.security.x509.AuthorityInfoAccessExtension aia
         2: .line 317
            aload 1 /* aia */
            ifnonnull 4
         3: .line 318
            aconst_null
            areturn
         4: .line 321
      StackMap locals: sun.security.x509.AuthorityInfoAccessExtension
      StackMap stack:
            aload 1 /* aia */
            invokevirtual sun.security.x509.AuthorityInfoAccessExtension.getAccessDescriptions:()Ljava/util/List;
            astore 2 /* descriptions */
        start local 2 // java.util.List descriptions
         5: .line 322
            aload 2 /* descriptions */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 4
            goto 15
      StackMap locals: sun.security.x509.X509CertImpl sun.security.x509.AuthorityInfoAccessExtension java.util.List top java.util.Iterator
      StackMap stack:
         6: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast sun.security.x509.AccessDescription
            astore 3 /* description */
        start local 3 // sun.security.x509.AccessDescription description
         7: .line 323
            aload 3 /* description */
            invokevirtual sun.security.x509.AccessDescription.getAccessMethod:()Lsun/security/util/ObjectIdentifier;
         8: .line 324
            getstatic sun.security.x509.AccessDescription.Ad_OCSP_Id:Lsun/security/util/ObjectIdentifier;
         9: .line 323
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
        10: .line 324
            ifeq 15
        11: .line 326
            aload 3 /* description */
            invokevirtual sun.security.x509.AccessDescription.getAccessLocation:()Lsun/security/x509/GeneralName;
            astore 5 /* generalName */
        start local 5 // sun.security.x509.GeneralName generalName
        12: .line 327
            aload 5 /* generalName */
            invokevirtual sun.security.x509.GeneralName.getType:()I
            bipush 6
            if_icmpne 15
        13: .line 328
            aload 5 /* generalName */
            invokevirtual sun.security.x509.GeneralName.getName:()Lsun/security/x509/GeneralNameInterface;
            checkcast sun.security.x509.URIName
            astore 6 /* uri */
        start local 6 // sun.security.x509.URIName uri
        14: .line 329
            aload 6 /* uri */
            invokevirtual sun.security.x509.URIName.getURI:()Ljava/net/URI;
            areturn
        end local 6 // sun.security.x509.URIName uri
        end local 5 // sun.security.x509.GeneralName generalName
        end local 3 // sun.security.x509.AccessDescription description
        15: .line 322
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        16: .line 333
            aconst_null
            areturn
        end local 2 // java.util.List descriptions
        end local 1 // sun.security.x509.AuthorityInfoAccessExtension aia
        end local 0 // sun.security.x509.X509CertImpl certImpl
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   17     0      certImpl  Lsun/security/x509/X509CertImpl;
            2   17     1           aia  Lsun/security/x509/AuthorityInfoAccessExtension;
            5   17     2  descriptions  Ljava/util/List<Lsun/security/x509/AccessDescription;>;
            7   15     3   description  Lsun/security/x509/AccessDescription;
           12   15     5   generalName  Lsun/security/x509/GeneralName;
           14   15     6           uri  Lsun/security/x509/URIName;
    MethodParameters:
          Name  Flags
      certImpl  
}
SourceFile: "OCSP.java"
NestMembers:
  sun.security.provider.certpath.OCSP$RevocationStatus  sun.security.provider.certpath.OCSP$RevocationStatus$CertStatus
InnerClasses:
  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
  public abstract RevocationStatus = sun.security.provider.certpath.OCSP$RevocationStatus of sun.security.provider.certpath.OCSP
  final IssuerInfo = sun.security.provider.certpath.OCSPResponse$IssuerInfo of sun.security.provider.certpath.OCSPResponse
  public final SingleResponse = sun.security.provider.certpath.OCSPResponse$SingleResponse of sun.security.provider.certpath.OCSPResponse