final class com.sun.security.sasl.CramMD5Server extends com.sun.security.sasl.CramMD5Base implements javax.security.sasl.SaslServer
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.security.sasl.CramMD5Server
  super_class: com.sun.security.sasl.CramMD5Base
{
  private java.lang.String fqdn;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

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

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

  private javax.security.auth.callback.CallbackHandler cbh;
    descriptor: Ljavax/security/auth/callback/CallbackHandler;
    flags: (0x0002) ACC_PRIVATE

  void <init>(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/util/Map;Ljavax/security/auth/callback/CallbackHandler;)V
    flags: (0x0000) 
    Code:
      stack=3, locals=5, args_size=5
        start local 0 // com.sun.security.sasl.CramMD5Server this
        start local 1 // java.lang.String protocol
        start local 2 // java.lang.String serverFqdn
        start local 3 // java.util.Map props
        start local 4 // javax.security.auth.callback.CallbackHandler cbh
         0: .line 70
            aload 0 /* this */
            invokespecial com.sun.security.sasl.CramMD5Base.<init>:()V
         1: .line 56
            aload 0 /* this */
            aconst_null
            putfield com.sun.security.sasl.CramMD5Server.challengeData:[B
         2: .line 72
            aload 2 /* serverFqdn */
            ifnonnull 6
         3: .line 73
            new javax.security.sasl.SaslException
            dup
         4: .line 74
            ldc "CRAM-MD5: fully qualified server name must be specified"
         5: .line 73
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 77
      StackMap locals: com.sun.security.sasl.CramMD5Server java.lang.String java.lang.String java.util.Map javax.security.auth.callback.CallbackHandler
      StackMap stack:
            aload 0 /* this */
            aload 2 /* serverFqdn */
            putfield com.sun.security.sasl.CramMD5Server.fqdn:Ljava/lang/String;
         7: .line 78
            aload 0 /* this */
            aload 4 /* cbh */
            putfield com.sun.security.sasl.CramMD5Server.cbh:Ljavax/security/auth/callback/CallbackHandler;
         8: .line 79
            return
        end local 4 // javax.security.auth.callback.CallbackHandler cbh
        end local 3 // java.util.Map props
        end local 2 // java.lang.String serverFqdn
        end local 1 // java.lang.String protocol
        end local 0 // com.sun.security.sasl.CramMD5Server this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    9     0        this  Lcom/sun/security/sasl/CramMD5Server;
            0    9     1    protocol  Ljava/lang/String;
            0    9     2  serverFqdn  Ljava/lang/String;
            0    9     3       props  Ljava/util/Map<Ljava/lang/String;*>;
            0    9     4         cbh  Ljavax/security/auth/callback/CallbackHandler;
    Exceptions:
      throws javax.security.sasl.SaslException
    Signature: (Ljava/lang/String;Ljava/lang/String;Ljava/util/Map<Ljava/lang/String;*>;Ljavax/security/auth/callback/CallbackHandler;)V
    MethodParameters:
            Name  Flags
      protocol    
      serverFqdn  
      props       
      cbh         

  public byte[] evaluateResponse(byte[]);
    descriptor: ([B)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=13, args_size=2
        start local 0 // com.sun.security.sasl.CramMD5Server this
        start local 1 // byte[] responseData
         0: .line 99
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.completed:Z
            ifeq 4
         1: .line 100
            new java.lang.IllegalStateException
            dup
         2: .line 101
            ldc "CRAM-MD5 authentication already completed"
         3: .line 100
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 104
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.aborted:Z
            ifeq 8
         5: .line 105
            new java.lang.IllegalStateException
            dup
         6: .line 106
            ldc "CRAM-MD5 authentication previously aborted due to error"
         7: .line 105
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         8: .line 110
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.challengeData:[B
            ifnonnull 32
         9: .line 111
            aload 1 /* responseData */
            arraylength
            ifeq 14
        10: .line 112
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
        11: .line 113
            new javax.security.sasl.SaslException
            dup
        12: .line 114
            ldc "CRAM-MD5 does not expect any initial response"
        13: .line 113
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 118
      StackMap locals:
      StackMap stack:
            new java.util.Random
            dup
            invokespecial java.util.Random.<init>:()V
            astore 2 /* random */
        start local 2 // java.util.Random random
        15: .line 119
            aload 2 /* random */
            invokevirtual java.util.Random.nextLong:()J
            lstore 3 /* rand */
        start local 3 // long rand
        16: .line 120
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 5 /* timestamp */
        start local 5 // long timestamp
        17: .line 122
            new java.lang.StringBuffer
            dup
            invokespecial java.lang.StringBuffer.<init>:()V
            astore 7 /* buf */
        start local 7 // java.lang.StringBuffer buf
        18: .line 123
            aload 7 /* buf */
            bipush 60
            invokevirtual java.lang.StringBuffer.append:(C)Ljava/lang/StringBuffer;
            pop
        19: .line 124
            aload 7 /* buf */
            lload 3 /* rand */
            invokevirtual java.lang.StringBuffer.append:(J)Ljava/lang/StringBuffer;
            pop
        20: .line 125
            aload 7 /* buf */
            bipush 46
            invokevirtual java.lang.StringBuffer.append:(C)Ljava/lang/StringBuffer;
            pop
        21: .line 126
            aload 7 /* buf */
            lload 5 /* timestamp */
            invokevirtual java.lang.StringBuffer.append:(J)Ljava/lang/StringBuffer;
            pop
        22: .line 127
            aload 7 /* buf */
            bipush 64
            invokevirtual java.lang.StringBuffer.append:(C)Ljava/lang/StringBuffer;
            pop
        23: .line 128
            aload 7 /* buf */
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.fqdn:Ljava/lang/String;
            invokevirtual java.lang.StringBuffer.append:(Ljava/lang/String;)Ljava/lang/StringBuffer;
            pop
        24: .line 129
            aload 7 /* buf */
            bipush 62
            invokevirtual java.lang.StringBuffer.append:(C)Ljava/lang/StringBuffer;
            pop
        25: .line 130
            aload 7 /* buf */
            invokevirtual java.lang.StringBuffer.toString:()Ljava/lang/String;
            astore 8 /* challengeStr */
        start local 8 // java.lang.String challengeStr
        26: .line 132
            getstatic com.sun.security.sasl.CramMD5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        27: .line 133
            ldc "CRAMSRV01:Generated challenge: {0}"
            aload 8 /* challengeStr */
        28: .line 132
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        29: .line 135
            aload 0 /* this */
            aload 8 /* challengeStr */
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            putfield com.sun.security.sasl.CramMD5Server.challengeData:[B
        30: .line 136
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.challengeData:[B
            invokevirtual byte[].clone:()Ljava/lang/Object;
            checkcast byte[]
        31: areturn
        end local 8 // java.lang.String challengeStr
        end local 7 // java.lang.StringBuffer buf
        end local 5 // long timestamp
        end local 3 // long rand
        end local 2 // java.util.Random random
        32: .line 140
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.CramMD5Server.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 37
        33: .line 141
            getstatic com.sun.security.sasl.CramMD5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        34: .line 142
            ldc "CRAMSRV02:Received response: {0}"
        35: .line 143
            new java.lang.String
            dup
            aload 1 /* responseData */
            ldc "UTF8"
            invokespecial java.lang.String.<init>:([BLjava/lang/String;)V
        36: .line 141
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        37: .line 147
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 2 /* ulen */
        start local 2 // int ulen
        38: .line 148
            iconst_0
            istore 3 /* i */
        start local 3 // int i
        39: goto 44
        40: .line 149
      StackMap locals: int int
      StackMap stack:
            aload 1 /* responseData */
            iload 3 /* i */
            baload
            bipush 32
            if_icmpne 43
        41: .line 150
            iload 3 /* i */
            istore 2 /* ulen */
        42: .line 151
            goto 45
        43: .line 148
      StackMap locals:
      StackMap stack:
            iinc 3 /* i */ 1
      StackMap locals:
      StackMap stack:
        44: iload 3 /* i */
            aload 1 /* responseData */
            arraylength
            if_icmplt 40
        end local 3 // int i
        45: .line 154
      StackMap locals:
      StackMap stack:
            iload 2 /* ulen */
            ifne 50
        46: .line 155
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
        47: .line 156
            new javax.security.sasl.SaslException
            dup
        48: .line 157
            ldc "CRAM-MD5: Invalid response; space missing"
        49: .line 156
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        50: .line 159
      StackMap locals:
      StackMap stack:
            new java.lang.String
            dup
            aload 1 /* responseData */
            iconst_0
            iload 2 /* ulen */
            ldc "UTF8"
            invokespecial java.lang.String.<init>:([BIILjava/lang/String;)V
            astore 3 /* username */
        start local 3 // java.lang.String username
        51: .line 161
            getstatic com.sun.security.sasl.CramMD5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        52: .line 162
            ldc "CRAMSRV03:Extracted username: {0}"
            aload 3 /* username */
        53: .line 161
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        54: .line 166
            new javax.security.auth.callback.NameCallback
            dup
            ldc "CRAM-MD5 authentication ID: "
            aload 3 /* username */
            invokespecial javax.security.auth.callback.NameCallback.<init>:(Ljava/lang/String;Ljava/lang/String;)V
        55: .line 165
            astore 4 /* ncb */
        start local 4 // javax.security.auth.callback.NameCallback ncb
        56: .line 168
            new javax.security.auth.callback.PasswordCallback
            dup
            ldc "CRAM-MD5 password: "
            iconst_0
            invokespecial javax.security.auth.callback.PasswordCallback.<init>:(Ljava/lang/String;Z)V
        57: .line 167
            astore 5 /* pcb */
        start local 5 // javax.security.auth.callback.PasswordCallback pcb
        58: .line 169
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.cbh:Ljavax/security/auth/callback/CallbackHandler;
            iconst_2
            anewarray javax.security.auth.callback.Callback
            dup
            iconst_0
            aload 4 /* ncb */
            aastore
            dup
            iconst_1
            aload 5 /* pcb */
            aastore
            invokeinterface javax.security.auth.callback.CallbackHandler.handle:([Ljavax/security/auth/callback/Callback;)V
        59: .line 170
            aload 5 /* pcb */
            invokevirtual javax.security.auth.callback.PasswordCallback.getPassword:()[C
            astore 6 /* pwChars */
        start local 6 // char[] pwChars
        60: .line 171
            aload 6 /* pwChars */
            ifnull 61
            aload 6 /* pwChars */
            arraylength
            ifne 65
        61: .line 173
      StackMap locals: com.sun.security.sasl.CramMD5Server byte[] int java.lang.String javax.security.auth.callback.NameCallback javax.security.auth.callback.PasswordCallback char[]
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
        62: .line 174
            new javax.security.sasl.SaslException
            dup
        63: .line 175
            new java.lang.StringBuilder
            dup
            ldc "CRAM-MD5: username not found: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* username */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        64: .line 174
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        65: .line 177
      StackMap locals:
      StackMap stack:
            aload 5 /* pcb */
            invokevirtual javax.security.auth.callback.PasswordCallback.clearPassword:()V
        66: .line 178
            new java.lang.String
            dup
            aload 6 /* pwChars */
            invokespecial java.lang.String.<init>:([C)V
            astore 7 /* pwStr */
        start local 7 // java.lang.String pwStr
        67: .line 179
            iconst_0
            istore 8 /* i */
        start local 8 // int i
        68: goto 71
        69: .line 180
      StackMap locals: java.lang.String int
      StackMap stack:
            aload 6 /* pwChars */
            iload 8 /* i */
            iconst_0
            castore
        70: .line 179
            iinc 8 /* i */ 1
      StackMap locals:
      StackMap stack:
        71: iload 8 /* i */
            aload 6 /* pwChars */
            arraylength
            if_icmplt 69
        end local 8 // int i
        72: .line 182
            aload 0 /* this */
            aload 7 /* pwStr */
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            putfield com.sun.security.sasl.CramMD5Server.pw:[B
        73: .line 186
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.pw:[B
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.challengeData:[B
            invokestatic com.sun.security.sasl.CramMD5Server.HMAC_MD5:([B[B)Ljava/lang/String;
            astore 8 /* digest */
        start local 8 // java.lang.String digest
        74: .line 188
            getstatic com.sun.security.sasl.CramMD5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        75: .line 189
            ldc "CRAMSRV04:Expecting digest: {0}"
            aload 8 /* digest */
        76: .line 188
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        77: .line 192
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.CramMD5Server.clearPassword:()V
        78: .line 195
            aload 8 /* digest */
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            astore 9 /* expectedDigest */
        start local 9 // byte[] expectedDigest
        79: .line 196
            aload 1 /* responseData */
            arraylength
            iload 2 /* ulen */
            isub
            iconst_1
            isub
            istore 10 /* digestLen */
        start local 10 // int digestLen
        80: .line 197
            aload 9 /* expectedDigest */
            arraylength
            iload 10 /* digestLen */
            if_icmpeq 83
        81: .line 198
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
        82: .line 199
            new javax.security.sasl.SaslException
            dup
            ldc "Invalid response"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        83: .line 201
      StackMap locals: com.sun.security.sasl.CramMD5Server byte[] int java.lang.String javax.security.auth.callback.NameCallback javax.security.auth.callback.PasswordCallback char[] java.lang.String java.lang.String byte[] int
      StackMap stack:
            iconst_0
            istore 11 /* j */
        start local 11 // int j
        84: .line 202
            iload 2 /* ulen */
            iconst_1
            iadd
            istore 12 /* i */
        start local 12 // int i
        85: goto 90
        86: .line 203
      StackMap locals: int int
      StackMap stack:
            aload 9 /* expectedDigest */
            iload 11 /* j */
            iinc 11 /* j */ 1
            baload
            aload 1 /* responseData */
            iload 12 /* i */
            baload
            if_icmpeq 89
        87: .line 204
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
        88: .line 205
            new javax.security.sasl.SaslException
            dup
            ldc "Invalid response"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        89: .line 202
      StackMap locals:
      StackMap stack:
            iinc 12 /* i */ 1
      StackMap locals:
      StackMap stack:
        90: iload 12 /* i */
            aload 1 /* responseData */
            arraylength
            if_icmplt 86
        end local 12 // int i
        91: .line 210
            new javax.security.sasl.AuthorizeCallback
            dup
            aload 3 /* username */
            aload 3 /* username */
            invokespecial javax.security.sasl.AuthorizeCallback.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            astore 12 /* acb */
        start local 12 // javax.security.sasl.AuthorizeCallback acb
        92: .line 211
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.cbh:Ljavax/security/auth/callback/CallbackHandler;
            iconst_1
            anewarray javax.security.auth.callback.Callback
            dup
            iconst_0
            aload 12 /* acb */
            aastore
            invokeinterface javax.security.auth.callback.CallbackHandler.handle:([Ljavax/security/auth/callback/Callback;)V
        93: .line 212
            aload 12 /* acb */
            invokevirtual javax.security.sasl.AuthorizeCallback.isAuthorized:()Z
            ifeq 96
        94: .line 213
            aload 0 /* this */
            aload 12 /* acb */
            invokevirtual javax.security.sasl.AuthorizeCallback.getAuthorizedID:()Ljava/lang/String;
            putfield com.sun.security.sasl.CramMD5Server.authzid:Ljava/lang/String;
        95: .line 214
            goto 100
        96: .line 216
      StackMap locals: com.sun.security.sasl.CramMD5Server byte[] int java.lang.String javax.security.auth.callback.NameCallback javax.security.auth.callback.PasswordCallback char[] java.lang.String java.lang.String byte[] int int javax.security.sasl.AuthorizeCallback
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
        97: .line 217
            new javax.security.sasl.SaslException
            dup
        98: .line 218
            new java.lang.StringBuilder
            dup
            ldc "CRAM-MD5: user not authorized: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 3 /* username */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        99: .line 217
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
       100: .line 221
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.CramMD5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
       101: .line 222
            ldc "CRAMSRV05:Authorization id: {0}"
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.authzid:Ljava/lang/String;
       102: .line 221
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
       103: .line 224
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.completed:Z
       104: .line 225
            aconst_null
            areturn
        end local 12 // javax.security.sasl.AuthorizeCallback acb
        end local 11 // int j
        end local 10 // int digestLen
        end local 9 // byte[] expectedDigest
        end local 8 // java.lang.String digest
        end local 7 // java.lang.String pwStr
        end local 6 // char[] pwChars
        end local 5 // javax.security.auth.callback.PasswordCallback pcb
        end local 4 // javax.security.auth.callback.NameCallback ncb
        end local 3 // java.lang.String username
        end local 2 // int ulen
       105: .line 227
      StackMap locals: com.sun.security.sasl.CramMD5Server byte[]
      StackMap stack: java.io.UnsupportedEncodingException
            astore 2 /* e */
        start local 2 // java.io.UnsupportedEncodingException e
       106: .line 228
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
       107: .line 229
            new javax.security.sasl.SaslException
            dup
            ldc "UTF8 not available on platform"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.UnsupportedEncodingException e
       108: .line 230
      StackMap locals:
      StackMap stack: java.security.NoSuchAlgorithmException
            astore 2 /* e */
        start local 2 // java.security.NoSuchAlgorithmException e
       109: .line 231
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
       110: .line 232
            new javax.security.sasl.SaslException
            dup
            ldc "MD5 algorithm not available on platform"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.security.NoSuchAlgorithmException e
       111: .line 233
      StackMap locals:
      StackMap stack: javax.security.auth.callback.UnsupportedCallbackException
            astore 2 /* e */
        start local 2 // javax.security.auth.callback.UnsupportedCallbackException e
       112: .line 234
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
       113: .line 235
            new javax.security.sasl.SaslException
            dup
            ldc "CRAM-MD5 authentication failed"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // javax.security.auth.callback.UnsupportedCallbackException e
       114: .line 236
      StackMap locals:
      StackMap stack: javax.security.sasl.SaslException
            astore 2 /* e */
        start local 2 // javax.security.sasl.SaslException e
       115: .line 237
            aload 2 /* e */
            athrow
        end local 2 // javax.security.sasl.SaslException e
       116: .line 238
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
       117: .line 239
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.CramMD5Server.aborted:Z
       118: .line 240
            new javax.security.sasl.SaslException
            dup
            ldc "CRAM-MD5 authentication failed"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        end local 1 // byte[] responseData
        end local 0 // com.sun.security.sasl.CramMD5Server this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0  119     0            this  Lcom/sun/security/sasl/CramMD5Server;
            0  119     1    responseData  [B
           15   32     2          random  Ljava/util/Random;
           16   32     3            rand  J
           17   32     5       timestamp  J
           18   32     7             buf  Ljava/lang/StringBuffer;
           26   32     8    challengeStr  Ljava/lang/String;
           38  105     2            ulen  I
           39   45     3               i  I
           51  105     3        username  Ljava/lang/String;
           56  105     4             ncb  Ljavax/security/auth/callback/NameCallback;
           58  105     5             pcb  Ljavax/security/auth/callback/PasswordCallback;
           60  105     6         pwChars  [C
           67  105     7           pwStr  Ljava/lang/String;
           68   72     8               i  I
           74  105     8          digest  Ljava/lang/String;
           79  105     9  expectedDigest  [B
           80  105    10       digestLen  I
           84  105    11               j  I
           85   91    12               i  I
           92  105    12             acb  Ljavax/security/sasl/AuthorizeCallback;
          106  108     2               e  Ljava/io/UnsupportedEncodingException;
          109  111     2               e  Ljava/security/NoSuchAlgorithmException;
          112  114     2               e  Ljavax/security/auth/callback/UnsupportedCallbackException;
          115  116     2               e  Ljavax/security/sasl/SaslException;
          117  119     2               e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           8    31     105  Class java.io.UnsupportedEncodingException
          32   104     105  Class java.io.UnsupportedEncodingException
           8    31     108  Class java.security.NoSuchAlgorithmException
          32   104     108  Class java.security.NoSuchAlgorithmException
           8    31     111  Class javax.security.auth.callback.UnsupportedCallbackException
          32   104     111  Class javax.security.auth.callback.UnsupportedCallbackException
           8    31     114  Class javax.security.sasl.SaslException
          32   104     114  Class javax.security.sasl.SaslException
           8    31     116  Class java.io.IOException
          32   104     116  Class java.io.IOException
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
              Name  Flags
      responseData  

  public java.lang.String getAuthorizationID();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.sun.security.sasl.CramMD5Server this
         0: .line 245
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.completed:Z
            ifeq 2
         1: .line 246
            aload 0 /* this */
            getfield com.sun.security.sasl.CramMD5Server.authzid:Ljava/lang/String;
            areturn
         2: .line 248
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
         3: .line 249
            ldc "CRAM-MD5 authentication not completed"
         4: .line 248
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // com.sun.security.sasl.CramMD5Server this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lcom/sun/security/sasl/CramMD5Server;
}
SourceFile: "CramMD5Server.java"