class sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl extends sun.security.ssl.ClientKeyExchange
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl
  super_class: sun.security.ssl.ClientKeyExchange
{
  private final sun.security.krb5.internal.ssl.KerberosPreMasterSecret preMaster;
    descriptor: Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final byte[] encodedTicket;
    descriptor: [B
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final javax.security.auth.kerberos.KerberosPrincipal peerPrincipal;
    descriptor: Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final javax.security.auth.kerberos.KerberosPrincipal localPrincipal;
    descriptor: Ljavax/security/auth/kerberos/KerberosPrincipal;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public int messageLength();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
         0: .line 219
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.encodedTicket:[B
            arraylength
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
            invokevirtual sun.security.krb5.internal.ssl.KerberosPreMasterSecret.getEncrypted:()[B
            arraylength
            iadd
            bipush 6
            iadd
            ireturn
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;

  public void send(sun.security.ssl.HandshakeOutStream);
    descriptor: (Lsun/security/ssl/HandshakeOutStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
        start local 1 // sun.security.ssl.HandshakeOutStream s
         0: .line 224
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.encodedTicket:[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         1: .line 225
            aload 1 /* s */
            aconst_null
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         2: .line 226
            aload 1 /* s */
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
            invokevirtual sun.security.krb5.internal.ssl.KerberosPreMasterSecret.getEncrypted:()[B
            invokevirtual sun.security.ssl.HandshakeOutStream.putBytes16:([B)V
         3: .line 227
            return
        end local 1 // sun.security.ssl.HandshakeOutStream s
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;
            0    4     1     s  Lsun/security/ssl/HandshakeOutStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      s     

  public void print(java.io.PrintStream);
    descriptor: (Ljava/io/PrintStream;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
        start local 1 // java.io.PrintStream s
         0: .line 231
            aload 1 /* s */
            ldc "*** ClientKeyExchange, Kerberos"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         1: .line 233
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 5
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 5
         2: .line 234
            aload 1 /* s */
            ldc "Kerberos service ticket"
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.encodedTicket:[B
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         3: .line 235
            aload 1 /* s */
            ldc "Random Secret"
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
            invokevirtual sun.security.krb5.internal.ssl.KerberosPreMasterSecret.getUnencrypted:()[B
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         4: .line 236
            aload 1 /* s */
            ldc "Encrypted random Secret"
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
            invokevirtual sun.security.krb5.internal.ssl.KerberosPreMasterSecret.getEncrypted:()[B
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         5: .line 238
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.io.PrintStream s
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;
            0    6     1     s  Ljava/io/PrintStream;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
      Name  Flags
      s     

  void <init>(java.lang.String, java.security.AccessControlContext, sun.security.ssl.ProtocolVersion, java.security.SecureRandom);
    descriptor: (Ljava/lang/String;Ljava/security/AccessControlContext;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;)V
    flags: (0x0000) 
    Code:
      stack=6, locals=7, args_size=5
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
        start local 1 // java.lang.String serverName
        start local 2 // java.security.AccessControlContext acc
        start local 3 // sun.security.ssl.ProtocolVersion protocolVersion
        start local 4 // java.security.SecureRandom rand
         0: .line 240
            aload 0 /* this */
            invokespecial sun.security.ssl.ClientKeyExchange.<init>:()V
         1: .line 244
            aload 1 /* serverName */
            aload 2 /* acc */
            invokestatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.getServiceTicket:(Ljava/lang/String;Ljava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
            astore 5 /* ticket */
        start local 5 // javax.security.auth.kerberos.KerberosTicket ticket
         2: .line 245
            aload 0 /* this */
            aload 5 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getEncoded:()[B
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.encodedTicket:[B
         3: .line 248
            aload 0 /* this */
            aload 5 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getServer:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.peerPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         4: .line 249
            aload 0 /* this */
            aload 5 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getClient:()Ljavax/security/auth/kerberos/KerberosPrincipal;
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.localPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
         5: .line 255
            new sun.security.krb5.EncryptionKey
            dup
         6: .line 256
            aload 5 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getSessionKeyType:()I
         7: .line 257
            aload 5 /* ticket */
            invokevirtual javax.security.auth.kerberos.KerberosTicket.getSessionKey:()Ljavax/crypto/SecretKey;
            invokeinterface javax.crypto.SecretKey.getEncoded:()[B
         8: .line 255
            invokespecial sun.security.krb5.EncryptionKey.<init>:(I[B)V
            astore 6 /* sessionKey */
        start local 6 // sun.security.krb5.EncryptionKey sessionKey
         9: .line 259
            aload 0 /* this */
            new sun.security.krb5.internal.ssl.KerberosPreMasterSecret
            dup
            aload 3 /* protocolVersion */
        10: .line 260
            aload 4 /* rand */
            aload 6 /* sessionKey */
            invokespecial sun.security.krb5.internal.ssl.KerberosPreMasterSecret.<init>:(Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;Lsun/security/krb5/EncryptionKey;)V
        11: .line 259
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
        12: .line 261
            return
        end local 6 // sun.security.krb5.EncryptionKey sessionKey
        end local 5 // javax.security.auth.kerberos.KerberosTicket ticket
        end local 4 // java.security.SecureRandom rand
        end local 3 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.lang.String serverName
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   13     0             this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;
            0   13     1       serverName  Ljava/lang/String;
            0   13     2              acc  Ljava/security/AccessControlContext;
            0   13     3  protocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   13     4             rand  Ljava/security/SecureRandom;
            2   13     5           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
            9   13     6       sessionKey  Lsun/security/krb5/EncryptionKey;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                 Name  Flags
      serverName       
      acc              
      protocolVersion  
      rand             

  void <init>(sun.security.ssl.ProtocolVersion, sun.security.ssl.ProtocolVersion, java.security.SecureRandom, byte[], byte[], java.security.AccessControlContext, java.lang.Object);
    descriptor: (Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;[B[BLjava/security/AccessControlContext;Ljava/lang/Object;)V
    flags: (0x0000) 
    Code:
      stack=8, locals=24, args_size=8
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
        start local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        start local 2 // sun.security.ssl.ProtocolVersion clientVersion
        start local 3 // java.security.SecureRandom rand
        start local 4 // byte[] encodedTicket
        start local 5 // byte[] encrypted
        start local 6 // java.security.AccessControlContext acc
        start local 7 // java.lang.Object serviceCreds
         0: .line 263
            aload 0 /* this */
            invokespecial sun.security.ssl.ClientKeyExchange.<init>:()V
         1: .line 269
            aload 0 /* this */
            aload 4 /* encodedTicket */
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.encodedTicket:[B
         2: .line 271
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 6
            ldc "verbose"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 6
         3: .line 272
            getstatic java.lang.System.out:Ljava/io/PrintStream;
         4: .line 273
            ldc "encoded Kerberos service ticket"
            aload 4 /* encodedTicket */
         5: .line 272
            invokestatic sun.security.ssl.Debug.println:(Ljava/io/PrintStream;Ljava/lang/String;[B)V
         6: .line 276
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom byte[] byte[] java.security.AccessControlContext java.lang.Object
      StackMap stack:
            aconst_null
            astore 8 /* sessionKey */
        start local 8 // sun.security.krb5.EncryptionKey sessionKey
         7: .line 277
            aconst_null
            astore 9 /* tmpPeer */
        start local 9 // javax.security.auth.kerberos.KerberosPrincipal tmpPeer
         8: .line 278
            aconst_null
            astore 10 /* tmpLocal */
        start local 10 // javax.security.auth.kerberos.KerberosPrincipal tmpLocal
         9: .line 281
            new sun.security.krb5.internal.Ticket
            dup
            aload 4 /* encodedTicket */
            invokespecial sun.security.krb5.internal.Ticket.<init>:([B)V
            astore 11 /* t */
        start local 11 // sun.security.krb5.internal.Ticket t
        10: .line 283
            aload 11 /* t */
            getfield sun.security.krb5.internal.Ticket.encPart:Lsun/security/krb5/EncryptedData;
            astore 12 /* encPart */
        start local 12 // sun.security.krb5.EncryptedData encPart
        11: .line 284
            aload 11 /* t */
            getfield sun.security.krb5.internal.Ticket.sname:Lsun/security/krb5/PrincipalName;
            astore 13 /* ticketSname */
        start local 13 // sun.security.krb5.PrincipalName ticketSname
        12: .line 286
            aload 7 /* serviceCreds */
            checkcast sun.security.jgss.krb5.ServiceCreds
            astore 14 /* creds */
        start local 14 // sun.security.jgss.krb5.ServiceCreds creds
        13: .line 288
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 13 /* ticketSname */
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
        14: .line 287
            astore 15 /* princ */
        start local 15 // javax.security.auth.kerberos.KerberosPrincipal princ
        15: .line 291
            aload 14 /* creds */
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getName:()Ljava/lang/String;
            ifnonnull 28
        16: .line 292
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 16 /* sm */
        start local 16 // java.lang.SecurityManager sm
        17: .line 294
            aload 16 /* sm */
            ifnull 28
        18: .line 296
            aload 16 /* sm */
            new javax.security.auth.kerberos.ServicePermission
            dup
        19: .line 297
            aload 13 /* ticketSname */
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            ldc "accept"
            invokespecial javax.security.auth.kerberos.ServicePermission.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            aload 6 /* acc */
        20: .line 296
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;Ljava/lang/Object;)V
        21: .line 299
            goto 28
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom byte[] byte[] java.security.AccessControlContext java.lang.Object sun.security.krb5.EncryptionKey javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal sun.security.krb5.internal.Ticket sun.security.krb5.EncryptedData sun.security.krb5.PrincipalName sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal java.lang.SecurityManager
      StackMap stack: java.lang.SecurityException
        22: astore 17 /* se */
        start local 17 // java.lang.SecurityException se
        23: .line 300
            aconst_null
            astore 7 /* serviceCreds */
        24: .line 302
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 27
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 27
        25: .line 303
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Permission to access Kerberos secret key denied"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        26: .line 305
            aload 17 /* se */
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            invokevirtual java.lang.SecurityException.printStackTrace:(Ljava/io/PrintStream;)V
        27: .line 307
      StackMap locals: java.lang.SecurityException
      StackMap stack:
            new java.io.IOException
            dup
            ldc "Kerberos service not allowedy"
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        end local 17 // java.lang.SecurityException se
        end local 16 // java.lang.SecurityManager sm
        28: .line 311
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$1
            dup
            aload 0 /* this */
            aload 14 /* creds */
            aload 15 /* princ */
            invokespecial sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$1.<init>:(Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;Lsun/security/jgss/krb5/ServiceCreds;Ljavax/security/auth/kerberos/KerberosPrincipal;)V
        29: .line 310
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosKey[]
            astore 16 /* serverKeys */
        start local 16 // javax.security.auth.kerberos.KerberosKey[] serverKeys
        30: .line 317
            aload 16 /* serverKeys */
            arraylength
            ifne 36
        31: .line 318
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Found no key for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 15 /* princ */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
        32: .line 319
            aload 14 /* creds */
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getName:()Ljava/lang/String;
            ifnonnull 33
            ldc ""
            goto 34
        33: .line 320
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom byte[] byte[] java.security.AccessControlContext java.lang.Object sun.security.krb5.EncryptionKey javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal sun.security.krb5.internal.Ticket sun.security.krb5.EncryptedData sun.security.krb5.PrincipalName sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosKey[]
      StackMap stack: new 31 new 31 java.lang.StringBuilder
            new java.lang.StringBuilder
            dup
            ldc ", this keytab is for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 14 /* creds */
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " only"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        34: .line 319
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom byte[] byte[] java.security.AccessControlContext java.lang.Object sun.security.krb5.EncryptionKey javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal sun.security.krb5.internal.Ticket sun.security.krb5.EncryptedData sun.security.krb5.PrincipalName sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosKey[]
      StackMap stack: new 31 new 31 java.lang.StringBuilder java.lang.String
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 318
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        36: .line 332
      StackMap locals:
      StackMap stack:
            aload 12 /* encPart */
            invokevirtual sun.security.krb5.EncryptedData.getEType:()I
            istore 17 /* encPartKeyType */
        start local 17 // int encPartKeyType
        37: .line 333
            aload 12 /* encPart */
            invokevirtual sun.security.krb5.EncryptedData.getKeyVersionNumber:()Ljava/lang/Integer;
            astore 18 /* encPartKeyVersion */
        start local 18 // java.lang.Integer encPartKeyVersion
        38: .line 334
            aconst_null
            astore 19 /* dkey */
        start local 19 // javax.security.auth.kerberos.KerberosKey dkey
        39: .line 336
            iload 17 /* encPartKeyType */
            aload 18 /* encPartKeyVersion */
            aload 16 /* serverKeys */
            invokestatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.findKey:(ILjava/lang/Integer;[Ljavax/security/auth/kerberos/KerberosKey;)Ljavax/security/auth/kerberos/KerberosKey;
            astore 19 /* dkey */
        40: .line 337
            goto 45
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom byte[] byte[] java.security.AccessControlContext java.lang.Object sun.security.krb5.EncryptionKey javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal sun.security.krb5.internal.Ticket sun.security.krb5.EncryptedData sun.security.krb5.PrincipalName sun.security.jgss.krb5.ServiceCreds javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosKey[] int java.lang.Integer javax.security.auth.kerberos.KerberosKey
      StackMap stack: sun.security.krb5.KrbException
        41: astore 20 /* ke */
        start local 20 // sun.security.krb5.KrbException ke
        42: .line 338
            new java.io.IOException
            dup
        43: .line 339
            ldc "Cannot find key matching version number"
            aload 20 /* ke */
        44: .line 338
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;Ljava/lang/Throwable;)V
            athrow
        end local 20 // sun.security.krb5.KrbException ke
        45: .line 341
      StackMap locals:
      StackMap stack:
            aload 19 /* dkey */
            ifnonnull 49
        46: .line 343
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Cannot find key of appropriate type to decrypt ticket - need etype "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        47: .line 344
            iload 17 /* encPartKeyType */
            invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        48: .line 343
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        49: .line 347
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.EncryptionKey
            dup
        50: .line 348
            iload 17 /* encPartKeyType */
        51: .line 349
            aload 19 /* dkey */
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
        52: .line 347
            invokespecial sun.security.krb5.EncryptionKey.<init>:(I[B)V
            astore 20 /* secretKey */
        start local 20 // sun.security.krb5.EncryptionKey secretKey
        53: .line 352
            aload 12 /* encPart */
            aload 20 /* secretKey */
            iconst_2
            invokevirtual sun.security.krb5.EncryptedData.decrypt:(Lsun/security/krb5/EncryptionKey;I)[B
            astore 21 /* bytes */
        start local 21 // byte[] bytes
        54: .line 355
            aload 12 /* encPart */
            aload 21 /* bytes */
            invokevirtual sun.security.krb5.EncryptedData.reset:([B)[B
            astore 22 /* temp */
        start local 22 // byte[] temp
        55: .line 356
            new sun.security.krb5.internal.EncTicketPart
            dup
            aload 22 /* temp */
            invokespecial sun.security.krb5.internal.EncTicketPart.<init>:([B)V
            astore 23 /* encTicketPart */
        start local 23 // sun.security.krb5.internal.EncTicketPart encTicketPart
        56: .line 359
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 23 /* encTicketPart */
            getfield sun.security.krb5.internal.EncTicketPart.cname:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
            astore 9 /* tmpPeer */
        57: .line 360
            new javax.security.auth.kerberos.KerberosPrincipal
            dup
            aload 13 /* ticketSname */
            invokevirtual sun.security.krb5.PrincipalName.getName:()Ljava/lang/String;
            invokespecial javax.security.auth.kerberos.KerberosPrincipal.<init>:(Ljava/lang/String;)V
            astore 10 /* tmpLocal */
        58: .line 362
            aload 23 /* encTicketPart */
            getfield sun.security.krb5.internal.EncTicketPart.key:Lsun/security/krb5/EncryptionKey;
            astore 8 /* sessionKey */
        59: .line 364
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 71
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 71
        60: .line 365
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "server principal: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 13 /* ticketSname */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        61: .line 366
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "cname: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 23 /* encTicketPart */
            getfield sun.security.krb5.internal.EncTicketPart.cname:Lsun/security/krb5/PrincipalName;
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        end local 23 // sun.security.krb5.internal.EncTicketPart encTicketPart
        end local 22 // byte[] temp
        end local 21 // byte[] bytes
        end local 20 // sun.security.krb5.EncryptionKey secretKey
        end local 19 // javax.security.auth.kerberos.KerberosKey dkey
        end local 18 // java.lang.Integer encPartKeyVersion
        end local 17 // int encPartKeyType
        end local 16 // javax.security.auth.kerberos.KerberosKey[] serverKeys
        end local 15 // javax.security.auth.kerberos.KerberosPrincipal princ
        end local 14 // sun.security.jgss.krb5.ServiceCreds creds
        end local 13 // sun.security.krb5.PrincipalName ticketSname
        end local 12 // sun.security.krb5.EncryptedData encPart
        end local 11 // sun.security.krb5.internal.Ticket t
        62: .line 368
            goto 71
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl sun.security.ssl.ProtocolVersion sun.security.ssl.ProtocolVersion java.security.SecureRandom byte[] byte[] java.security.AccessControlContext java.lang.Object sun.security.krb5.EncryptionKey javax.security.auth.kerberos.KerberosPrincipal javax.security.auth.kerberos.KerberosPrincipal
      StackMap stack: java.io.IOException
        63: astore 11 /* e */
        start local 11 // java.io.IOException e
        64: .line 369
            aload 11 /* e */
            athrow
        end local 11 // java.io.IOException e
        65: .line 370
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 11 /* e */
        start local 11 // java.lang.Exception e
        66: .line 371
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 70
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 70
        67: .line 372
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "KerberosWrapper error getting session key, generating random secret ("
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        68: .line 373
            aload 11 /* e */
            invokevirtual java.lang.Exception.getMessage:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc ")"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        69: .line 372
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        70: .line 375
      StackMap locals: java.lang.Exception
      StackMap stack:
            aconst_null
            astore 8 /* sessionKey */
        end local 11 // java.lang.Exception e
        71: .line 380
      StackMap locals:
      StackMap stack:
            aload 8 /* sessionKey */
            ifnull 76
        72: .line 381
            aload 0 /* this */
            new sun.security.krb5.internal.ssl.KerberosPreMasterSecret
            dup
            aload 1 /* protocolVersion */
        73: .line 382
            aload 2 /* clientVersion */
            aload 3 /* rand */
            aload 5 /* encrypted */
            aload 8 /* sessionKey */
            invokespecial sun.security.krb5.internal.ssl.KerberosPreMasterSecret.<init>:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;[BLsun/security/krb5/EncryptionKey;)V
        74: .line 381
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
        75: .line 383
            goto 77
        76: .line 385
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            new sun.security.krb5.internal.ssl.KerberosPreMasterSecret
            dup
            aload 2 /* clientVersion */
            aload 3 /* rand */
            invokespecial sun.security.krb5.internal.ssl.KerberosPreMasterSecret.<init>:(Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;)V
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
        77: .line 388
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 9 /* tmpPeer */
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.peerPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
        78: .line 389
            aload 0 /* this */
            aload 10 /* tmpLocal */
            putfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.localPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
        79: .line 390
            return
        end local 10 // javax.security.auth.kerberos.KerberosPrincipal tmpLocal
        end local 9 // javax.security.auth.kerberos.KerberosPrincipal tmpPeer
        end local 8 // sun.security.krb5.EncryptionKey sessionKey
        end local 7 // java.lang.Object serviceCreds
        end local 6 // java.security.AccessControlContext acc
        end local 5 // byte[] encrypted
        end local 4 // byte[] encodedTicket
        end local 3 // java.security.SecureRandom rand
        end local 2 // sun.security.ssl.ProtocolVersion clientVersion
        end local 1 // sun.security.ssl.ProtocolVersion protocolVersion
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0   80     0               this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;
            0   80     1    protocolVersion  Lsun/security/ssl/ProtocolVersion;
            0   80     2      clientVersion  Lsun/security/ssl/ProtocolVersion;
            0   80     3               rand  Ljava/security/SecureRandom;
            0   80     4      encodedTicket  [B
            0   80     5          encrypted  [B
            0   80     6                acc  Ljava/security/AccessControlContext;
            0   80     7       serviceCreds  Ljava/lang/Object;
            7   80     8         sessionKey  Lsun/security/krb5/EncryptionKey;
            8   80     9            tmpPeer  Ljavax/security/auth/kerberos/KerberosPrincipal;
            9   80    10           tmpLocal  Ljavax/security/auth/kerberos/KerberosPrincipal;
           10   62    11                  t  Lsun/security/krb5/internal/Ticket;
           11   62    12            encPart  Lsun/security/krb5/EncryptedData;
           12   62    13        ticketSname  Lsun/security/krb5/PrincipalName;
           13   62    14              creds  Lsun/security/jgss/krb5/ServiceCreds;
           15   62    15              princ  Ljavax/security/auth/kerberos/KerberosPrincipal;
           17   28    16                 sm  Ljava/lang/SecurityManager;
           23   28    17                 se  Ljava/lang/SecurityException;
           30   62    16         serverKeys  [Ljavax/security/auth/kerberos/KerberosKey;
           37   62    17     encPartKeyType  I
           38   62    18  encPartKeyVersion  Ljava/lang/Integer;
           39   62    19               dkey  Ljavax/security/auth/kerberos/KerberosKey;
           42   45    20                 ke  Lsun/security/krb5/KrbException;
           53   62    20          secretKey  Lsun/security/krb5/EncryptionKey;
           54   62    21              bytes  [B
           55   62    22               temp  [B
           56   62    23      encTicketPart  Lsun/security/krb5/internal/EncTicketPart;
           64   65    11                  e  Ljava/io/IOException;
           66   71    11                  e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
          17    21      22  Class java.lang.SecurityException
          39    40      41  Class sun.security.krb5.KrbException
           9    62      63  Class java.io.IOException
           9    62      65  Class java.lang.Exception
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                 Name  Flags
      protocolVersion  
      clientVersion    
      rand             
      encodedTicket    
      encrypted        
      acc              
      serviceCreds     

  private static javax.security.auth.kerberos.KerberosTicket getServiceTicket(java.lang.String, java.security.AccessControlContext);
    descriptor: (Ljava/lang/String;Ljava/security/AccessControlContext;)Ljavax/security/auth/kerberos/KerberosTicket;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=11, args_size=2
        start local 0 // java.lang.String serverName
        start local 1 // java.security.AccessControlContext acc
         0: .line 396
            ldc "localhost"
            aload 0 /* serverName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifne 2
         1: .line 397
            ldc "localhost.localdomain"
            aload 0 /* serverName */
            invokevirtual java.lang.String.equals:(Ljava/lang/Object;)Z
            ifeq 8
         2: .line 399
      StackMap locals:
      StackMap stack:
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.debug:Lsun/security/ssl/Debug;
            ifnull 4
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 4
         3: .line 400
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Get the local hostname"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         4: .line 403
      StackMap locals:
      StackMap stack:
            new sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$2
            dup
            invokespecial sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$2.<init>:()V
         5: .line 402
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedAction;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 2 /* localHost */
        start local 2 // java.lang.String localHost
         6: .line 417
            aload 2 /* localHost */
            ifnull 8
         7: .line 418
            aload 2 /* localHost */
            astore 0 /* serverName */
        end local 2 // java.lang.String localHost
         8: .line 424
      StackMap locals:
      StackMap stack:
            new java.lang.StringBuilder
            dup
            ldc "host/"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* serverName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 2 /* serviceName */
        start local 2 // java.lang.String serviceName
         9: .line 427
            new sun.security.krb5.PrincipalName
            dup
            aload 2 /* serviceName */
        10: .line 428
            iconst_3
        11: .line 427
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;I)V
            astore 3 /* principal */
        start local 3 // sun.security.krb5.PrincipalName principal
        12: .line 429
            goto 21
        end local 3 // sun.security.krb5.PrincipalName principal
      StackMap locals: java.lang.String java.security.AccessControlContext java.lang.String
      StackMap stack: java.lang.SecurityException
        13: astore 4 /* se */
        start local 4 // java.lang.SecurityException se
        14: .line 430
            aload 4 /* se */
            athrow
        end local 4 // java.lang.SecurityException se
        15: .line 431
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 4 /* e */
        start local 4 // java.lang.Exception e
        16: .line 432
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Invalid service principal name: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        17: .line 433
            aload 2 /* serviceName */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        18: .line 432
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            astore 5 /* ioe */
        start local 5 // java.io.IOException ioe
        19: .line 434
            aload 5 /* ioe */
            aload 4 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        20: .line 435
            aload 5 /* ioe */
            athrow
        end local 5 // java.io.IOException ioe
        end local 4 // java.lang.Exception e
        start local 3 // sun.security.krb5.PrincipalName principal
        21: .line 437
      StackMap locals: sun.security.krb5.PrincipalName
      StackMap stack:
            aload 3 /* principal */
            invokevirtual sun.security.krb5.PrincipalName.getRealmAsString:()Ljava/lang/String;
            astore 4 /* realm */
        start local 4 // java.lang.String realm
        22: .line 439
            aload 3 /* principal */
            invokevirtual sun.security.krb5.PrincipalName.toString:()Ljava/lang/String;
            astore 5 /* serverPrincipal */
        start local 5 // java.lang.String serverPrincipal
        23: .line 440
            new java.lang.StringBuilder
            dup
            ldc "krbtgt/"
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 4 /* realm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc "@"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 4 /* realm */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 6 /* tgsPrincipal */
        start local 6 // java.lang.String tgsPrincipal
        24: .line 441
            aconst_null
            astore 7 /* clientPrincipal */
        start local 7 // java.lang.String clientPrincipal
        25: .line 446
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 8 /* sm */
        start local 8 // java.lang.SecurityManager sm
        26: .line 447
            aload 8 /* sm */
            ifnull 30
        27: .line 448
            aload 8 /* sm */
            new javax.security.auth.kerberos.ServicePermission
            dup
            aload 5 /* serverPrincipal */
        28: .line 449
            ldc "initiate"
            invokespecial javax.security.auth.kerberos.ServicePermission.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            aload 1 /* acc */
        29: .line 448
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;Ljava/lang/Object;)V
        30: .line 454
      StackMap locals: java.lang.String java.security.AccessControlContext java.lang.String sun.security.krb5.PrincipalName java.lang.String java.lang.String java.lang.String java.lang.String java.lang.SecurityManager
      StackMap stack:
            new sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$3
            dup
            aload 7 /* clientPrincipal */
            aload 5 /* serverPrincipal */
            aload 6 /* tgsPrincipal */
            aload 1 /* acc */
            invokespecial sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$3.<init>:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/security/AccessControlContext;)V
        31: .line 453
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KerberosTicket
            astore 9 /* ticket */
        start local 9 // javax.security.auth.kerberos.KerberosTicket ticket
        32: .line 462
            aload 9 /* ticket */
            ifnonnull 36
        33: .line 463
            new java.io.IOException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Failed to find any kerberos service ticket for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        34: .line 464
            aload 5 /* serverPrincipal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        35: .line 463
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            athrow
        36: .line 466
      StackMap locals: javax.security.auth.kerberos.KerberosTicket
      StackMap stack:
            aload 9 /* ticket */
        37: areturn
        end local 9 // javax.security.auth.kerberos.KerberosTicket ticket
        38: .line 467
      StackMap locals: java.lang.String java.security.AccessControlContext java.lang.String sun.security.krb5.PrincipalName java.lang.String java.lang.String java.lang.String java.lang.String java.lang.SecurityManager
      StackMap stack: java.security.PrivilegedActionException
            astore 9 /* e */
        start local 9 // java.security.PrivilegedActionException e
        39: .line 468
            new java.io.IOException
            dup
        40: .line 469
            new java.lang.StringBuilder
            dup
            ldc "Attempt to obtain kerberos service ticket for "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        41: .line 470
            aload 5 /* serverPrincipal */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            ldc " failed!"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        42: .line 469
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        43: .line 468
            invokespecial java.io.IOException.<init>:(Ljava/lang/String;)V
            astore 10 /* ioe */
        start local 10 // java.io.IOException ioe
        44: .line 471
            aload 10 /* ioe */
            aload 9 /* e */
            invokevirtual java.io.IOException.initCause:(Ljava/lang/Throwable;)Ljava/lang/Throwable;
            pop
        45: .line 472
            aload 10 /* ioe */
            athrow
        end local 10 // java.io.IOException ioe
        end local 9 // java.security.PrivilegedActionException e
        end local 8 // java.lang.SecurityManager sm
        end local 7 // java.lang.String clientPrincipal
        end local 6 // java.lang.String tgsPrincipal
        end local 5 // java.lang.String serverPrincipal
        end local 4 // java.lang.String realm
        end local 3 // sun.security.krb5.PrincipalName principal
        end local 2 // java.lang.String serviceName
        end local 1 // java.security.AccessControlContext acc
        end local 0 // java.lang.String serverName
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   46     0       serverName  Ljava/lang/String;
            0   46     1              acc  Ljava/security/AccessControlContext;
            6    8     2        localHost  Ljava/lang/String;
            9   46     2      serviceName  Ljava/lang/String;
           12   13     3        principal  Lsun/security/krb5/PrincipalName;
           21   46     3        principal  Lsun/security/krb5/PrincipalName;
           14   15     4               se  Ljava/lang/SecurityException;
           16   21     4                e  Ljava/lang/Exception;
           19   21     5              ioe  Ljava/io/IOException;
           22   46     4            realm  Ljava/lang/String;
           23   46     5  serverPrincipal  Ljava/lang/String;
           24   46     6     tgsPrincipal  Ljava/lang/String;
           25   46     7  clientPrincipal  Ljava/lang/String;
           26   46     8               sm  Ljava/lang/SecurityManager;
           32   38     9           ticket  Ljavax/security/auth/kerberos/KerberosTicket;
           39   46     9                e  Ljava/security/PrivilegedActionException;
           44   46    10              ioe  Ljava/io/IOException;
      Exception table:
        from    to  target  type
           9    12      13  Class java.lang.SecurityException
           9    12      15  Class java.lang.Exception
          30    37      38  Class java.security.PrivilegedActionException
    Exceptions:
      throws java.io.IOException
    MethodParameters:
            Name  Flags
      serverName  
      acc         final

  public javax.crypto.SecretKey clientKeyExchange();
    descriptor: ()Ljavax/crypto/SecretKey;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
         0: .line 478
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.preMaster:Lsun/security/krb5/internal/ssl/KerberosPreMasterSecret;
            invokevirtual sun.security.krb5.internal.ssl.KerberosPreMasterSecret.getUnencrypted:()[B
            astore 1 /* secretBytes */
        start local 1 // byte[] secretBytes
         1: .line 479
            new javax.crypto.spec.SecretKeySpec
            dup
            aload 1 /* secretBytes */
            ldc "TlsPremasterSecret"
            invokespecial javax.crypto.spec.SecretKeySpec.<init>:([BLjava/lang/String;)V
            areturn
        end local 1 // byte[] secretBytes
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;
            1    2     1  secretBytes  [B

  public java.security.Principal getPeerPrincipal();
    descriptor: ()Ljava/security/Principal;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
         0: .line 484
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.peerPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;

  public java.security.Principal getLocalPrincipal();
    descriptor: ()Ljava/security/Principal;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
         0: .line 489
            aload 0 /* this */
            getfield sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.localPrincipal:Ljavax/security/auth/kerberos/KerberosPrincipal;
            areturn
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService$ExchangerImpl;

  private static boolean versionMatches(java.lang.Integer, int);
    descriptor: (Ljava/lang/Integer;I)Z
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // java.lang.Integer v1
        start local 1 // int v2
         0: .line 503
            aload 0 /* v1 */
            ifnull 1
            aload 0 /* v1 */
            invokevirtual java.lang.Integer.intValue:()I
            ifeq 1
            iload 1 /* v2 */
            ifne 2
         1: .line 504
      StackMap locals:
      StackMap stack:
            iconst_1
            ireturn
         2: .line 506
      StackMap locals:
      StackMap stack:
            aload 0 /* v1 */
            iload 1 /* v2 */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokevirtual java.lang.Integer.equals:(Ljava/lang/Object;)Z
            ireturn
        end local 1 // int v2
        end local 0 // java.lang.Integer v1
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0    v1  Ljava/lang/Integer;
            0    3     1    v2  I
    MethodParameters:
      Name  Flags
      v1    
      v2    

  private static javax.security.auth.kerberos.KerberosKey findKey(int, java.lang.Integer, javax.security.auth.kerberos.KerberosKey[]);
    descriptor: (ILjava/lang/Integer;[Ljavax/security/auth/kerberos/KerberosKey;)Ljavax/security/auth/kerberos/KerberosKey;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=6, locals=9, args_size=3
        start local 0 // int etype
        start local 1 // java.lang.Integer version
        start local 2 // javax.security.auth.kerberos.KerberosKey[] keys
         0: .line 512
            iconst_0
            istore 4 /* etypeFound */
        start local 4 // boolean etypeFound
         1: .line 516
            iconst_0
            istore 5 /* kvno_found */
        start local 5 // int kvno_found
         2: .line 517
            aconst_null
            astore 6 /* key_found */
        start local 6 // javax.security.auth.kerberos.KerberosKey key_found
         3: .line 519
            iconst_0
            istore 7 /* i */
        start local 7 // int i
         4: goto 15
         5: .line 520
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] top int int javax.security.auth.kerberos.KerberosKey int
      StackMap stack:
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            istore 3 /* ktype */
        start local 3 // int ktype
         6: .line 521
            iload 0 /* etype */
            iload 3 /* ktype */
            if_icmpne 14
         7: .line 522
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
            istore 8 /* kv */
        start local 8 // int kv
         8: .line 523
            iconst_1
            istore 4 /* etypeFound */
         9: .line 524
            aload 1 /* version */
            iload 8 /* kv */
            invokestatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.versionMatches:(Ljava/lang/Integer;I)Z
            ifeq 11
        10: .line 525
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            areturn
        11: .line 526
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] int int int javax.security.auth.kerberos.KerberosKey int int
      StackMap stack:
            iload 8 /* kv */
            iload 5 /* kvno_found */
            if_icmple 14
        12: .line 527
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            astore 6 /* key_found */
        13: .line 528
            iload 8 /* kv */
            istore 5 /* kvno_found */
        end local 8 // int kv
        14: .line 519
      StackMap locals:
      StackMap stack:
            iinc 7 /* i */ 1
        end local 3 // int ktype
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] top int int javax.security.auth.kerberos.KerberosKey int
      StackMap stack:
        15: iload 7 /* i */
            aload 2 /* keys */
            arraylength
            if_icmplt 5
        end local 7 // int i
        16: .line 534
            iload 0 /* etype */
            iconst_1
            if_icmpeq 18
        17: .line 535
            iload 0 /* etype */
            iconst_3
            if_icmpne 40
        18: .line 536
      StackMap locals:
      StackMap stack:
            iconst_0
            istore 7 /* i */
        start local 7 // int i
        19: goto 39
        20: .line 537
      StackMap locals: int
      StackMap stack:
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getKeyType:()I
            istore 3 /* ktype */
        start local 3 // int ktype
        21: .line 538
            iload 3 /* ktype */
            iconst_1
            if_icmpeq 23
        22: .line 539
            iload 3 /* ktype */
            iconst_3
            if_icmpne 38
        23: .line 540
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] int int int javax.security.auth.kerberos.KerberosKey int
      StackMap stack:
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getVersionNumber:()I
            istore 8 /* kv */
        start local 8 // int kv
        24: .line 541
            iconst_1
            istore 4 /* etypeFound */
        25: .line 542
            aload 1 /* version */
            iload 8 /* kv */
            invokestatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.versionMatches:(Ljava/lang/Integer;I)Z
            ifeq 31
        26: .line 543
            new javax.security.auth.kerberos.KerberosKey
            dup
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
        27: .line 544
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
        28: .line 545
            iload 0 /* etype */
        29: .line 546
            iload 8 /* kv */
        30: .line 543
            invokespecial javax.security.auth.kerberos.KerberosKey.<init>:(Ljavax/security/auth/kerberos/KerberosPrincipal;[BII)V
            areturn
        31: .line 547
      StackMap locals: int
      StackMap stack:
            iload 8 /* kv */
            iload 5 /* kvno_found */
            if_icmple 38
        32: .line 548
            new javax.security.auth.kerberos.KerberosKey
            dup
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getPrincipal:()Ljavax/security/auth/kerberos/KerberosPrincipal;
        33: .line 549
            aload 2 /* keys */
            iload 7 /* i */
            aaload
            invokevirtual javax.security.auth.kerberos.KerberosKey.getEncoded:()[B
        34: .line 550
            iload 0 /* etype */
        35: .line 551
            iload 8 /* kv */
        36: .line 548
            invokespecial javax.security.auth.kerberos.KerberosKey.<init>:(Ljavax/security/auth/kerberos/KerberosPrincipal;[BII)V
            astore 6 /* key_found */
        37: .line 552
            iload 8 /* kv */
            istore 5 /* kvno_found */
        end local 8 // int kv
        38: .line 536
      StackMap locals:
      StackMap stack:
            iinc 7 /* i */ 1
        end local 3 // int ktype
      StackMap locals: int java.lang.Integer javax.security.auth.kerberos.KerberosKey[] top int int javax.security.auth.kerberos.KerberosKey int
      StackMap stack:
        39: iload 7 /* i */
            aload 2 /* keys */
            arraylength
            if_icmplt 20
        end local 7 // int i
        40: .line 557
      StackMap locals:
      StackMap stack:
            iload 4 /* etypeFound */
            ifeq 42
        41: .line 558
            aload 6 /* key_found */
            areturn
        42: .line 560
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 6 // javax.security.auth.kerberos.KerberosKey key_found
        end local 5 // int kvno_found
        end local 4 // boolean etypeFound
        end local 2 // javax.security.auth.kerberos.KerberosKey[] keys
        end local 1 // java.lang.Integer version
        end local 0 // int etype
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   43     0       etype  I
            0   43     1     version  Ljava/lang/Integer;
            0   43     2        keys  [Ljavax/security/auth/kerberos/KerberosKey;
            6   15     3       ktype  I
           21   39     3       ktype  I
            1   43     4  etypeFound  Z
            2   43     5  kvno_found  I
            3   43     6   key_found  Ljavax/security/auth/kerberos/KerberosKey;
            4   16     7           i  I
            8   14     8          kv  I
           19   40     7           i  I
           24   38     8          kv  I
    Exceptions:
      throws sun.security.krb5.KrbException
    MethodParameters:
         Name  Flags
      etype    
      version  
      keys     
}
SourceFile: "Krb5KeyExchangeService.java"
NestHost: sun.security.krb5.internal.ssl.Krb5KeyExchangeService
InnerClasses:
  ExchangerImpl = sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl of sun.security.krb5.internal.ssl.Krb5KeyExchangeService
  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$1
  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$2
  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$3