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

  private boolean finalHandshake;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private boolean mutual;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 83
            ldc Lcom/sun/security/sasl/gsskerb/GssKrb5Client;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            putstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            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=6, locals=11, args_size=6
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Client 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 97
            aload 0 /* this */
            aload 4 /* props */
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            invokespecial com.sun.security.sasl.gsskerb.GssKrb5Base.<init>:(Ljava/util/Map;Ljava/lang/String;)V
         1: .line 85
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.finalHandshake:Z
         2: .line 86
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.mutual:Z
         3: .line 99
            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;
            astore 6 /* service */
        start local 6 // java.lang.String service
         4: .line 100
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5CLNT01:Requesting service name: {0}"
         5: .line 101
            aload 6 /* service */
         6: .line 100
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
         7: .line 104
            invokestatic org.ietf.jgss.GSSManager.getInstance:()Lorg/ietf/jgss/GSSManager;
            astore 7 /* mgr */
        start local 7 // org.ietf.jgss.GSSManager mgr
         8: .line 107
            aload 7 /* mgr */
            aload 6 /* service */
         9: .line 108
            getstatic org.ietf.jgss.GSSName.NT_HOSTBASED_SERVICE:Lorg/ietf/jgss/Oid;
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.KRB5_OID:Lorg/ietf/jgss/Oid;
        10: .line 107
            invokevirtual org.ietf.jgss.GSSManager.createName:(Ljava/lang/String;Lorg/ietf/jgss/Oid;Lorg/ietf/jgss/Oid;)Lorg/ietf/jgss/GSSName;
            astore 8 /* acceptorName */
        start local 8 // org.ietf.jgss.GSSName acceptorName
        11: .line 111
            aconst_null
            astore 9 /* credentials */
        start local 9 // org.ietf.jgss.GSSCredential credentials
        12: .line 112
            aload 4 /* props */
            ifnull 19
        13: .line 113
            aload 4 /* props */
            ldc "javax.security.sasl.credentials"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 10 /* prop */
        start local 10 // java.lang.Object prop
        14: .line 114
            aload 10 /* prop */
            ifnull 19
            aload 10 /* prop */
            instanceof org.ietf.jgss.GSSCredential
            ifeq 19
        15: .line 115
            aload 10 /* prop */
            checkcast org.ietf.jgss.GSSCredential
            astore 9 /* credentials */
        16: .line 116
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        17: .line 117
            ldc "KRB5CLNT01:Using the credentials supplied in javax.security.sasl.credentials"
        18: .line 116
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;)V
        end local 10 // java.lang.Object prop
        19: .line 123
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Client java.lang.String java.lang.String java.lang.String java.util.Map javax.security.auth.callback.CallbackHandler java.lang.String org.ietf.jgss.GSSManager org.ietf.jgss.GSSName org.ietf.jgss.GSSCredential
      StackMap stack:
            aload 0 /* this */
            aload 7 /* mgr */
            aload 8 /* acceptorName */
        20: .line 124
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.KRB5_OID:Lorg/ietf/jgss/Oid;
        21: .line 125
            aload 9 /* credentials */
        22: .line 126
            ldc 2147483647
        23: .line 123
            invokevirtual org.ietf.jgss.GSSManager.createContext:(Lorg/ietf/jgss/GSSName;Lorg/ietf/jgss/Oid;Lorg/ietf/jgss/GSSCredential;I)Lorg/ietf/jgss/GSSContext;
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
        24: .line 129
            aload 9 /* credentials */
            ifnull 26
        25: .line 130
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_1
            invokeinterface org.ietf.jgss.GSSContext.requestCredDeleg:(Z)V
        26: .line 134
      StackMap locals:
      StackMap stack:
            aload 4 /* props */
            ifnull 30
        27: .line 136
            aload 4 /* props */
            ldc "javax.security.sasl.server.authentication"
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 10 /* prop */
        start local 10 // java.lang.String prop
        28: .line 137
            aload 10 /* prop */
            ifnull 30
        29: .line 138
            aload 0 /* this */
            ldc "true"
            aload 10 /* prop */
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.mutual:Z
        end local 10 // java.lang.String prop
        30: .line 141
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.mutual:Z
            invokeinterface org.ietf.jgss.GSSContext.requestMutualAuth:(Z)V
        31: .line 145
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_1
            invokeinterface org.ietf.jgss.GSSContext.requestConf:(Z)V
        32: .line 146
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_1
            invokeinterface org.ietf.jgss.GSSContext.requestInteg:(Z)V
        end local 9 // org.ietf.jgss.GSSCredential credentials
        end local 8 // org.ietf.jgss.GSSName acceptorName
        end local 7 // org.ietf.jgss.GSSManager mgr
        33: .line 148
            goto 36
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Client java.lang.String java.lang.String java.lang.String java.util.Map javax.security.auth.callback.CallbackHandler java.lang.String
      StackMap stack: org.ietf.jgss.GSSException
        34: astore 7 /* e */
        start local 7 // org.ietf.jgss.GSSException e
        35: .line 149
            new javax.security.sasl.SaslException
            dup
            ldc "Failure to initialize security context"
            aload 7 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // org.ietf.jgss.GSSException e
        36: .line 152
      StackMap locals:
      StackMap stack:
            aload 1 /* authzID */
            ifnull 41
            aload 1 /* authzID */
            invokevirtual java.lang.String.length:()I
            ifle 41
        37: .line 154
            aload 0 /* this */
            aload 1 /* authzID */
            ldc "UTF8"
            invokevirtual java.lang.String.getBytes:(Ljava/lang/String;)[B
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
        38: .line 155
            goto 41
      StackMap locals:
      StackMap stack: java.io.IOException
        39: astore 7 /* e */
        start local 7 // java.io.IOException e
        40: .line 156
            new javax.security.sasl.SaslException
            dup
            ldc "Cannot encode authorization ID"
            aload 7 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 7 // java.io.IOException e
        41: .line 159
      StackMap locals:
      StackMap stack:
            return
        end local 6 // java.lang.String service
        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.gsskerb.GssKrb5Client this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   42     0          this  Lcom/sun/security/sasl/gsskerb/GssKrb5Client;
            0   42     1       authzID  Ljava/lang/String;
            0   42     2      protocol  Ljava/lang/String;
            0   42     3    serverName  Ljava/lang/String;
            0   42     4         props  Ljava/util/Map<Ljava/lang/String;*>;
            0   42     5           cbh  Ljavax/security/auth/callback/CallbackHandler;
            4   42     6       service  Ljava/lang/String;
            8   33     7           mgr  Lorg/ietf/jgss/GSSManager;
           11   33     8  acceptorName  Lorg/ietf/jgss/GSSName;
           12   33     9   credentials  Lorg/ietf/jgss/GSSCredential;
           14   19    10          prop  Ljava/lang/Object;
           28   30    10          prop  Ljava/lang/String;
           35   36     7             e  Lorg/ietf/jgss/GSSException;
           40   41     7             e  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           7    33      34  Class org.ietf.jgss.GSSException
          37    38      39  Class java.io.IOException
    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.gsskerb.GssKrb5Client this
         0: .line 162
            iconst_1
            ireturn
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Client this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/sun/security/sasl/gsskerb/GssKrb5Client;

  public byte[] evaluateChallenge(byte[]);
    descriptor: ([B)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Client this
        start local 1 // byte[] challengeData
         0: .line 180
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.completed:Z
            ifeq 4
         1: .line 181
            new java.lang.IllegalStateException
            dup
         2: .line 182
            ldc "GSSAPI authentication already complete"
         3: .line 181
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 185
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.finalHandshake:Z
            ifeq 6
         5: .line 186
            aload 0 /* this */
            aload 1 /* challengeData */
            invokevirtual com.sun.security.sasl.gsskerb.GssKrb5Client.doFinalHandshake:([B)[B
            areturn
         6: .line 192
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 1 /* challengeData */
         7: .line 193
            iconst_0
            aload 1 /* challengeData */
            arraylength
         8: .line 192
            invokeinterface org.ietf.jgss.GSSContext.initSecContext:([BII)[B
            astore 2 /* gssOutToken */
        start local 2 // byte[] gssOutToken
         9: .line 194
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 16
        10: .line 195
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            ldc "evaluteChallenge"
        11: .line 196
            ldc "KRB5CLNT02:Challenge: [raw]"
            aload 1 /* challengeData */
        12: .line 195
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        13: .line 197
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            ldc "evaluateChallenge"
        14: .line 198
            ldc "KRB5CLNT03:Response: [after initSecCtx]"
            aload 2 /* gssOutToken */
        15: .line 197
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        16: .line 201
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            invokeinterface org.ietf.jgss.GSSContext.isEstablished:()Z
            ifeq 21
        17: .line 202
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.finalHandshake:Z
        18: .line 203
            aload 2 /* gssOutToken */
            ifnonnull 21
        19: .line 205
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.EMPTY:[B
        20: areturn
        21: .line 209
      StackMap locals:
      StackMap stack:
            aload 2 /* gssOutToken */
        22: areturn
        end local 2 // byte[] gssOutToken
        23: .line 210
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Client byte[]
      StackMap stack: org.ietf.jgss.GSSException
            astore 2 /* e */
        start local 2 // org.ietf.jgss.GSSException e
        24: .line 211
            new javax.security.sasl.SaslException
            dup
            ldc "GSS initiate failed"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // org.ietf.jgss.GSSException e
        end local 1 // byte[] challengeData
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Client this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   25     0           this  Lcom/sun/security/sasl/gsskerb/GssKrb5Client;
            0   25     1  challengeData  [B
            9   23     2    gssOutToken  [B
           24   25     2              e  Lorg/ietf/jgss/GSSException;
      Exception table:
        from    to  target  type
           6    20      23  Class org.ietf.jgss.GSSException
          21    22      23  Class org.ietf.jgss.GSSException
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
               Name  Flags
      challengeData  

  private byte[] doFinalHandshake(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=8, args_size=2
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Client this
        start local 1 // byte[] challengeData
         0: .line 221
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 4
         1: .line 222
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doFinalHandshake"
         2: .line 223
            ldc "KRB5CLNT04:Challenge [raw]:"
            aload 1 /* challengeData */
         3: .line 222
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
         4: .line 226
      StackMap locals:
      StackMap stack:
            aload 1 /* challengeData */
            arraylength
            ifne 7
         5: .line 228
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.EMPTY:[B
         6: areturn
         7: .line 233
      StackMap locals:
      StackMap stack:
            new org.ietf.jgss.MessageProp
            dup
            iconst_0
            invokespecial org.ietf.jgss.MessageProp.<init>:(Z)V
            astore 2 /* msgProp */
        start local 2 // org.ietf.jgss.MessageProp msgProp
         8: .line 234
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 1 /* challengeData */
            iconst_0
         9: .line 235
            aload 1 /* challengeData */
            arraylength
            aload 2 /* msgProp */
        10: .line 234
            invokeinterface org.ietf.jgss.GSSContext.unwrap:([BIILorg/ietf/jgss/MessageProp;)[B
            astore 3 /* gssOutToken */
        start local 3 // byte[] gssOutToken
        11: .line 236
            aload 0 /* this */
            ldc "Handshake failure: "
            aload 2 /* msgProp */
            invokevirtual com.sun.security.sasl.gsskerb.GssKrb5Client.checkMessageProp:(Ljava/lang/String;Lorg/ietf/jgss/MessageProp;)V
        12: .line 240
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.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 20
        13: .line 241
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 17
        14: .line 242
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doFinalHandshake"
        15: .line 243
            ldc "KRB5CLNT05:Challenge [unwrapped]:"
            aload 3 /* gssOutToken */
        16: .line 242
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        17: .line 245
      StackMap locals: org.ietf.jgss.MessageProp byte[]
      StackMap stack:
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5CLNT06:Server protections: {0}"
        18: .line 246
            aload 3 /* gssOutToken */
            iconst_0
            baload
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
        19: .line 245
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        20: .line 251
      StackMap locals:
      StackMap stack:
            aload 3 /* gssOutToken */
            iconst_0
            baload
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.qop:[B
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.findPreferredMask:(B[B)B
            istore 4 /* selectedQop */
        start local 4 // byte selectedQop
        21: .line 252
            iload 4 /* selectedQop */
            ifne 25
        22: .line 253
            new javax.security.sasl.SaslException
            dup
        23: .line 254
            ldc "No common protection layer between client and server"
        24: .line 253
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        25: .line 257
      StackMap locals: int
      StackMap stack:
            iload 4 /* selectedQop */
            iconst_4
            iand
            ifeq 29
        26: .line 258
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.privacy:Z
        27: .line 259
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.integrity:Z
        28: .line 260
            goto 31
      StackMap locals:
      StackMap stack:
        29: iload 4 /* selectedQop */
            iconst_2
            iand
            ifeq 31
        30: .line 261
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.integrity:Z
        31: .line 266
      StackMap locals:
      StackMap stack:
            aload 3 /* gssOutToken */
            iconst_1
            iconst_3
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.networkByteOrderToInt:([BII)I
            istore 5 /* srvMaxBufSize */
        start local 5 // int srvMaxBufSize
        32: .line 270
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.sendMaxBufSize:I
            ifne 33
            iload 5 /* srvMaxBufSize */
            goto 34
        33: .line 271
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Client byte[] org.ietf.jgss.MessageProp byte[] int int
      StackMap stack: com.sun.security.sasl.gsskerb.GssKrb5Client
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.sendMaxBufSize:I
            iload 5 /* srvMaxBufSize */
            invokestatic java.lang.Math.min:(II)I
        34: .line 270
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Client byte[] org.ietf.jgss.MessageProp byte[] int int
      StackMap stack: com.sun.security.sasl.gsskerb.GssKrb5Client int
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.sendMaxBufSize:I
        35: .line 274
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_0
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.privacy:Z
        36: .line 275
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.sendMaxBufSize:I
        37: .line 274
            invokeinterface org.ietf.jgss.GSSContext.getWrapSizeLimit:(IZI)I
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.rawSendSize:I
        38: .line 277
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.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 45
        39: .line 278
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        40: .line 279
            ldc "KRB5CLNT07:Client max recv size: {0}; server max recv size: {1}; rawSendSize: {2}"
        41: .line 280
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.recvMaxBufSize:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_1
        42: .line 281
            iload 5 /* srvMaxBufSize */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_2
        43: .line 282
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.rawSendSize:I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
        44: .line 278
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
        45: .line 287
      StackMap locals:
      StackMap stack:
            iconst_4
            istore 6 /* len */
        start local 6 // int len
        46: .line 288
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
            ifnull 48
        47: .line 289
            iload 6 /* len */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
            arraylength
            iadd
            istore 6 /* len */
        48: .line 292
      StackMap locals: int
      StackMap stack:
            iload 6 /* len */
            newarray 8
            astore 7 /* gssInToken */
        start local 7 // byte[] gssInToken
        49: .line 293
            aload 7 /* gssInToken */
            iconst_0
            iload 4 /* selectedQop */
            bastore
        50: .line 295
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.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 57
        51: .line 296
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        52: .line 297
            ldc "KRB5CLNT08:Selected protection: {0}; privacy: {1}; integrity: {2}"
        53: .line 298
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            iload 4 /* selectedQop */
            invokestatic java.lang.Byte.valueOf:(B)Ljava/lang/Byte;
            aastore
            dup
            iconst_1
        54: .line 299
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.privacy:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            aastore
            dup
            iconst_2
        55: .line 300
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.integrity:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            aastore
        56: .line 296
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
        57: .line 303
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.privacy:Z
            ifne 58
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.integrity:Z
            ifeq 59
        58: .line 306
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.recvMaxBufSize:I
            aload 7 /* gssInToken */
            iconst_1
            iconst_3
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.intToNetworkByteOrder:(I[BII)V
        59: .line 308
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
            ifnull 62
        60: .line 310
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
            iconst_0
            aload 7 /* gssInToken */
            iconst_4
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
            arraylength
            invokestatic java.lang.System.arraycopy:(Ljava/lang/Object;ILjava/lang/Object;II)V
        61: .line 311
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5CLNT09:Authzid: {0}"
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.authzID:[B
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        62: .line 314
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 66
        63: .line 315
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doFinalHandshake"
        64: .line 316
            ldc "KRB5CLNT10:Response [raw]"
            aload 7 /* gssInToken */
        65: .line 315
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        66: .line 319
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Client.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 7 /* gssInToken */
        67: .line 320
            iconst_0
            aload 7 /* gssInToken */
            arraylength
        68: .line 321
            new org.ietf.jgss.MessageProp
            dup
            iconst_0
            iconst_0
            invokespecial org.ietf.jgss.MessageProp.<init>:(IZ)V
        69: .line 319
            invokeinterface org.ietf.jgss.GSSContext.wrap:([BIILorg/ietf/jgss/MessageProp;)[B
            astore 3 /* gssOutToken */
        70: .line 323
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINER:Ljava/util/logging/Level;
            invokevirtual java.util.logging.Logger.isLoggable:(Ljava/util/logging/Level;)Z
            ifeq 74
        71: .line 324
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Client.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doFinalHandshake"
        72: .line 325
            ldc "KRB5CLNT11:Response [after wrap]"
            aload 3 /* gssOutToken */
        73: .line 324
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Client.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        74: .line 328
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Client.completed:Z
        75: .line 330
            aload 3 /* gssOutToken */
        76: areturn
        end local 7 // byte[] gssInToken
        end local 6 // int len
        end local 5 // int srvMaxBufSize
        end local 4 // byte selectedQop
        end local 3 // byte[] gssOutToken
        end local 2 // org.ietf.jgss.MessageProp msgProp
        77: .line 331
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Client byte[]
      StackMap stack: org.ietf.jgss.GSSException
            astore 2 /* e */
        start local 2 // org.ietf.jgss.GSSException e
        78: .line 332
            new javax.security.sasl.SaslException
            dup
            ldc "Final handshake failed"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // org.ietf.jgss.GSSException e
        end local 1 // byte[] challengeData
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Client this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   79     0           this  Lcom/sun/security/sasl/gsskerb/GssKrb5Client;
            0   79     1  challengeData  [B
            8   77     2        msgProp  Lorg/ietf/jgss/MessageProp;
           11   77     3    gssOutToken  [B
           21   77     4    selectedQop  B
           32   77     5  srvMaxBufSize  I
           46   77     6            len  I
           49   77     7     gssInToken  [B
           78   79     2              e  Lorg/ietf/jgss/GSSException;
      Exception table:
        from    to  target  type
           0     6      77  Class org.ietf.jgss.GSSException
           7    76      77  Class org.ietf.jgss.GSSException
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
               Name  Flags
      challengeData  
}
SourceFile: "GssKrb5Client.java"