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 69
            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 78
            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 87
            new sun.security.action.GetIntegerAction
            dup
            ldc "com.sun.security.ocsp.timeout"
            invokespecial sun.security.action.GetIntegerAction.<init>:(Ljava/lang/String;)V
         1: .line 86
            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 88
            aload 0 /* tmp */
            ifnull 3
            aload 0 /* tmp */
            invokevirtual java.lang.Integer.intValue:()I
            ifge 4
         3: .line 89
      StackMap locals: java.lang.Integer
      StackMap stack:
            sipush 15000
            ireturn
         4: .line 93
      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 96
            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 123
            aload 0 /* cert */
            aload 1 /* issuerCert */
            aload 2 /* responderURI */
            aload 3 /* responderCert */
            aload 4 /* date */
         1: .line 124
            invokestatic java.util.Collections.emptyList:()Ljava/util/List;
            ldc "generic"
         2: .line 123
            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 134
            aload 0 /* cert */
            aload 2 /* responderURI */
            aconst_null
            aload 1 /* issuerCert */
            aload 3 /* responderCert */
            aload 4 /* date */
         1: .line 135
            aload 5 /* extensions */
            aload 6 /* variant */
         2: .line 134
            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 146
            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 147
            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 148
            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 149
            new java.security.cert.CertPathValidatorException
            dup
         5: .line 150
            ldc "Exception while encoding OCSPRequest"
            aload 9 /* e */
         6: .line 149
            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 152
      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 153
            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 154
            aload 4 /* responderCert */
            aload 5 /* date */
            aload 6 /* extensions */
            aload 7 /* variant */
        10: .line 152
            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 155
            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 182
            aconst_null
            astore 7 /* nonce */
        start local 7 // byte[] nonce
         1: .line 183
            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 184
            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 185
            aload 8 /* ext */
            invokeinterface java.security.cert.Extension.getValue:()[B
            astore 7 /* nonce */
        end local 8 // java.security.cert.Extension ext
         5: .line 183
      StackMap locals:
      StackMap stack:
            aload 9
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 189
            aconst_null
            astore 8 /* ocspResponse */
        start local 8 // sun.security.provider.certpath.OCSPResponse ocspResponse
         7: .line 191
            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 192
            new sun.security.provider.certpath.OCSPResponse
            dup
            aload 9 /* response */
            invokespecial sun.security.provider.certpath.OCSPResponse.<init>:([B)V
            astore 8 /* ocspResponse */
         9: .line 195
            aload 8 /* ocspResponse */
            aload 0 /* certIds */
            aload 2 /* issuerInfo */
            aload 3 /* responderCert */
            aload 4 /* date */
        10: .line 196
            aload 7 /* nonce */
            aload 6 /* variant */
        11: .line 195
            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 197
            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 198
            new java.security.cert.CertPathValidatorException
            dup
        15: .line 199
            ldc "Unable to determine revocation status due to network error"
        16: .line 200
            aload 9 /* ioe */
            aconst_null
            iconst_m1
            getstatic java.security.cert.CertPathValidatorException$BasicReason.UNDETERMINED_REVOCATION_STATUS:Ljava/security/cert/CertPathValidatorException$BasicReason;
        17: .line 198
            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 203
      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 223
            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 224
            aload 3 /* request */
            invokevirtual sun.security.provider.certpath.OCSPRequest.encodeBytes:()[B
            astore 4 /* bytes */
        start local 4 // byte[] bytes
         2: .line 226
            aconst_null
            astore 5 /* in */
        start local 5 // java.io.InputStream in
         3: .line 227
            aconst_null
            astore 6 /* out */
        start local 6 // java.io.OutputStream out
         4: .line 228
            aconst_null
            astore 7 /* response */
        start local 7 // byte[] response
         5: .line 231
            aload 1 /* responderURI */
            invokevirtual java.net.URI.toURL:()Ljava/net/URL;
            astore 8 /* url */
        start local 8 // java.net.URL url
         6: .line 232
            getstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
            ifnull 8
         7: .line 233
            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 235
      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:
            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
         9: .line 236
            aload 9 /* con */
            getstatic sun.security.provider.certpath.OCSP.CONNECT_TIMEOUT:I
            invokevirtual java.net.HttpURLConnection.setConnectTimeout:(I)V
        10: .line 237
            aload 9 /* con */
            getstatic sun.security.provider.certpath.OCSP.CONNECT_TIMEOUT:I
            invokevirtual java.net.HttpURLConnection.setReadTimeout:(I)V
        11: .line 238
            aload 9 /* con */
            iconst_1
            invokevirtual java.net.HttpURLConnection.setDoOutput:(Z)V
        12: .line 239
            aload 9 /* con */
            iconst_1
            invokevirtual java.net.HttpURLConnection.setDoInput:(Z)V
        13: .line 240
            aload 9 /* con */
            ldc "POST"
            invokevirtual java.net.HttpURLConnection.setRequestMethod:(Ljava/lang/String;)V
        14: .line 241
            aload 9 /* con */
        15: .line 242
            ldc "Content-type"
            ldc "application/ocsp-request"
        16: .line 241
            invokevirtual java.net.HttpURLConnection.setRequestProperty:(Ljava/lang/String;Ljava/lang/String;)V
        17: .line 243
            aload 9 /* con */
        18: .line 244
            ldc "Content-length"
            aload 4 /* bytes */
            arraylength
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
        19: .line 243
            invokevirtual java.net.HttpURLConnection.setRequestProperty:(Ljava/lang/String;Ljava/lang/String;)V
        20: .line 245
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getOutputStream:()Ljava/io/OutputStream;
            astore 6 /* out */
        21: .line 246
            aload 6 /* out */
            aload 4 /* bytes */
            invokevirtual java.io.OutputStream.write:([B)V
        22: .line 247
            aload 6 /* out */
            invokevirtual java.io.OutputStream.flush:()V
        23: .line 249
            getstatic sun.security.provider.certpath.OCSP.debug:Lsun/security/util/Debug;
            ifnull 28
        24: .line 250
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getResponseCode:()I
            sipush 200
            if_icmpeq 28
        25: .line 251
            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;
        26: .line 252
            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;
        27: .line 251
            invokevirtual sun.security.util.Debug.println:(Ljava/lang/String;)V
        28: .line 254
      StackMap locals: java.net.HttpURLConnection
      StackMap stack:
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getInputStream:()Ljava/io/InputStream;
            astore 5 /* in */
        29: .line 255
            aload 9 /* con */
            invokevirtual java.net.HttpURLConnection.getContentLength:()I
            istore 10 /* contentLength */
        start local 10 // int contentLength
        30: .line 256
            iload 10 /* contentLength */
            iconst_m1
            if_icmpne 32
        31: .line 257
            ldc 2147483647
            istore 10 /* contentLength */
        32: .line 259
      StackMap locals: int
      StackMap stack:
            iload 10 /* contentLength */
            sipush 2048
            if_icmple 33
            sipush 2048
            goto 34
      StackMap locals:
      StackMap stack:
        33: iload 10 /* contentLength */
      StackMap locals:
      StackMap stack: int
        34: newarray 8
            astore 7 /* response */
        35: .line 260
            iconst_0
            istore 11 /* total */
        start local 11 // int total
        36: .line 261
            goto 43
        37: .line 262
      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
        38: .line 263
            iload 12 /* count */
            ifge 40
        39: .line 264
            goto 44
        40: .line 266
      StackMap locals: int
      StackMap stack:
            iload 11 /* total */
            iload 12 /* count */
            iadd
            istore 11 /* total */
        41: .line 267
            iload 11 /* total */
            aload 7 /* response */
            arraylength
            if_icmplt 43
            iload 11 /* total */
            iload 10 /* contentLength */
            if_icmpge 43
        42: .line 268
            aload 7 /* response */
            iload 11 /* total */
            iconst_2
            imul
            invokestatic java.util.Arrays.copyOf:([BI)[B
            astore 7 /* response */
        end local 12 // int count
        43: .line 261
      StackMap locals:
      StackMap stack:
            iload 11 /* total */
            iload 10 /* contentLength */
            if_icmplt 37
        44: .line 271
      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
        45: .line 272
            goto 58
      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
        46: astore 13
        47: .line 273
            aload 5 /* in */
            ifnull 52
        48: .line 275
            aload 5 /* in */
            invokevirtual java.io.InputStream.close:()V
        49: .line 276
            goto 52
      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
        50: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        51: .line 277
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        52: .line 280
      StackMap locals:
      StackMap stack:
            aload 6 /* out */
            ifnull 57
        53: .line 282
            aload 6 /* out */
            invokevirtual java.io.OutputStream.close:()V
        54: .line 283
            goto 57
      StackMap locals:
      StackMap stack: java.io.IOException
        55: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        56: .line 284
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        57: .line 287
      StackMap locals:
      StackMap stack:
            aload 13
            athrow
        58: .line 273
      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 63
        59: .line 275
            aload 5 /* in */
            invokevirtual java.io.InputStream.close:()V
        60: .line 276
            goto 63
      StackMap locals:
      StackMap stack: java.io.IOException
        61: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        62: .line 277
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        63: .line 280
      StackMap locals:
      StackMap stack:
            aload 6 /* out */
            ifnull 68
        64: .line 282
            aload 6 /* out */
            invokevirtual java.io.OutputStream.close:()V
        65: .line 283
            goto 68
      StackMap locals:
      StackMap stack: java.io.IOException
        66: astore 14 /* ioe */
        start local 14 // java.io.IOException ioe
        67: .line 284
            aload 14 /* ioe */
            athrow
        end local 14 // java.io.IOException ioe
        68: .line 288
      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   69     0        certIds  Ljava/util/List<Lsun/security/provider/certpath/CertId;>;
            0   69     1   responderURI  Ljava/net/URI;
            0   69     2     extensions  Ljava/util/List<Ljava/security/cert/Extension;>;
            1   69     3        request  Lsun/security/provider/certpath/OCSPRequest;
            2   69     4          bytes  [B
            3   69     5             in  Ljava/io/InputStream;
            4   69     6            out  Ljava/io/OutputStream;
            5   69     7       response  [B
            6   45     8            url  Ljava/net/URL;
            9   45     9            con  Ljava/net/HttpURLConnection;
           30   45    10  contentLength  I
           36   45    11          total  I
           38   43    12          count  I
           51   52    14            ioe  Ljava/io/IOException;
           62   63    14            ioe  Ljava/io/IOException;
           56   57    14            ioe  Ljava/io/IOException;
           67   68    14            ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           5    46      46  any
          48    49      50  Class java.io.IOException
          53    54      55  Class java.io.IOException
          59    60      61  Class java.io.IOException
          64    65      66  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 302
            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 303
      StackMap locals:
      StackMap stack: java.security.cert.CertificateException
            pop
         3: .line 305
            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 313
            aload 0 /* certImpl */
            invokevirtual sun.security.x509.X509CertImpl.getAuthorityInfoAccessExtension:()Lsun/security/x509/AuthorityInfoAccessExtension;
         1: .line 312
            astore 1 /* aia */
        start local 1 // sun.security.x509.AuthorityInfoAccessExtension aia
         2: .line 314
            aload 1 /* aia */
            ifnonnull 4
         3: .line 315
            aconst_null
            areturn
         4: .line 318
      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 319
            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 320
            aload 3 /* description */
            invokevirtual sun.security.x509.AccessDescription.getAccessMethod:()Lsun/security/util/ObjectIdentifier;
         8: .line 321
            getstatic sun.security.x509.AccessDescription.Ad_OCSP_Id:Lsun/security/util/ObjectIdentifier;
         9: .line 320
            invokevirtual sun.security.util.ObjectIdentifier.equals:(Ljava/lang/Object;)Z
        10: .line 321
            ifeq 15
        11: .line 323
            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 324
            aload 5 /* generalName */
            invokevirtual sun.security.x509.GeneralName.getType:()I
            bipush 6
            if_icmpne 15
        13: .line 325
            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 326
            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 319
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        16: .line 330
            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