final class com.sun.security.sasl.PlainClient implements javax.security.sasl.SaslClient
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.security.sasl.PlainClient
  super_class: java.lang.Object
{
  private boolean completed;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

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

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

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

  private static byte SEP;
    descriptor: B
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 44
            iconst_0
            putstatic com.sun.security.sasl.PlainClient.SEP:B
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  void <init>(java.lang.String, java.lang.String, byte[]);
    descriptor: (Ljava/lang/String;Ljava/lang/String;[B)V
    flags: (0x0000) 
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // com.sun.security.sasl.PlainClient this
        start local 1 // java.lang.String authorizationID
        start local 2 // java.lang.String authenticationID
        start local 3 // byte[] pw
         0: .line 57
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 40
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.PlainClient.completed:Z
         2: .line 59
            aload 2 /* authenticationID */
            ifnull 3
            aload 3 /* pw */
            ifnonnull 6
         3: .line 60
      StackMap locals: com.sun.security.sasl.PlainClient java.lang.String java.lang.String byte[]
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
         4: .line 61
            ldc "PLAIN: authorization ID and password must be specified"
         5: .line 60
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         6: .line 64
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* authorizationID */
            putfield com.sun.security.sasl.PlainClient.authorizationID:Ljava/lang/String;
         7: .line 65
            aload 0 /* this */
            aload 2 /* authenticationID */
            putfield com.sun.security.sasl.PlainClient.authenticationID:Ljava/lang/String;
         8: .line 66
            aload 0 /* this */
            aload 3 /* pw */
            putfield com.sun.security.sasl.PlainClient.pw:[B
         9: .line 67
            return
        end local 3 // byte[] pw
        end local 2 // java.lang.String authenticationID
        end local 1 // java.lang.String authorizationID
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   10     0              this  Lcom/sun/security/sasl/PlainClient;
            0   10     1   authorizationID  Ljava/lang/String;
            0   10     2  authenticationID  Ljava/lang/String;
            0   10     3                pw  [B
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
                  Name  Flags
      authorizationID   
      authenticationID  
      pw                

  public java.lang.String getMechanismName();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.security.sasl.PlainClient this
         0: .line 76
            ldc "PLAIN"
            areturn
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/sasl/PlainClient;

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

  public void dispose();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.security.sasl.PlainClient this
         0: .line 84
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.PlainClient.clearPassword:()V
         1: .line 85
            return
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/sun/security/sasl/PlainClient;
    Exceptions:
      throws javax.security.sasl.SaslException

  public byte[] evaluateChallenge(byte[]);
    descriptor: ([B)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=6, args_size=2
        start local 0 // com.sun.security.sasl.PlainClient this
        start local 1 // byte[] challengeData
         0: .line 97
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.completed:Z
            ifeq 4
         1: .line 98
            new java.lang.IllegalStateException
            dup
         2: .line 99
            ldc "PLAIN authentication already completed"
         3: .line 98
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 101
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.PlainClient.completed:Z
         5: .line 102
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.authorizationID:Ljava/lang/String;
            ifnull 7
         6: .line 103
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.authorizationID:Ljava/lang/String;
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokevirtual java.lang.String.getBytes:(Ljava/nio/charset/Charset;)[B
            goto 8
         7: .line 104
      StackMap locals:
      StackMap stack:
            aconst_null
         8: .line 102
      StackMap locals:
      StackMap stack: byte[]
            astore 2 /* authz */
        start local 2 // byte[] authz
         9: .line 105
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.authenticationID:Ljava/lang/String;
            getstatic java.nio.charset.StandardCharsets.UTF_8:Ljava/nio/charset/Charset;
            invokevirtual java.lang.String.getBytes:(Ljava/nio/charset/Charset;)[B
            astore 3 /* auth */
        start local 3 // byte[] auth
        10: .line 107
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.pw:[B
            arraylength
            aload 3 /* auth */
            arraylength
            iadd
            iconst_2
            iadd
        11: .line 108
            aload 2 /* authz */
            ifnonnull 12
            iconst_0
            goto 13
      StackMap locals: com.sun.security.sasl.PlainClient byte[] byte[] byte[]
      StackMap stack: int
        12: aload 2 /* authz */
            arraylength
        13: .line 107
      StackMap locals: com.sun.security.sasl.PlainClient byte[] byte[] byte[]
      StackMap stack: int int
            iadd
            newarray 8
            astore 4 /* answer */
        start local 4 // byte[] answer
        14: .line 110
            iconst_0
            istore 5 /* pos */
        start local 5 // int pos
        15: .line 111
            aload 2 /* authz */
            ifnull 18
        16: .line 112
            aload 2 /* authz */
            iconst_0
            aload 4 /* answer */
            iconst_0
            aload 2 /* authz */
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        17: .line 113
            aload 2 /* authz */
            arraylength
            istore 5 /* pos */
        18: .line 115
      StackMap locals: byte[] int
      StackMap stack:
            aload 4 /* answer */
            iload 5 /* pos */
            iinc 5 /* pos */ 1
            getstatic com.sun.security.sasl.PlainClient.SEP:B
            bastore
        19: .line 116
            aload 3 /* auth */
            iconst_0
            aload 4 /* answer */
            iload 5 /* pos */
            aload 3 /* auth */
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        20: .line 118
            iload 5 /* pos */
            aload 3 /* auth */
            arraylength
            iadd
            istore 5 /* pos */
        21: .line 119
            aload 4 /* answer */
            iload 5 /* pos */
            iinc 5 /* pos */ 1
            getstatic com.sun.security.sasl.PlainClient.SEP:B
            bastore
        22: .line 121
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.pw:[B
            iconst_0
            aload 4 /* answer */
            iload 5 /* pos */
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.pw:[B
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        23: .line 123
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.PlainClient.clearPassword:()V
        24: .line 124
            aload 4 /* answer */
            areturn
        end local 5 // int pos
        end local 4 // byte[] answer
        end local 3 // byte[] auth
        end local 2 // byte[] authz
        end local 1 // byte[] challengeData
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   25     0           this  Lcom/sun/security/sasl/PlainClient;
            0   25     1  challengeData  [B
            9   25     2          authz  [B
           10   25     3           auth  [B
           14   25     4         answer  [B
           15   25     5            pos  I
    MethodParameters:
               Name  Flags
      challengeData  

  public boolean isComplete();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.security.sasl.PlainClient this
         0: .line 134
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.completed:Z
            ireturn
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/sasl/PlainClient;

  public byte[] unwrap(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // com.sun.security.sasl.PlainClient this
        start local 1 // byte[] incoming
        start local 2 // int offset
        start local 3 // int len
         0: .line 144
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.completed:Z
            ifeq 4
         1: .line 145
            new javax.security.sasl.SaslException
            dup
         2: .line 146
            ldc "PLAIN supports neither integrity nor privacy"
         3: .line 145
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 148
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "PLAIN authentication not completed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // int len
        end local 2 // int offset
        end local 1 // byte[] incoming
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lcom/sun/security/sasl/PlainClient;
            0    5     1  incoming  [B
            0    5     2    offset  I
            0    5     3       len  I
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
          Name  Flags
      incoming  
      offset    
      len       

  public byte[] wrap(byte[], int, int);
    descriptor: ([BII)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=4
        start local 0 // com.sun.security.sasl.PlainClient this
        start local 1 // byte[] outgoing
        start local 2 // int offset
        start local 3 // int len
         0: .line 158
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.completed:Z
            ifeq 4
         1: .line 159
            new javax.security.sasl.SaslException
            dup
         2: .line 160
            ldc "PLAIN supports neither integrity nor privacy"
         3: .line 159
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 162
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "PLAIN authentication not completed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // int len
        end local 2 // int offset
        end local 1 // byte[] outgoing
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lcom/sun/security/sasl/PlainClient;
            0    5     1  outgoing  [B
            0    5     2    offset  I
            0    5     3       len  I
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
          Name  Flags
      outgoing  
      offset    
      len       

  public java.lang.Object getNegotiatedProperty(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // com.sun.security.sasl.PlainClient this
        start local 1 // java.lang.String propName
         0: .line 177
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.completed:Z
            ifeq 4
         1: .line 178
            aload 1 /* propName */
            ldc "javax.security.sasl.qop"
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 3
         2: .line 179
            ldc "auth"
            areturn
         3: .line 181
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
         4: .line 184
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "PLAIN authentication not completed"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 1 // java.lang.String propName
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    5     0      this  Lcom/sun/security/sasl/PlainClient;
            0    5     1  propName  Ljava/lang/String;
    MethodParameters:
          Name  Flags
      propName  

  private void clearPassword();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // com.sun.security.sasl.PlainClient this
         0: .line 189
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.pw:[B
            ifnull 7
         1: .line 191
            iconst_0
            istore 1 /* i */
        start local 1 // int i
         2: goto 5
         3: .line 192
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.pw:[B
            iload 1 /* i */
            iconst_0
            bastore
         4: .line 191
            iinc 1 /* i */ 1
      StackMap locals:
      StackMap stack:
         5: iload 1 /* i */
            aload 0 /* this */
            getfield com.sun.security.sasl.PlainClient.pw:[B
            arraylength
            if_icmplt 3
        end local 1 // int i
         6: .line 194
            aload 0 /* this */
            aconst_null
            putfield com.sun.security.sasl.PlainClient.pw:[B
         7: .line 196
      StackMap locals:
      StackMap stack:
            return
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Lcom/sun/security/sasl/PlainClient;
            2    6     1     i  I

  protected void finalize();
    descriptor: ()V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.security.sasl.PlainClient this
         0: .line 200
            aload 0 /* this */
            invokevirtual com.sun.security.sasl.PlainClient.clearPassword:()V
         1: .line 201
            return
        end local 0 // com.sun.security.sasl.PlainClient this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/sun/security/sasl/PlainClient;
}
SourceFile: "PlainClient.java"