final class com.sun.security.sasl.digest.DigestMD5Client extends com.sun.security.sasl.digest.DigestMD5Base implements javax.security.sasl.SaslClient
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.security.sasl.digest.DigestMD5Client
  super_class: com.sun.security.sasl.digest.DigestMD5Base
{
  private static final java.lang.String MY_CLASS_NAME;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String CIPHER_PROPERTY;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "com.sun.security.sasl.digest.cipher"

  private static final java.lang.String[] DIRECTIVE_KEY;
    descriptor: [Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

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

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

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

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

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

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

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

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

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

  private int nonceCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String specifiedCipher;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private byte[] cnonce;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String username;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private char[] passwd;
    descriptor: [C
    flags: (0x0002) ACC_PRIVATE

  private byte[] authzidBytes;
    descriptor: [B
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=4, locals=0, args_size=0
         0: .line 99
            ldc Lcom/sun/security/sasl/digest/DigestMD5Client;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            putstatic com.sun.security.sasl.digest.DigestMD5Client.MY_CLASS_NAME:Ljava/lang/String;
         1: .line 106
            bipush 9
            anewarray java.lang.String
            dup
            iconst_0
         2: .line 107
            ldc "realm"
            aastore
            dup
            iconst_1
         3: .line 108
            ldc "qop"
            aastore
            dup
            iconst_2
         4: .line 109
            ldc "algorithm"
            aastore
            dup
            iconst_3
         5: .line 110
            ldc "nonce"
            aastore
            dup
            iconst_4
         6: .line 111
            ldc "maxbuf"
            aastore
            dup
            iconst_5
         7: .line 112
            ldc "charset"
            aastore
            dup
            bipush 6
         8: .line 113
            ldc "cipher"
            aastore
            dup
            bipush 7
         9: .line 114
            ldc "rspauth"
            aastore
            dup
            bipush 8
        10: .line 115
            ldc "stale"
            aastore
        11: .line 106
            putstatic com.sun.security.sasl.digest.DigestMD5Client.DIRECTIVE_KEY:[Ljava/lang/String;
        12: .line 127
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.String, java.lang.String, java.lang.String, java.util.Map<java.lang.String, ?>, javax.security.auth.callback.CallbackHandler);
    descriptor: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljavax/security/auth/callback/CallbackHandler;)V
    flags: (0x0000) 
    Code:
      stack=7, locals=7, args_size=6
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // java.lang.String authzid
        start local 2 // java.lang.String protocol
        start local 3 // java.lang.String serverName
        start local 4 // java.util.Map props
        start local 5 // javax.security.auth.callback.CallbackHandler cbh
         0: .line 153
            aload 0 /* this */
            aload 4 /* props */
            getstatic com.sun.security.sasl.digest.DigestMD5Client.MY_CLASS_NAME:Ljava/lang/String;
            iconst_2
            new java.lang.StringBuilder
            dup
            aload 2 /* protocol */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc "/"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* serverName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 5 /* cbh */
            invokespecial com.sun.security.sasl.digest.DigestMD5Base.<init>:(Ljava/util/Map;Ljava/lang/String;ILjava/lang/String;Ljavax/security/auth/callback/CallbackHandler;)V
         1: .line 156
            aload 1 /* authzid */
            ifnull 9
         2: .line 157
            aload 0 /* this */
            aload 1 /* authzid */
            putfield com.sun.security.sasl.digest.DigestMD5Client.authzid:Ljava/lang/String;
         3: .line 159
            aload 0 /* this */
            aload 1 /* authzid */
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            putfield com.sun.security.sasl.digest.DigestMD5Client.authzidBytes:[B
         4: .line 161
            goto 9
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client java.lang.String java.lang.String java.lang.String java.util.Map javax.security.auth.callback.CallbackHandler
      StackMap stack: java.io.UnsupportedEncodingException
         5: astore 6 /* e */
        start local 6 // java.io.UnsupportedEncodingException e
         6: .line 162
            new javax.security.sasl.SaslException
            dup
         7: .line 163
            ldc "DIGEST-MD5: Error encoding authzid value into UTF-8"
            aload 6 /* e */
         8: .line 162
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.io.UnsupportedEncodingException e
         9: .line 167
      StackMap locals:
      StackMap stack:
            aload 4 /* props */
            ifnull 14
        10: .line 168
            aload 0 /* this */
            aload 4 /* props */
            ldc "com.sun.security.sasl.digest.cipher"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            putfield com.sun.security.sasl.digest.DigestMD5Client.specifiedCipher:Ljava/lang/String;
        11: .line 170
            getstatic com.sun.security.sasl.digest.DigestMD5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "DIGEST60:Explicitly specified cipher: {0}"
        12: .line 171
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.specifiedCipher:Ljava/lang/String;
        13: .line 170
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        14: .line 173
      StackMap locals:
      StackMap stack:
            return
        end local 5 // javax.security.auth.callback.CallbackHandler cbh
        end local 4 // java.util.Map props
        end local 3 // java.lang.String serverName
        end local 2 // java.lang.String protocol
        end local 1 // java.lang.String authzid
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   15     0        this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   15     1     authzid  Ljava/lang/String;
            0   15     2    protocol  Ljava/lang/String;
            0   15     3  serverName  Ljava/lang/String;
            0   15     4       props  Ljava/util/Map<Ljava/lang/String;*>;
            0   15     5         cbh  Ljavax/security/auth/callback/CallbackHandler;
            6    9     6           e  Ljava/io/UnsupportedEncodingException;
      Exception table:
        from    to  target  type
           3     4       5  Class java.io.UnsupportedEncodingException
    Exceptions:
      throws javax.security.sasl.SaslException
    Signature: (Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map<Ljava/lang/String;*>;Ljavax/security/auth/callback/CallbackHandler;)V
    MethodParameters:
            Name  Flags
      authzid     
      protocol    
      serverName  
      props       
      cbh         

  public boolean hasInitialResponse();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
         0: .line 181
            iconst_0
            ireturn
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/sasl/digest/DigestMD5Client;

  public byte[] evaluateChallenge(byte[]);
    descriptor: ([B)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[] challengeData
         0: .line 201
            aload 1 /* challengeData */
            arraylength
            sipush 2048
            if_icmple 6
         1: .line 202
            new javax.security.sasl.SaslException
            dup
         2: .line 203
            new java.lang.StringBuilder
            dup
            ldc "DIGEST-MD5: Invalid digest-challenge length. Got:  "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 204
            aload 1 /* challengeData */
            arraylength
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            ldc " Expected < "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            sipush 2048
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
         4: .line 203
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         5: .line 202
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 210
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.step:I
            tableswitch { // 2 - 3
                    2: 7
                    3: 26
              default: 44
          }
         7: .line 215
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            iconst_3
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 3 /* realmChoices */
        start local 3 // java.util.List realmChoices
         8: .line 216
            aload 1 /* challengeData */
            getstatic com.sun.security.sasl.digest.DigestMD5Client.DIRECTIVE_KEY:[Ljava/lang/String;
         9: .line 217
            aload 3 /* realmChoices */
            iconst_0
        10: .line 216
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.parseDirectives:([B[Ljava/lang/String;Ljava/util/List;I)[[B
            astore 2 /* challengeVal */
        start local 2 // byte[][] challengeVal
        11: .line 220
            aload 0 /* this */
            aload 2 /* challengeVal */
            aload 3 /* realmChoices */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.processChallenge:([[BLjava/util/List;)V
        12: .line 221
            aload 0 /* this */
            aload 2 /* challengeVal */
            iconst_1
            aaload
            aload 2 /* challengeVal */
            bipush 6
            aaload
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.checkQopSupport:([B[B)V
        13: .line 222
            aload 0 /* this */
            dup
            getfield com.sun.security.sasl.digest.DigestMD5Client.step:I
            iconst_1
            iadd
            putfield com.sun.security.sasl.digest.DigestMD5Client.step:I
        14: .line 223
            aload 0 /* this */
            aload 2 /* challengeVal */
            iconst_5
            aaload
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.generateClientResponse:([B)[B
        15: areturn
        16: .line 224
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[] byte[][] java.util.List
      StackMap stack: javax.security.sasl.SaslException
            astore 4 /* e */
        start local 4 // javax.security.sasl.SaslException e
        17: .line 225
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.digest.DigestMD5Client.step:I
        18: .line 226
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.clearPassword:()V
        19: .line 227
            aload 4 /* e */
            athrow
        end local 4 // javax.security.sasl.SaslException e
        20: .line 228
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 4 /* e */
        start local 4 // java.io.IOException e
        21: .line 229
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.digest.DigestMD5Client.step:I
        22: .line 230
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.clearPassword:()V
        23: .line 231
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Error generating digest response-value"
        24: .line 232
            aload 4 /* e */
        25: .line 231
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 4 // java.io.IOException e
        end local 3 // java.util.List realmChoices
        end local 2 // byte[][] challengeVal
        26: .line 239
      StackMap locals:
      StackMap stack:
            aload 1 /* challengeData */
            getstatic com.sun.security.sasl.digest.DigestMD5Client.DIRECTIVE_KEY:[Ljava/lang/String;
        27: .line 240
            aconst_null
            iconst_0
        28: .line 239
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.parseDirectives:([B[Ljava/lang/String;Ljava/util/List;I)[[B
            astore 2 /* challengeVal */
        start local 2 // byte[][] challengeVal
        29: .line 241
            aload 0 /* this */
            aload 2 /* challengeVal */
            bipush 7
            aaload
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.validateResponseValue:([B)V
        30: .line 245
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.integrity:Z
            ifeq 33
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.privacy:Z
            ifeq 33
        31: .line 246
            aload 0 /* this */
            new com.sun.security.sasl.digest.DigestMD5Base$DigestPrivacy
            dup
            aload 0 /* this */
            iconst_1
            invokespecial com.sun.security.sasl.digest.DigestMD5Base$DigestPrivacy.<init>:(Lcom/sun/security/sasl/digest/DigestMD5Base;Z)V
            putfield com.sun.security.sasl.digest.DigestMD5Client.secCtx:Lcom/sun/security/sasl/digest/SecurityCtx;
        32: .line 247
            goto 35
      StackMap locals: byte[][]
      StackMap stack:
        33: aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.integrity:Z
            ifeq 35
        34: .line 248
            aload 0 /* this */
            new com.sun.security.sasl.digest.DigestMD5Base$DigestIntegrity
            dup
            aload 0 /* this */
            iconst_1
            invokespecial com.sun.security.sasl.digest.DigestMD5Base$DigestIntegrity.<init>:(Lcom/sun/security/sasl/digest/DigestMD5Base;Z)V
            putfield com.sun.security.sasl.digest.DigestMD5Client.secCtx:Lcom/sun/security/sasl/digest/SecurityCtx;
        35: .line 253
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.clearPassword:()V
        36: .line 254
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.digest.DigestMD5Client.step:I
        37: .line 255
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.digest.DigestMD5Client.completed:Z
        38: .line 251
            aconst_null
            areturn
        end local 2 // byte[][] challengeVal
        39: .line 252
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[]
      StackMap stack: java.lang.Throwable
            astore 4
        40: .line 253
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.clearPassword:()V
        41: .line 254
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.digest.DigestMD5Client.step:I
        42: .line 255
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.digest.DigestMD5Client.completed:Z
        43: .line 256
            aload 4
            athrow
        44: .line 260
      StackMap locals:
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Client at illegal state"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // byte[] challengeData
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   45     0           this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   45     1  challengeData  [B
           11   26     2   challengeVal  [[B
           29   39     2   challengeVal  [[B
            8   26     3   realmChoices  Ljava/util/List<[B>;
           17   20     4              e  Ljavax/security/sasl/SaslException;
           21   26     4              e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
          11    15      16  Class javax.security.sasl.SaslException
          11    15      20  Class java.io.IOException
          26    35      39  any
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
               Name  Flags
      challengeData  

  private void processChallenge(byte[][], java.util.List<byte[]>);
    descriptor: ([[BLjava/util/List;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=8, args_size=3
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[][] challengeVal
        start local 2 // java.util.List realmChoices
         0: .line 278
            aload 1 /* challengeVal */
            iconst_5
            aaload
            ifnull 7
         1: .line 279
            ldc "utf-8"
            new java.lang.String
            dup
            aload 1 /* challengeVal */
            iconst_5
            aaload
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 5
         2: .line 280
            new javax.security.sasl.SaslException
            dup
            new java.lang.StringBuilder
            dup
            ldc "DIGEST-MD5: digest-challenge format violation. Unrecognised charset value: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         3: .line 282
            new java.lang.String
            dup
            aload 1 /* challengeVal */
            iconst_5
            aaload
            invokespecial java.lang.String.<init>:([B)V
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
         4: .line 280
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 284
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "UTF8"
            putfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
         6: .line 285
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.digest.DigestMD5Client.useUTF8:Z
         7: .line 290
      StackMap locals:
      StackMap stack:
            aload 1 /* challengeVal */
            iconst_2
            aaload
            ifnonnull 9
         8: .line 291
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Digest-challenge format violation: algorithm directive missing"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         9: .line 293
      StackMap locals:
      StackMap stack:
            ldc "md5-sess"
            new java.lang.String
            dup
            aload 1 /* challengeVal */
            iconst_2
            aaload
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 13
        10: .line 294
            new javax.security.sasl.SaslException
            dup
            new java.lang.StringBuilder
            dup
            ldc "DIGEST-MD5: Digest-challenge format violation. Invalid value for 'algorithm' directive: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        11: .line 296
            aload 1 /* challengeVal */
            iconst_2
            aaload
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        12: .line 294
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        13: .line 300
      StackMap locals:
      StackMap stack:
            aload 1 /* challengeVal */
            iconst_3
            aaload
            ifnonnull 15
        14: .line 301
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Digest-challenge format violation: nonce directive missing"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        15: .line 304
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* challengeVal */
            iconst_3
            aaload
            putfield com.sun.security.sasl.digest.DigestMD5Client.nonce:[B
        16: .line 309
            aconst_null
            astore 3 /* realmTokens */
        start local 3 // java.lang.String[] realmTokens
        17: .line 311
            aload 1 /* challengeVal */
            iconst_0
            aaload
            ifnull 29
        18: .line 312
            aload 2 /* realmChoices */
            ifnull 19
            aload 2 /* realmChoices */
            invokeinterface java.util.List.size:()I
            iconst_1
            if_icmpgt 21
        19: .line 314
      StackMap locals: java.lang.String[]
      StackMap stack:
            aload 0 /* this */
            new java.lang.String
            dup
            aload 1 /* challengeVal */
            iconst_0
            aaload
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
        20: .line 315
            goto 29
        21: .line 316
      StackMap locals:
      StackMap stack:
            aload 2 /* realmChoices */
            invokeinterface java.util.List.size:()I
            anewarray java.lang.String
            astore 3 /* realmTokens */
        22: .line 317
            iconst_0
            istore 4 /* i */
        start local 4 // int i
        23: goto 28
        24: .line 318
      StackMap locals: int
      StackMap stack:
            aload 3 /* realmTokens */
            iload 4 /* i */
        25: .line 319
            new java.lang.String
            dup
            aload 2 /* realmChoices */
            iload 4 /* i */
            invokeinterface java.util.List.get:(I)Ljava/lang/Object;
            checkcast byte[]
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
        26: .line 318
            aastore
        27: .line 317
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        28: iload 4 /* i */
            aload 3 /* realmTokens */
            arraylength
            if_icmplt 24
        end local 4 // int i
        29: .line 324
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.authzid:Ljava/lang/String;
            ifnonnull 31
        30: .line 325
            new javax.security.auth.callback.NameCallback
            dup
            ldc "DIGEST-MD5 authentication ID: "
            invokespecial javax.security.auth.callback.NameCallback.<init>:(Ljava/lang/String;)V
            goto 32
        31: .line 326
      StackMap locals:
      StackMap stack:
            new javax.security.auth.callback.NameCallback
            dup
            ldc "DIGEST-MD5 authentication ID: "
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.authzid:Ljava/lang/String;
            invokespecial javax.security.auth.callback.NameCallback.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        32: .line 324
      StackMap locals:
      StackMap stack: javax.security.auth.callback.NameCallback
            astore 4 /* ncb */
        start local 4 // javax.security.auth.callback.NameCallback ncb
        33: .line 328
            new javax.security.auth.callback.PasswordCallback
            dup
            ldc "DIGEST-MD5 password: "
            iconst_0
            invokespecial javax.security.auth.callback.PasswordCallback.<init>:(Ljava/lang/String;Z)V
        34: .line 327
            astore 5 /* pcb */
        start local 5 // javax.security.auth.callback.PasswordCallback pcb
        35: .line 330
            aload 3 /* realmTokens */
            ifnonnull 44
        36: .line 334
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
            ifnonnull 37
            new javax.security.sasl.RealmCallback
            dup
            ldc "DIGEST-MD5 realm: "
            invokespecial javax.security.sasl.RealmCallback.<init>:(Ljava/lang/String;)V
            goto 38
        37: .line 335
      StackMap locals: javax.security.auth.callback.NameCallback javax.security.auth.callback.PasswordCallback
      StackMap stack:
            new javax.security.sasl.RealmCallback
            dup
            ldc "DIGEST-MD5 realm: "
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
            invokespecial javax.security.sasl.RealmCallback.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        38: .line 333
      StackMap locals:
      StackMap stack: javax.security.sasl.RealmCallback
            astore 6 /* tcb */
        start local 6 // javax.security.sasl.RealmCallback tcb
        39: .line 337
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.cbh:Ljavax/security/auth/callback/CallbackHandler;
            iconst_3
            anewarray javax.security.auth.callback.Callback
            dup
            iconst_0
            aload 6 /* tcb */
            aastore
            dup
            iconst_1
            aload 4 /* ncb */
            aastore
            dup
            iconst_2
            aload 5 /* pcb */
            aastore
            invokeinterface javax.security.auth.callback.CallbackHandler.handle:([Ljavax/security/auth/callback/Callback;)V
        40: .line 340
            aload 0 /* this */
            aload 6 /* tcb */
            invokevirtual javax.security.sasl.RealmCallback.getText:()Ljava/lang/String;
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
        41: .line 341
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
            ifnonnull 56
        42: .line 342
            aload 0 /* this */
            ldc ""
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
        end local 6 // javax.security.sasl.RealmCallback tcb
        43: .line 344
            goto 56
        44: .line 345
      StackMap locals:
      StackMap stack:
            new javax.security.sasl.RealmChoiceCallback
            dup
        45: .line 346
            ldc "DIGEST-MD5 realm: "
        46: .line 347
            aload 3 /* realmTokens */
        47: .line 348
            iconst_0
            iconst_0
        48: .line 345
            invokespecial javax.security.sasl.RealmChoiceCallback.<init>:(Ljava/lang/String;[Ljava/lang/String;IZ)V
            astore 6 /* ccb */
        start local 6 // javax.security.sasl.RealmChoiceCallback ccb
        49: .line 349
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.cbh:Ljavax/security/auth/callback/CallbackHandler;
            iconst_3
            anewarray javax.security.auth.callback.Callback
            dup
            iconst_0
            aload 6 /* ccb */
            aastore
            dup
            iconst_1
            aload 4 /* ncb */
            aastore
            dup
            iconst_2
            aload 5 /* pcb */
            aastore
            invokeinterface javax.security.auth.callback.CallbackHandler.handle:([Ljavax/security/auth/callback/Callback;)V
        50: .line 352
            aload 6 /* ccb */
            invokevirtual javax.security.sasl.RealmChoiceCallback.getSelectedIndexes:()[I
            astore 7 /* selected */
        start local 7 // int[] selected
        51: .line 353
            aload 7 /* selected */
            ifnull 54
        52: .line 354
            aload 7 /* selected */
            iconst_0
            iaload
            iflt 54
        53: .line 355
            aload 7 /* selected */
            iconst_0
            iaload
            aload 3 /* realmTokens */
            arraylength
            if_icmplt 55
        54: .line 356
      StackMap locals: javax.security.sasl.RealmChoiceCallback int[]
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Invalid realm chosen"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        55: .line 358
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 3 /* realmTokens */
            aload 7 /* selected */
            iconst_0
            iaload
            aaload
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
        end local 7 // int[] selected
        end local 6 // javax.security.sasl.RealmChoiceCallback ccb
        56: .line 361
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 5 /* pcb */
            invokevirtual javax.security.auth.callback.PasswordCallback.getPassword:()[C
            putfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
        57: .line 362
            aload 5 /* pcb */
            invokevirtual javax.security.auth.callback.PasswordCallback.clearPassword:()V
        58: .line 363
            aload 0 /* this */
            aload 4 /* ncb */
            invokevirtual javax.security.auth.callback.NameCallback.getName:()Ljava/lang/String;
            putfield com.sun.security.sasl.digest.DigestMD5Client.username:Ljava/lang/String;
        end local 5 // javax.security.auth.callback.PasswordCallback pcb
        end local 4 // javax.security.auth.callback.NameCallback ncb
        end local 3 // java.lang.String[] realmTokens
        59: .line 365
            goto 70
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[][] java.util.List
      StackMap stack: javax.security.sasl.SaslException
        60: astore 3 /* se */
        start local 3 // javax.security.sasl.SaslException se
        61: .line 366
            aload 3 /* se */
            athrow
        end local 3 // javax.security.sasl.SaslException se
        62: .line 368
      StackMap locals:
      StackMap stack: javax.security.auth.callback.UnsupportedCallbackException
            astore 3 /* e */
        start local 3 // javax.security.auth.callback.UnsupportedCallbackException e
        63: .line 369
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Cannot perform callback to acquire realm, authentication ID or password"
        64: .line 370
            aload 3 /* e */
        65: .line 369
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // javax.security.auth.callback.UnsupportedCallbackException e
        66: .line 372
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 3 /* e */
        start local 3 // java.io.IOException e
        67: .line 373
            new javax.security.sasl.SaslException
            dup
        68: .line 374
            ldc "DIGEST-MD5: Error acquiring realm, authentication ID or password"
            aload 3 /* e */
        69: .line 373
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.io.IOException e
        70: .line 377
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.username:Ljava/lang/String;
            ifnull 71
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
            ifnonnull 74
        71: .line 378
      StackMap locals:
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
        72: .line 379
            ldc "DIGEST-MD5: authentication ID and password must be specified"
        73: .line 378
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        74: .line 384
      StackMap locals:
      StackMap stack:
            aload 1 /* challengeVal */
            iconst_4
            aaload
            ifnonnull 75
            ldc 65536
            goto 76
        75: .line 385
      StackMap locals:
      StackMap stack:
            new java.lang.String
            dup
            aload 1 /* challengeVal */
            iconst_4
            aaload
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            invokestatic java.lang.Integer.parseInt:(Ljava/lang/String;)I
        76: .line 383
      StackMap locals:
      StackMap stack: int
            istore 3 /* srvMaxBufSize */
        start local 3 // int srvMaxBufSize
        77: .line 386
            aload 0 /* this */
        78: .line 387
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.sendMaxBufSize:I
            ifne 79
            iload 3 /* srvMaxBufSize */
            goto 80
        79: .line 388
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[][] java.util.List int
      StackMap stack: com.sun.security.sasl.digest.DigestMD5Client
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.sendMaxBufSize:I
            iload 3 /* srvMaxBufSize */
            invokestatic java.lang.Math.min:(II)I
        80: .line 386
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[][] java.util.List int
      StackMap stack: com.sun.security.sasl.digest.DigestMD5Client int
            putfield com.sun.security.sasl.digest.DigestMD5Client.sendMaxBufSize:I
        81: .line 389
            return
        end local 3 // int srvMaxBufSize
        end local 2 // java.util.List realmChoices
        end local 1 // byte[][] challengeVal
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   82     0           this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   82     1   challengeVal  [[B
            0   82     2   realmChoices  Ljava/util/List<[B>;
           17   59     3    realmTokens  [Ljava/lang/String;
           23   29     4              i  I
           33   59     4            ncb  Ljavax/security/auth/callback/NameCallback;
           35   59     5            pcb  Ljavax/security/auth/callback/PasswordCallback;
           39   43     6            tcb  Ljavax/security/sasl/RealmCallback;
           49   56     6            ccb  Ljavax/security/sasl/RealmChoiceCallback;
           51   56     7       selected  [I
           61   62     3             se  Ljavax/security/sasl/SaslException;
           63   66     3              e  Ljavax/security/auth/callback/UnsupportedCallbackException;
           67   70     3              e  Ljava/io/IOException;
           77   82     3  srvMaxBufSize  I
      Exception table:
        from    to  target  type
          16    59      60  Class javax.security.sasl.SaslException
          16    59      62  Class javax.security.auth.callback.UnsupportedCallbackException
          16    59      66  Class java.io.IOException
    Exceptions:
      throws javax.security.sasl.SaslException, java.io.UnsupportedEncodingException
    Signature: ([[BLjava/util/List<[B>;)V
    MethodParameters:
              Name  Flags
      challengeVal  
      realmChoices  

  private void checkQopSupport(byte[], byte[]);
    descriptor: ([B[B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=7, args_size=3
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[] qopInChallenge
        start local 2 // byte[] ciphersInChallenge
         0: .line 404
            aload 1 /* qopInChallenge */
            ifnonnull 3
         1: .line 405
            ldc "auth"
            astore 3 /* qopOptions */
        start local 3 // java.lang.String qopOptions
         2: .line 406
            goto 4
        end local 3 // java.lang.String qopOptions
         3: .line 407
      StackMap locals:
      StackMap stack:
            new java.lang.String
            dup
            aload 1 /* qopInChallenge */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            astore 3 /* qopOptions */
        start local 3 // java.lang.String qopOptions
         4: .line 411
      StackMap locals: java.lang.String
      StackMap stack:
            iconst_3
            anewarray java.lang.String
            astore 4 /* serverQopTokens */
        start local 4 // java.lang.String[] serverQopTokens
         5: .line 412
            aload 3 /* qopOptions */
            aload 4 /* serverQopTokens */
         6: .line 413
            iconst_1
         7: .line 412
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.parseQop:(Ljava/lang/String;[Ljava/lang/String;Z)[B
            astore 5 /* serverQop */
        start local 5 // byte[] serverQop
         8: .line 414
            aload 5 /* serverQop */
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.combineMasks:([B)B
            istore 6 /* serverAllQop */
        start local 6 // byte serverAllQop
         9: .line 416
            iload 6 /* serverAllQop */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.qop:[B
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.findPreferredMask:(B[B)B
            tableswitch { // 0 - 4
                    0: 10
                    1: 11
                    2: 13
                    3: 21
                    4: 17
              default: 21
          }
        10: .line 418
      StackMap locals: java.lang.String[] byte[] int
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: No common protection layer between client and server"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        11: .line 422
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "auth"
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedQop:Ljava/lang/String;
        12: .line 424
            goto 21
        13: .line 427
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "auth-int"
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedQop:Ljava/lang/String;
        14: .line 428
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.digest.DigestMD5Client.integrity:Z
        15: .line 429
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.sendMaxBufSize:I
            bipush 16
            isub
            putfield com.sun.security.sasl.digest.DigestMD5Client.rawSendSize:I
        16: .line 430
            goto 21
        17: .line 433
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "auth-conf"
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedQop:Ljava/lang/String;
        18: .line 434
            aload 0 /* this */
            aload 0 /* this */
            iconst_1
            dup_x1
            putfield com.sun.security.sasl.digest.DigestMD5Client.integrity:Z
            putfield com.sun.security.sasl.digest.DigestMD5Client.privacy:Z
        19: .line 435
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.sendMaxBufSize:I
            bipush 26
            isub
            putfield com.sun.security.sasl.digest.DigestMD5Client.rawSendSize:I
        20: .line 436
            aload 0 /* this */
            aload 2 /* ciphersInChallenge */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.checkStrengthSupport:([B)V
        21: .line 440
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.digest.DigestMD5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 25
        22: .line 441
            getstatic com.sun.security.sasl.digest.DigestMD5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "DIGEST61:Raw send size: {0}"
        23: .line 442
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.rawSendSize:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
        24: .line 441
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        25: .line 444
      StackMap locals:
      StackMap stack:
            return
        end local 6 // byte serverAllQop
        end local 5 // byte[] serverQop
        end local 4 // java.lang.String[] serverQopTokens
        end local 3 // java.lang.String qopOptions
        end local 2 // byte[] ciphersInChallenge
        end local 1 // byte[] qopInChallenge
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   26     0                this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   26     1      qopInChallenge  [B
            0   26     2  ciphersInChallenge  [B
            2    3     3          qopOptions  Ljava/lang/String;
            4   26     3          qopOptions  Ljava/lang/String;
            5   26     4     serverQopTokens  [Ljava/lang/String;
            8   26     5           serverQop  [B
            9   26     6        serverAllQop  B
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                    Name  Flags
      qopInChallenge      
      ciphersInChallenge  

  private void checkStrengthSupport(byte[]);
    descriptor: ([B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=11, args_size=2
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[] ciphersInChallenge
         0: .line 460
            aload 1 /* ciphersInChallenge */
            ifnonnull 2
         1: .line 461
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: server did not specify cipher to use for 'auth-conf'"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 466
      StackMap locals:
      StackMap stack:
            new java.lang.String
            dup
            aload 1 /* ciphersInChallenge */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
            astore 2 /* cipherOptions */
        start local 2 // java.lang.String cipherOptions
         3: .line 467
            new java.util.StringTokenizer
            dup
            aload 2 /* cipherOptions */
            ldc ", \t\n"
            invokespecial java.util.StringTokenizer.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            astore 3 /* parser */
        start local 3 // java.util.StringTokenizer parser
         4: .line 468
            aload 3 /* parser */
            invokevirtual java.util.StringTokenizer.countTokens:()I
            istore 4 /* tokenCount */
        start local 4 // int tokenCount
         5: .line 469
            aconst_null
            astore 5 /* token */
        start local 5 // java.lang.String token
         6: .line 470
            iconst_5
            newarray 8
            astore 6 /* serverCiphers */
        start local 6 // byte[] serverCiphers
         7: .line 475
            aload 6 /* serverCiphers */
            arraylength
            anewarray java.lang.String
            astore 7 /* serverCipherStrs */
        start local 7 // java.lang.String[] serverCipherStrs
         8: .line 478
            iconst_0
            istore 8 /* i */
        start local 8 // int i
         9: goto 20
        10: .line 479
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[] java.lang.String java.util.StringTokenizer int java.lang.String byte[] java.lang.String[] int
      StackMap stack:
            aload 3 /* parser */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            astore 5 /* token */
        11: .line 480
            iconst_0
            istore 9 /* j */
        start local 9 // int j
        12: goto 18
        13: .line 481
      StackMap locals: int
      StackMap stack:
            aload 5 /* token */
            getstatic com.sun.security.sasl.digest.DigestMD5Client.CIPHER_TOKENS:[Ljava/lang/String;
            iload 9 /* j */
            aaload
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 17
        14: .line 482
            aload 6 /* serverCiphers */
            iload 9 /* j */
            dup2
            baload
            getstatic com.sun.security.sasl.digest.DigestMD5Client.CIPHER_MASKS:[B
            iload 9 /* j */
            baload
            ior
            i2b
            bastore
        15: .line 483
            aload 7 /* serverCipherStrs */
            iload 9 /* j */
            aload 5 /* token */
            aastore
        16: .line 484
            getstatic com.sun.security.sasl.digest.DigestMD5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "DIGEST62:Server supports {0}"
            aload 5 /* token */
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        17: .line 480
      StackMap locals:
      StackMap stack:
            iinc 9 /* j */ 1
      StackMap locals:
      StackMap stack:
        18: iload 9 /* j */
            getstatic com.sun.security.sasl.digest.DigestMD5Client.CIPHER_TOKENS:[Ljava/lang/String;
            arraylength
            if_icmplt 13
        end local 9 // int j
        19: .line 478
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        20: iload 8 /* i */
            iload 4 /* tokenCount */
            if_icmplt 10
        end local 8 // int i
        21: .line 490
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.getPlatformCiphers:()[B
            astore 8 /* clntCiphers */
        start local 8 // byte[] clntCiphers
        22: .line 493
            iconst_0
            istore 9 /* inter */
        start local 9 // byte inter
        23: .line 494
            iconst_0
            istore 10 /* i */
        start local 10 // int i
        24: goto 28
        25: .line 495
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[] java.lang.String java.util.StringTokenizer int java.lang.String byte[] java.lang.String[] byte[] int int
      StackMap stack:
            aload 6 /* serverCiphers */
            iload 10 /* i */
            dup2
            baload
            aload 8 /* clntCiphers */
            iload 10 /* i */
            baload
            iand
            i2b
            bastore
        26: .line 496
            iload 9 /* inter */
            aload 6 /* serverCiphers */
            iload 10 /* i */
            baload
            ior
            i2b
            istore 9 /* inter */
        27: .line 494
            iinc 10 /* i */ 1
      StackMap locals:
      StackMap stack:
        28: iload 10 /* i */
            aload 6 /* serverCiphers */
            arraylength
            if_icmplt 25
        end local 10 // int i
        29: .line 499
            iload 9 /* inter */
            ifne 35
        30: .line 500
            new javax.security.sasl.SaslException
            dup
        31: .line 501
            new java.lang.StringBuilder
            dup
            ldc "DIGEST-MD5: Client supports none of these cipher suites: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        32: .line 502
            aload 2 /* cipherOptions */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        33: .line 501
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 500
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        35: .line 508
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            aload 6 /* serverCiphers */
            aload 7 /* serverCipherStrs */
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.findCipherAndStrength:([B[Ljava/lang/String;)Ljava/lang/String;
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedCipher:Ljava/lang/String;
        36: .line 510
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedCipher:Ljava/lang/String;
            ifnonnull 38
        37: .line 511
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Unable to negotiate a strength level for 'auth-conf'"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        38: .line 514
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.digest.DigestMD5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "DIGEST63:Cipher suite: {0}"
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedCipher:Ljava/lang/String;
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        39: .line 515
            return
        end local 9 // byte inter
        end local 8 // byte[] clntCiphers
        end local 7 // java.lang.String[] serverCipherStrs
        end local 6 // byte[] serverCiphers
        end local 5 // java.lang.String token
        end local 4 // int tokenCount
        end local 3 // java.util.StringTokenizer parser
        end local 2 // java.lang.String cipherOptions
        end local 1 // byte[] ciphersInChallenge
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   40     0                this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   40     1  ciphersInChallenge  [B
            3   40     2       cipherOptions  Ljava/lang/String;
            4   40     3              parser  Ljava/util/StringTokenizer;
            5   40     4          tokenCount  I
            6   40     5               token  Ljava/lang/String;
            7   40     6       serverCiphers  [B
            8   40     7    serverCipherStrs  [Ljava/lang/String;
            9   21     8                   i  I
           12   19     9                   j  I
           22   40     8         clntCiphers  [B
           23   40     9               inter  B
           24   29    10                   i  I
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                    Name  Flags
      ciphersInChallenge  

  private java.lang.String findCipherAndStrength(byte[], java.lang.String[]);
    descriptor: ([B[Ljava/lang/String;)Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[] supportedCiphers
        start local 2 // java.lang.String[] tokens
         0: .line 529
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         1: goto 19
         2: .line 530
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[] java.lang.String[] top int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.strength:[B
            iload 4 /* i */
            baload
            dup
            istore 3 /* s */
        start local 3 // byte s
         3: ifeq 18
         4: .line 531
            iconst_0
            istore 5 /* j */
        start local 5 // int j
         5: goto 17
         6: .line 536
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[] java.lang.String[] int int int
      StackMap stack:
            iload 3 /* s */
            aload 1 /* supportedCiphers */
            iload 5 /* j */
            baload
            if_icmpne 16
         7: .line 537
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.specifiedCipher:Ljava/lang/String;
            ifnull 9
         8: .line 538
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.specifiedCipher:Ljava/lang/String;
            aload 2 /* tokens */
            iload 5 /* j */
            aaload
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 16
         9: .line 539
      StackMap locals:
      StackMap stack:
            iload 3 /* s */
            tableswitch { // 1 - 4
                    1: 14
                    2: 12
                    3: 15
                    4: 10
              default: 15
          }
        10: .line 541
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "high"
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedStrength:Ljava/lang/String;
        11: .line 542
            goto 15
        12: .line 544
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "medium"
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedStrength:Ljava/lang/String;
        13: .line 545
            goto 15
        14: .line 547
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc "low"
            putfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedStrength:Ljava/lang/String;
        15: .line 551
      StackMap locals:
      StackMap stack:
            aload 2 /* tokens */
            iload 5 /* j */
            aaload
            areturn
        16: .line 531
      StackMap locals:
      StackMap stack:
            iinc 5 /* j */ 1
      StackMap locals:
      StackMap stack:
        17: iload 5 /* j */
            aload 1 /* supportedCiphers */
            arraylength
            if_icmplt 6
        end local 5 // int j
        18: .line 529
      StackMap locals:
      StackMap stack:
            iinc 4 /* i */ 1
        end local 3 // byte s
      StackMap locals: com.sun.security.sasl.digest.DigestMD5Client byte[] java.lang.String[] top int
      StackMap stack:
        19: iload 4 /* i */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.strength:[B
            arraylength
            if_icmplt 2
        end local 4 // int i
        20: .line 557
            aconst_null
            areturn
        end local 2 // java.lang.String[] tokens
        end local 1 // byte[] supportedCiphers
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   21     0              this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   21     1  supportedCiphers  [B
            0   21     2            tokens  [Ljava/lang/String;
            3   19     3                 s  B
            1   20     4                 i  I
            5   18     5                 j  I
    MethodParameters:
                  Name  Flags
      supportedCiphers  
      tokens            

  private byte[] generateClientResponse(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=12, locals=4, args_size=2
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[] charset
         0: .line 576
            new java.io.ByteArrayOutputStream
            dup
            invokespecial java.io.ByteArrayOutputStream.<init>:()V
            astore 2 /* digestResp */
        start local 2 // java.io.ByteArrayOutputStream digestResp
         1: .line 578
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.useUTF8:Z
            ifeq 5
         2: .line 579
            aload 2 /* digestResp */
            ldc "charset="
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
         3: .line 580
            aload 2 /* digestResp */
            aload 1 /* charset */
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
         4: .line 581
            aload 2 /* digestResp */
            bipush 44
            invokevirtual java.io.ByteArrayOutputStream.write:(I)V
         5: .line 584
      StackMap locals: java.io.ByteArrayOutputStream
      StackMap stack:
            aload 2 /* digestResp */
            new java.lang.StringBuilder
            dup
            ldc "username=\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
         6: .line 585
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.username:Ljava/lang/String;
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.quotedStringValue:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\","
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
         7: .line 584
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
         8: .line 587
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
            invokevirtual java.lang.String.length:()I
            ifle 12
         9: .line 588
            aload 2 /* digestResp */
            new java.lang.StringBuilder
            dup
            ldc "realm=\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        10: .line 589
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.quotedStringValue:(Ljava/lang/String;)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\","
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
        11: .line 588
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        12: .line 592
      StackMap locals:
      StackMap stack:
            aload 2 /* digestResp */
            ldc "nonce=\""
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        13: .line 593
            aload 2 /* digestResp */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonce:[B
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.writeQuotedStringValue:(Ljava/io/ByteArrayOutputStream;[B)V
        14: .line 594
            aload 2 /* digestResp */
            bipush 34
            invokevirtual java.io.ByteArrayOutputStream.write:(I)V
        15: .line 595
            aload 2 /* digestResp */
            bipush 44
            invokevirtual java.io.ByteArrayOutputStream.write:(I)V
        16: .line 597
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonce:[B
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.getNonceCount:([B)I
            putfield com.sun.security.sasl.digest.DigestMD5Client.nonceCount:I
        17: .line 598
            aload 2 /* digestResp */
            new java.lang.StringBuilder
            dup
            ldc "nc="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        18: .line 599
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonceCount:I
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.nonceCountToHex:(I)Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ","
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
        19: .line 598
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        20: .line 601
            aload 0 /* this */
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.generateNonce:()[B
            putfield com.sun.security.sasl.digest.DigestMD5Client.cnonce:[B
        21: .line 602
            aload 2 /* digestResp */
            ldc "cnonce=\""
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        22: .line 603
            aload 2 /* digestResp */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.cnonce:[B
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.writeQuotedStringValue:(Ljava/io/ByteArrayOutputStream;[B)V
        23: .line 604
            aload 2 /* digestResp */
            ldc "\","
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        24: .line 605
            aload 2 /* digestResp */
            new java.lang.StringBuilder
            dup
            ldc "digest-uri=\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.digestUri:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\","
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        25: .line 607
            aload 2 /* digestResp */
            ldc "maxbuf="
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        26: .line 608
            aload 2 /* digestResp */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.recvMaxBufSize:I
            invokestatic java.lang.String.valueOf:(I)Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        27: .line 609
            aload 2 /* digestResp */
            bipush 44
            invokevirtual java.io.ByteArrayOutputStream.write:(I)V
        28: .line 612
            aload 2 /* digestResp */
            ldc "response="
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        29: .line 613
            aload 2 /* digestResp */
            aload 0 /* this */
            ldc "AUTHENTICATE"
        30: .line 614
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.digestUri:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedQop:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.username:Ljava/lang/String;
        31: .line 615
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonce:[B
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.cnonce:[B
        32: .line 616
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonceCount:I
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.authzidBytes:[B
        33: .line 613
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.generateResponseValue:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[C[B[BI[B)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        34: .line 617
            aload 2 /* digestResp */
            bipush 44
            invokevirtual java.io.ByteArrayOutputStream.write:(I)V
        35: .line 618
            goto 40
      StackMap locals:
      StackMap stack: java.lang.Exception
        36: astore 3 /* e */
        start local 3 // java.lang.Exception e
        37: .line 619
            new javax.security.sasl.SaslException
            dup
        38: .line 620
            ldc "DIGEST-MD5: Error generating response value"
            aload 3 /* e */
        39: .line 619
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 3 // java.lang.Exception e
        40: .line 623
      StackMap locals:
      StackMap stack:
            aload 2 /* digestResp */
            new java.lang.StringBuilder
            dup
            ldc "qop="
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedQop:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        41: .line 625
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedCipher:Ljava/lang/String;
            ifnull 43
        42: .line 626
            aload 2 /* digestResp */
            new java.lang.StringBuilder
            dup
            ldc ",cipher=\""
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedCipher:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "\""
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        43: .line 629
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.authzidBytes:[B
            ifnull 47
        44: .line 630
            aload 2 /* digestResp */
            ldc ",authzid=\""
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        45: .line 631
            aload 2 /* digestResp */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.authzidBytes:[B
            invokestatic com.sun.security.sasl.digest.DigestMD5Client.writeQuotedStringValue:(Ljava/io/ByteArrayOutputStream;[B)V
        46: .line 632
            aload 2 /* digestResp */
            ldc "\""
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.encoding:Ljava/lang/String;
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            invokevirtual java.io.ByteArrayOutputStream.write:([B)V
        47: .line 635
      StackMap locals:
      StackMap stack:
            aload 2 /* digestResp */
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            sipush 4096
            if_icmple 51
        48: .line 636
            new javax.security.sasl.SaslException
            dup
            new java.lang.StringBuilder
            dup
            ldc "DIGEST-MD5: digest-response size too large. Length: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        49: .line 637
            aload 2 /* digestResp */
            invokevirtual java.io.ByteArrayOutputStream.size:()I
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        50: .line 636
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        51: .line 639
      StackMap locals:
      StackMap stack:
            aload 2 /* digestResp */
            invokevirtual java.io.ByteArrayOutputStream.toByteArray:()[B
            areturn
        end local 2 // java.io.ByteArrayOutputStream digestResp
        end local 1 // byte[] charset
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   52     0        this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   52     1     charset  [B
            1   52     2  digestResp  Ljava/io/ByteArrayOutputStream;
           37   40     3           e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          28    35      36  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      charset  

  private void validateResponseValue(byte[]);
    descriptor: ([B)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=11, locals=3, args_size=2
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
        start local 1 // byte[] fromServer
         0: .line 657
            aload 1 /* fromServer */
            ifnonnull 2
         1: .line 658
            new javax.security.sasl.SaslException
            dup
            ldc "DIGEST-MD5: Authenication failed. Expecting 'rspauth' authentication success message"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 663
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            ldc ""
         3: .line 664
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.digestUri:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedQop:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.username:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.negotiatedRealm:Ljava/lang/String;
         4: .line 665
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonce:[B
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.cnonce:[B
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.nonceCount:I
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.authzidBytes:[B
         5: .line 663
            invokevirtual com.sun.security.sasl.digest.DigestMD5Client.generateResponseValue:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[C[B[BI[B)[B
            astore 2 /* expected */
        start local 2 // byte[] expected
         6: .line 666
            aload 2 /* expected */
            aload 1 /* fromServer */
            invokestatic java.util.Arrays.equals:([B[B)Z
            ifne 18
         7: .line 668
            new javax.security.sasl.SaslException
            dup
         8: .line 669
            ldc "Server's rspauth value does not match what client expects"
         9: .line 668
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        end local 2 // byte[] expected
        10: .line 671
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 2 /* e */
        start local 2 // java.security.NoSuchAlgorithmException e
        11: .line 672
            new javax.security.sasl.SaslException
            dup
        12: .line 673
            ldc "Problem generating response value for verification"
            aload 2 /* e */
        13: .line 672
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.NoSuchAlgorithmException e
        14: .line 674
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
        15: .line 675
            new javax.security.sasl.SaslException
            dup
        16: .line 676
            ldc "Problem generating response value for verification"
            aload 2 /* e */
        17: .line 675
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        18: .line 678
      StackMap locals:
      StackMap stack:
            return
        end local 1 // byte[] fromServer
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   19     0        this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            0   19     1  fromServer  [B
            6   10     2    expected  [B
           11   14     2           e  Ljava/security/NoSuchAlgorithmException;
           15   18     2           e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           2    10      10  Class java.security.NoSuchAlgorithmException
           2    10      14  Class java.io.IOException
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
            Name  Flags
      fromServer  

  private static int getNonceCount(byte[]);
    descriptor: ([B)I
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // byte[] nonceValue
         0: .line 689
            iconst_1
            ireturn
        end local 0 // byte[] nonceValue
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0  nonceValue  [B
    MethodParameters:
            Name  Flags
      nonceValue  

  private void clearPassword();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // com.sun.security.sasl.digest.DigestMD5Client this
         0: .line 693
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
            ifnull 7
         1: .line 694
            iconst_0
            istore 1 /* i */
        start local 1 // int i
         2: goto 5
         3: .line 695
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
            iload 1 /* i */
            iconst_0
            castore
         4: .line 694
            iinc 1 /* i */ 1
      StackMap locals:
      StackMap stack:
         5: iload 1 /* i */
            aload 0 /* this */
            getfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
            arraylength
            if_icmplt 3
        end local 1 // int i
         6: .line 697
            aload 0 /* this */
            aconst_null
            putfield com.sun.security.sasl.digest.DigestMD5Client.passwd:[C
         7: .line 699
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.security.sasl.digest.DigestMD5Client this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lcom/sun/security/sasl/digest/DigestMD5Client;
            2    6     1     i  I
}
SourceFile: "DigestMD5Client.java"
InnerClasses:
  DigestIntegrity = com.sun.security.sasl.digest.DigestMD5Base$DigestIntegrity of com.sun.security.sasl.digest.DigestMD5Base
  final DigestPrivacy = com.sun.security.sasl.digest.DigestMD5Base$DigestPrivacy of com.sun.security.sasl.digest.DigestMD5Base