final class com.sun.security.sasl.gsskerb.GssKrb5Server extends com.sun.security.sasl.gsskerb.GssKrb5Base implements javax.security.sasl.SaslServer
  minor version: 0
  major version: 59
  flags: flags: (0x0030) ACC_FINAL, ACC_SUPER
  this_class: com.sun.security.sasl.gsskerb.GssKrb5Server
  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 int handshakeStage;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String peer;
    descriptor: Ljava/lang/String;
    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

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 66
            ldc Lcom/sun/security/sasl/gsskerb/GssKrb5Server;
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            putstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  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=5, locals=9, args_size=5
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
        start local 1 // java.lang.String protocol
        start local 2 // java.lang.String serverName
        start local 3 // java.util.Map props
        start local 4 // javax.security.auth.callback.CallbackHandler cbh
         0: .line 81
            aload 0 /* this */
            aload 3 /* props */
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            invokespecial com.sun.security.sasl.gsskerb.GssKrb5Base.<init>:(Ljava/util/Map;Ljava/lang/String;)V
         1: .line 68
            aload 0 /* this */
            iconst_0
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.handshakeStage:I
         2: .line 83
            aload 0 /* this */
            aload 4 /* cbh */
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.cbh:Ljavax/security/auth/callback/CallbackHandler;
         3: .line 84
            new java.lang.StringBuilder
            dup
            aload 1 /* 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 2 /* serverName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 5 /* service */
        start local 5 // java.lang.String service
         4: .line 86
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5SRV01:Using service name: {0}"
            aload 5 /* service */
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
         5: .line 89
            invokestatic org.ietf.jgss.GSSManager.getInstance:()Lorg/ietf/jgss/GSSManager;
            astore 6 /* mgr */
        start local 6 // org.ietf.jgss.GSSManager mgr
         6: .line 92
            aload 6 /* mgr */
            aload 5 /* service */
         7: .line 93
            getstatic org.ietf.jgss.GSSName.NT_HOSTBASED_SERVICE:Lorg/ietf/jgss/Oid;
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.KRB5_OID:Lorg/ietf/jgss/Oid;
         8: .line 92
            invokevirtual org.ietf.jgss.GSSManager.createName:(Ljava/lang/String;Lorg/ietf/jgss/Oid;Lorg/ietf/jgss/Oid;)Lorg/ietf/jgss/GSSName;
            astore 7 /* serviceName */
        start local 7 // org.ietf.jgss.GSSName serviceName
         9: .line 95
            aload 6 /* mgr */
            aload 7 /* serviceName */
        10: .line 96
            ldc 2147483647
        11: .line 97
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.KRB5_OID:Lorg/ietf/jgss/Oid;
            iconst_2
        12: .line 95
            invokevirtual org.ietf.jgss.GSSManager.createCredential:(Lorg/ietf/jgss/GSSName;ILorg/ietf/jgss/Oid;I)Lorg/ietf/jgss/GSSCredential;
            astore 8 /* cred */
        start local 8 // org.ietf.jgss.GSSCredential cred
        13: .line 100
            aload 0 /* this */
            aload 6 /* mgr */
            aload 8 /* cred */
            invokevirtual org.ietf.jgss.GSSManager.createContext:(Lorg/ietf/jgss/GSSCredential;)Lorg/ietf/jgss/GSSContext;
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
        14: .line 102
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.allQop:B
            iconst_2
            iand
            ifeq 16
        15: .line 104
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_1
            invokeinterface org.ietf.jgss.GSSContext.requestInteg:(Z)V
        16: .line 107
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server 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 */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.allQop:B
            iconst_4
            iand
            ifeq 21
        17: .line 109
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_1
            invokeinterface org.ietf.jgss.GSSContext.requestConf:(Z)V
        end local 8 // org.ietf.jgss.GSSCredential cred
        end local 7 // org.ietf.jgss.GSSName serviceName
        end local 6 // org.ietf.jgss.GSSManager mgr
        18: .line 111
            goto 21
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server java.lang.String java.lang.String java.util.Map javax.security.auth.callback.CallbackHandler java.lang.String
      StackMap stack: org.ietf.jgss.GSSException
        19: astore 6 /* e */
        start local 6 // org.ietf.jgss.GSSException e
        20: .line 112
            new javax.security.sasl.SaslException
            dup
            ldc "Failure to initialize security context"
            aload 6 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // org.ietf.jgss.GSSException e
        21: .line 114
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5SRV02:Initialization complete"
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;)V
        22: .line 115
            return
        end local 5 // java.lang.String service
        end local 4 // javax.security.auth.callback.CallbackHandler cbh
        end local 3 // java.util.Map props
        end local 2 // java.lang.String serverName
        end local 1 // java.lang.String protocol
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   23     0         this  Lcom/sun/security/sasl/gsskerb/GssKrb5Server;
            0   23     1     protocol  Ljava/lang/String;
            0   23     2   serverName  Ljava/lang/String;
            0   23     3        props  Ljava/util/Map<Ljava/lang/String;*>;
            0   23     4          cbh  Ljavax/security/auth/callback/CallbackHandler;
            4   23     5      service  Ljava/lang/String;
            6   18     6          mgr  Lorg/ietf/jgss/GSSManager;
            9   18     7  serviceName  Lorg/ietf/jgss/GSSName;
           13   18     8         cred  Lorg/ietf/jgss/GSSCredential;
           20   21     6            e  Lorg/ietf/jgss/GSSException;
      Exception table:
        from    to  target  type
           5    18      19  Class org.ietf.jgss.GSSException
    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    
      serverName  
      props       
      cbh         

  public byte[] evaluateResponse(byte[]);
    descriptor: ([B)[B
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
        start local 1 // byte[] responseData
         0: .line 133
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.completed:Z
            ifeq 4
         1: .line 134
            new javax.security.sasl.SaslException
            dup
         2: .line 135
            ldc "SASL authentication already complete"
         3: .line 134
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 138
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 8
         5: .line 139
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            ldc "evaluateResponse"
         6: .line 140
            ldc "KRB5SRV03:Response [raw]:"
            aload 1 /* responseData */
         7: .line 139
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
         8: .line 143
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.handshakeStage:I
            tableswitch { // 1 - 2
                    1: 9
                    2: 10
              default: 11
          }
         9: .line 145
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* responseData */
            invokevirtual com.sun.security.sasl.gsskerb.GssKrb5Server.doHandshake1:([B)[B
            areturn
        10: .line 148
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* responseData */
            invokevirtual com.sun.security.sasl.gsskerb.GssKrb5Server.doHandshake2:([B)[B
            areturn
        11: .line 154
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 1 /* responseData */
        12: .line 155
            iconst_0
            aload 1 /* responseData */
            arraylength
        13: .line 154
            invokeinterface org.ietf.jgss.GSSContext.acceptSecContext:([BII)[B
            astore 2 /* gssOutToken */
        start local 2 // byte[] gssOutToken
        14: .line 157
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 18
        15: .line 158
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            ldc "evaluateResponse"
        16: .line 159
            ldc "KRB5SRV04:Challenge: [after acceptSecCtx]"
            aload 2 /* gssOutToken */
        17: .line 158
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        18: .line 162
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            invokeinterface org.ietf.jgss.GSSContext.isEstablished:()Z
            ifeq 25
        19: .line 163
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.handshakeStage:I
        20: .line 165
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            invokeinterface org.ietf.jgss.GSSContext.getSrcName:()Lorg/ietf/jgss/GSSName;
            invokeinterface org.ietf.jgss.GSSName.toString:()Ljava/lang/String;
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.peer:Ljava/lang/String;
        21: .line 167
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5SRV05:Peer name is : {0}"
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.peer:Ljava/lang/String;
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        22: .line 169
            aload 2 /* gssOutToken */
            ifnonnull 25
        23: .line 170
            aload 0 /* this */
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.EMPTY:[B
            invokevirtual com.sun.security.sasl.gsskerb.GssKrb5Server.doHandshake1:([B)[B
        24: areturn
        25: .line 174
      StackMap locals:
      StackMap stack:
            aload 2 /* gssOutToken */
        26: areturn
        end local 2 // byte[] gssOutToken
        27: .line 175
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server byte[]
      StackMap stack: org.ietf.jgss.GSSException
            astore 2 /* e */
        start local 2 // org.ietf.jgss.GSSException e
        28: .line 176
            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[] responseData
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   29     0          this  Lcom/sun/security/sasl/gsskerb/GssKrb5Server;
            0   29     1  responseData  [B
           14   27     2   gssOutToken  [B
           28   29     2             e  Lorg/ietf/jgss/GSSException;
      Exception table:
        from    to  target  type
          11    24      27  Class org.ietf.jgss.GSSException
          25    26      27  Class org.ietf.jgss.GSSException
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
              Name  Flags
      responseData  

  private byte[] doHandshake1(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=4, args_size=2
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
        start local 1 // byte[] responseData
         0: .line 185
            aload 1 /* responseData */
            ifnull 4
            aload 1 /* responseData */
            arraylength
            ifle 4
         1: .line 186
            new javax.security.sasl.SaslException
            dup
         2: .line 187
            ldc "Handshake expecting no response data from server"
         3: .line 186
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
         4: .line 194
      StackMap locals:
      StackMap stack:
            iconst_4
            newarray 8
            astore 2 /* gssInToken */
        start local 2 // byte[] gssInToken
         5: .line 195
            aload 2 /* gssInToken */
            iconst_0
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.allQop:B
            bastore
         6: .line 196
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.recvMaxBufSize:I
            aload 2 /* gssInToken */
            iconst_1
            iconst_3
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.intToNetworkByteOrder:(I[BII)V
         7: .line 198
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 13
         8: .line 199
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
         9: .line 200
            ldc "KRB5SRV06:Supported protections: {0}; recv max buf size: {1}"
        10: .line 201
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            new java.lang.Byte
            dup
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.allQop:B
            invokespecial java.lang.Byte.<init>:(B)V
            aastore
            dup
            iconst_1
        11: .line 202
            new java.lang.Integer
            dup
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.recvMaxBufSize:I
            invokespecial java.lang.Integer.<init>:(I)V
            aastore
        12: .line 199
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
        13: .line 205
      StackMap locals: byte[]
      StackMap stack:
            aload 0 /* this */
            iconst_2
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.handshakeStage:I
        14: .line 207
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 18
        15: .line 208
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doHandshake1"
        16: .line 209
            ldc "KRB5SRV07:Challenge [raw]"
            aload 2 /* gssInToken */
        17: .line 208
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        18: .line 212
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 2 /* gssInToken */
            iconst_0
            aload 2 /* gssInToken */
            arraylength
        19: .line 213
            new org.ietf.jgss.MessageProp
            dup
            iconst_0
            iconst_0
            invokespecial org.ietf.jgss.MessageProp.<init>:(IZ)V
        20: .line 212
            invokeinterface org.ietf.jgss.GSSContext.wrap:([BIILorg/ietf/jgss/MessageProp;)[B
            astore 3 /* gssOutToken */
        start local 3 // byte[] gssOutToken
        21: .line 215
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 25
        22: .line 216
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doHandshake1"
        23: .line 217
            ldc "KRB5SRV08:Challenge [after wrap]"
            aload 3 /* gssOutToken */
        24: .line 216
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
        25: .line 219
      StackMap locals: byte[]
      StackMap stack:
            aload 3 /* gssOutToken */
        26: areturn
        end local 3 // byte[] gssOutToken
        end local 2 // byte[] gssInToken
        27: .line 221
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server byte[]
      StackMap stack: org.ietf.jgss.GSSException
            astore 2 /* e */
        start local 2 // org.ietf.jgss.GSSException e
        28: .line 222
            new javax.security.sasl.SaslException
            dup
            ldc "Problem wrapping handshake1"
            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[] responseData
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   29     0          this  Lcom/sun/security/sasl/gsskerb/GssKrb5Server;
            0   29     1  responseData  [B
            5   27     2    gssInToken  [B
           21   27     3   gssOutToken  [B
           28   29     2             e  Lorg/ietf/jgss/GSSException;
      Exception table:
        from    to  target  type
           0    26      27  Class org.ietf.jgss.GSSException
    Exceptions:
      throws javax.security.sasl.SaslException
    MethodParameters:
              Name  Flags
      responseData  

  private byte[] doHandshake2(byte[]);
    descriptor: ([B)[B
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=9, locals=7, args_size=2
        start local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
        start local 1 // byte[] responseData
         0: .line 230
            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
         1: .line 231
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            aload 1 /* responseData */
            iconst_0
         2: .line 232
            aload 1 /* responseData */
            arraylength
            aload 2 /* msgProp */
         3: .line 231
            invokeinterface org.ietf.jgss.GSSContext.unwrap:([BIILorg/ietf/jgss/MessageProp;)[B
            astore 3 /* gssOutToken */
        start local 3 // byte[] gssOutToken
         4: .line 233
            aload 0 /* this */
            ldc "Handshake failure: "
            aload 2 /* msgProp */
            invokevirtual com.sun.security.sasl.gsskerb.GssKrb5Server.checkMessageProp:(Ljava/lang/String;Lorg/ietf/jgss/MessageProp;)V
         5: .line 235
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 9
         6: .line 236
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.MY_CLASS_NAME:Ljava/lang/String;
            ldc "doHandshake2"
         7: .line 237
            ldc "KRB5SRV09:Response [after unwrap]"
            aload 3 /* gssOutToken */
         8: .line 236
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.traceOutput:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;[B)V
         9: .line 241
      StackMap locals: org.ietf.jgss.MessageProp byte[]
      StackMap stack:
            aload 3 /* gssOutToken */
            iconst_0
            baload
            istore 4 /* selectedQop */
        start local 4 // byte selectedQop
        10: .line 242
            iload 4 /* selectedQop */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.allQop:B
            iand
            ifne 14
        11: .line 243
            new javax.security.sasl.SaslException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Client selected unsupported protection: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        12: .line 244
            iload 4 /* selectedQop */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        13: .line 243
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 246
      StackMap locals: int
      StackMap stack:
            iload 4 /* selectedQop */
            iconst_4
            iand
            ifeq 18
        15: .line 247
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.privacy:Z
        16: .line 248
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.integrity:Z
        17: .line 249
            goto 20
      StackMap locals:
      StackMap stack:
        18: iload 4 /* selectedQop */
            iconst_2
            iand
            ifeq 20
        19: .line 250
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.integrity:Z
        20: .line 256
      StackMap locals:
      StackMap stack:
            aload 3 /* gssOutToken */
            iconst_1
            iconst_3
            invokestatic com.sun.security.sasl.gsskerb.GssKrb5Server.networkByteOrderToInt:([BII)I
            istore 5 /* clntMaxBufSize */
        start local 5 // int clntMaxBufSize
        21: .line 260
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.sendMaxBufSize:I
            ifne 22
            iload 5 /* clntMaxBufSize */
            goto 23
        22: .line 261
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server byte[] org.ietf.jgss.MessageProp byte[] int int
      StackMap stack: com.sun.security.sasl.gsskerb.GssKrb5Server
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.sendMaxBufSize:I
            iload 5 /* clntMaxBufSize */
            invokestatic java.lang.Math.min:(II)I
        23: .line 260
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server byte[] org.ietf.jgss.MessageProp byte[] int int
      StackMap stack: com.sun.security.sasl.gsskerb.GssKrb5Server int
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.sendMaxBufSize:I
        24: .line 264
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.secCtx:Lorg/ietf/jgss/GSSContext;
            iconst_0
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.privacy:Z
        25: .line 265
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.sendMaxBufSize:I
        26: .line 264
            invokeinterface org.ietf.jgss.GSSContext.getWrapSizeLimit:(IZI)I
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.rawSendSize:I
        27: .line 267
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.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 40
        28: .line 268
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        29: .line 269
            ldc "KRB5SRV10:Selected protection: {0}; privacy: {1}; integrity: {2}"
        30: .line 270
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            new java.lang.Byte
            dup
            iload 4 /* selectedQop */
            invokespecial java.lang.Byte.<init>:(B)V
            aastore
            dup
            iconst_1
        31: .line 271
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.privacy:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            aastore
            dup
            iconst_2
        32: .line 272
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.integrity:Z
            invokestatic java.lang.Boolean.valueOf:(Z)Ljava/lang/Boolean;
            aastore
        33: .line 268
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
        34: .line 273
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
        35: .line 274
            ldc "KRB5SRV11:Client max recv size: {0}; server max send size: {1}; rawSendSize: {2}"
        36: .line 275
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            new java.lang.Integer
            dup
            iload 5 /* clntMaxBufSize */
            invokespecial java.lang.Integer.<init>:(I)V
            aastore
            dup
            iconst_1
        37: .line 276
            new java.lang.Integer
            dup
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.sendMaxBufSize:I
            invokespecial java.lang.Integer.<init>:(I)V
            aastore
            dup
            iconst_2
        38: .line 277
            new java.lang.Integer
            dup
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.rawSendSize:I
            invokespecial java.lang.Integer.<init>:(I)V
            aastore
        39: .line 273
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;[Ljava/lang/Object;)V
        40: .line 281
      StackMap locals:
      StackMap stack:
            aload 3 /* gssOutToken */
            arraylength
            iconst_4
            if_icmple 47
        41: .line 283
            aload 0 /* this */
            new java.lang.String
            dup
            aload 3 /* gssOutToken */
            iconst_4
        42: .line 284
            aload 3 /* gssOutToken */
            arraylength
            iconst_4
            isub
            ldc "UTF-8"
            invokespecial java.lang.String.<init>:([BIILjava/lang/String;)V
        43: .line 283
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
        44: .line 285
            goto 48
      StackMap locals:
      StackMap stack: java.io.UnsupportedEncodingException
        45: astore 6 /* uee */
        start local 6 // java.io.UnsupportedEncodingException uee
        46: .line 286
            new javax.security.sasl.SaslException
            dup
            ldc "Cannot decode authzid"
            aload 6 /* uee */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 6 // java.io.UnsupportedEncodingException uee
        47: .line 289
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.peer:Ljava/lang/String;
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
        48: .line 291
      StackMap locals:
      StackMap stack:
            getstatic com.sun.security.sasl.gsskerb.GssKrb5Server.logger:Ljava/util/logging/Logger;
            getstatic java.util.logging.Level.FINE:Ljava/util/logging/Level;
            ldc "KRB5SRV12:Authzid: {0}"
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
            invokevirtual java.util.logging.Logger.log:(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Object;)V
        49: .line 293
            new javax.security.sasl.AuthorizeCallback
            dup
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.peer:Ljava/lang/String;
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
            invokespecial javax.security.sasl.AuthorizeCallback.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            astore 6 /* acb */
        start local 6 // javax.security.sasl.AuthorizeCallback acb
        50: .line 296
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.cbh:Ljavax/security/auth/callback/CallbackHandler;
            iconst_1
            anewarray javax.security.auth.callback.Callback
            dup
            iconst_0
            aload 6 /* acb */
            aastore
            invokeinterface javax.security.auth.callback.CallbackHandler.handle:([Ljavax/security/auth/callback/Callback;)V
        51: .line 297
            aload 6 /* acb */
            invokevirtual javax.security.sasl.AuthorizeCallback.isAuthorized:()Z
            ifeq 55
        52: .line 298
            aload 0 /* this */
            aload 6 /* acb */
            invokevirtual javax.security.sasl.AuthorizeCallback.getAuthorizedID:()Ljava/lang/String;
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
        53: .line 299
            aload 0 /* this */
            iconst_1
            putfield com.sun.security.sasl.gsskerb.GssKrb5Server.completed:Z
        54: .line 300
            goto 58
        55: .line 302
      StackMap locals: javax.security.sasl.AuthorizeCallback
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
            new java.lang.StringBuilder
            dup
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.peer:Ljava/lang/String;
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        56: .line 303
            ldc " is not authorized to connect as "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        57: .line 302
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        58: .line 306
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 6 // javax.security.sasl.AuthorizeCallback acb
        end local 5 // int clntMaxBufSize
        end local 4 // byte selectedQop
        end local 3 // byte[] gssOutToken
        end local 2 // org.ietf.jgss.MessageProp msgProp
        59: .line 307
      StackMap locals: com.sun.security.sasl.gsskerb.GssKrb5Server byte[]
      StackMap stack: org.ietf.jgss.GSSException
            astore 2 /* e */
        start local 2 // org.ietf.jgss.GSSException e
        60: .line 308
            new javax.security.sasl.SaslException
            dup
            ldc "Final handshake step 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
        61: .line 309
      StackMap locals:
      StackMap stack: java.io.IOException
            astore 2 /* e */
        start local 2 // java.io.IOException e
        62: .line 310
            new javax.security.sasl.SaslException
            dup
            ldc "Problem with callback handler"
            aload 2 /* e */
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 2 // java.io.IOException e
        63: .line 311
      StackMap locals:
      StackMap stack: javax.security.auth.callback.UnsupportedCallbackException
            astore 2 /* e */
        start local 2 // javax.security.auth.callback.UnsupportedCallbackException e
        64: .line 312
            new javax.security.sasl.SaslException
            dup
            ldc "Problem with callback handler"
            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
        end local 1 // byte[] responseData
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   65     0            this  Lcom/sun/security/sasl/gsskerb/GssKrb5Server;
            0   65     1    responseData  [B
            1   59     2         msgProp  Lorg/ietf/jgss/MessageProp;
            4   59     3     gssOutToken  [B
           10   59     4     selectedQop  B
           21   59     5  clntMaxBufSize  I
           46   47     6             uee  Ljava/io/UnsupportedEncodingException;
           50   59     6             acb  Ljavax/security/sasl/AuthorizeCallback;
           60   61     2               e  Lorg/ietf/jgss/GSSException;
           62   63     2               e  Ljava/io/IOException;
           64   65     2               e  Ljavax/security/auth/callback/UnsupportedCallbackException;
      Exception table:
        from    to  target  type
          41    44      45  Class java.io.UnsupportedEncodingException
           0    58      59  Class org.ietf.jgss.GSSException
           0    58      61  Class java.io.IOException
           0    58      63  Class javax.security.auth.callback.UnsupportedCallbackException
    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.gsskerb.GssKrb5Server this
         0: .line 317
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.completed:Z
            ifeq 2
         1: .line 318
            aload 0 /* this */
            getfield com.sun.security.sasl.gsskerb.GssKrb5Server.authzid:Ljava/lang/String;
            areturn
         2: .line 320
      StackMap locals:
      StackMap stack:
            new java.lang.IllegalStateException
            dup
            ldc "Authentication incomplete"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 0 // com.sun.security.sasl.gsskerb.GssKrb5Server this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/sun/security/sasl/gsskerb/GssKrb5Server;
}
SourceFile: "GssKrb5Server.java"