public class sun.security.krb5.internal.ssl.Krb5KeyExchangeService implements sun.security.ssl.ClientKeyExchangeService
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.krb5.internal.ssl.Krb5KeyExchangeService
  super_class: java.lang.Object
{
  public static final sun.security.ssl.Debug debug;
    descriptor: Lsun/security/ssl/Debug;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 72
            ldc "ssl"
            invokestatic sun.security.ssl.Debug.getInstance:(Ljava/lang/String;)Lsun/security/ssl/Debug;
            putstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
         0: .line 70
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;

  public java.lang.String[] supported();
    descriptor: ()[Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
         0: .line 76
            iconst_2
            anewarray java.lang.String
            dup
            iconst_0
            ldc "KRB5"
            aastore
            dup
            iconst_1
            ldc "KRB5_EXPORT"
            aastore
            areturn
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;

  public java.lang.Object getServiceCreds(java.security.AccessControlContext);
    descriptor: (Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
        start local 1 // java.security.AccessControlContext acc
         0: .line 84
            aload 1 /* acc */
            invokedynamic run(Ljava/security/AccessControlContext;)Ljava/security/PrivilegedExceptionAction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()Ljava/lang/Object;
                  sun/security/krb5/internal/ssl/Krb5KeyExchangeService.lambda$0(Ljava/security/AccessControlContext;)Lsun/security/jgss/krb5/ServiceCreds; (6)
                  ()Lsun/security/jgss/krb5/ServiceCreds;
         1: .line 82
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast sun.security.jgss.krb5.ServiceCreds
            astore 2 /* serviceCreds */
        start local 2 // sun.security.jgss.krb5.ServiceCreds serviceCreds
         2: .line 86
            aload 2 /* serviceCreds */
            ifnonnull 6
         3: .line 87
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            ifnull 5
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 5
         4: .line 88
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Kerberos serviceCreds not available"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         5: .line 90
      StackMap locals: sun.security.jgss.krb5.ServiceCreds
      StackMap stack:
            aconst_null
            areturn
         6: .line 92
      StackMap locals:
      StackMap stack:
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            ifnull 8
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 8
         7: .line 93
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Using Kerberos creds"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         8: .line 95
      StackMap locals:
      StackMap stack:
            aload 2 /* serviceCreds */
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getName:()Ljava/lang/String;
            astore 3 /* serverPrincipal */
        start local 3 // java.lang.String serverPrincipal
         9: .line 96
            aload 3 /* serverPrincipal */
            ifnull 20
        10: .line 100
            invokestatic java.lang.System.getSecurityManager:()Ljava/lang/SecurityManager;
            astore 4 /* sm */
        start local 4 // java.lang.SecurityManager sm
        11: .line 102
            aload 4 /* sm */
            ifnull 20
        12: .line 104
            aload 4 /* sm */
            new javax.security.auth.kerberos.ServicePermission
            dup
        13: .line 105
            aload 3 /* serverPrincipal */
            ldc "accept"
            invokespecial javax.security.auth.kerberos.ServicePermission.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            aload 1 /* acc */
        14: .line 104
            invokevirtual java.lang.SecurityManager.checkPermission:(Ljava/security/Permission;Ljava/lang/Object;)V
        15: .line 107
            goto 20
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService java.security.AccessControlContext sun.security.jgss.krb5.ServiceCreds java.lang.String java.lang.SecurityManager
      StackMap stack: java.lang.SecurityException
        16: pop
        17: .line 108
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            ifnull 19
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 19
        18: .line 109
            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
        19: .line 112
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 4 // java.lang.SecurityManager sm
        20: .line 115
      StackMap locals:
      StackMap stack:
            aload 2 /* serviceCreds */
        21: areturn
        end local 3 // java.lang.String serverPrincipal
        end local 2 // sun.security.jgss.krb5.ServiceCreds serviceCreds
        22: .line 116
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService java.security.AccessControlContext
      StackMap stack: java.security.PrivilegedActionException
            astore 2 /* e */
        start local 2 // java.security.PrivilegedActionException e
        23: .line 118
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            ifnull 27
            ldc "handshake"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 27
        24: .line 119
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Attempt to obtain Kerberos key failed: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        25: .line 120
            aload 2 /* e */
            invokevirtual java.security.PrivilegedActionException.toString:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        26: .line 119
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        27: .line 122
      StackMap locals: java.security.PrivilegedActionException
      StackMap stack:
            aconst_null
            areturn
        end local 2 // java.security.PrivilegedActionException e
        end local 1 // java.security.AccessControlContext acc
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   28     0             this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;
            0   28     1              acc  Ljava/security/AccessControlContext;
            2   22     2     serviceCreds  Lsun/security/jgss/krb5/ServiceCreds;
            9   22     3  serverPrincipal  Ljava/lang/String;
           11   20     4               sm  Ljava/lang/SecurityManager;
           23   28     2                e  Ljava/security/PrivilegedActionException;
      Exception table:
        from    to  target  type
          11    15      16  Class java.lang.SecurityException
           0     5      22  Class java.security.PrivilegedActionException
           6    19      22  Class java.security.PrivilegedActionException
          20    21      22  Class java.security.PrivilegedActionException
    MethodParameters:
      Name  Flags
      acc   

  public java.lang.String getServiceHostName(java.security.Principal);
    descriptor: (Ljava/security/Principal;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=5, args_size=2
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
        start local 1 // java.security.Principal principal
         0: .line 128
            aload 1 /* principal */
            ifnonnull 2
         1: .line 129
            aconst_null
            areturn
         2: .line 131
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* hostName */
        start local 2 // java.lang.String hostName
         3: .line 134
            new sun.security.krb5.PrincipalName
            dup
            aload 1 /* principal */
            invokeinterface java.security.Principal.getName:()Ljava/lang/String;
         4: .line 135
            iconst_3
         5: .line 134
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;I)V
         6: .line 133
            astore 3 /* princName */
        start local 3 // sun.security.krb5.PrincipalName princName
         7: .line 136
            aload 3 /* princName */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            astore 4 /* nameParts */
        start local 4 // java.lang.String[] nameParts
         8: .line 137
            aload 4 /* nameParts */
            arraylength
            iconst_2
            if_icmplt 12
         9: .line 138
            aload 4 /* nameParts */
            iconst_1
            aaload
            astore 2 /* hostName */
        end local 4 // java.lang.String[] nameParts
        end local 3 // sun.security.krb5.PrincipalName princName
        10: .line 140
            goto 12
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService java.security.Principal java.lang.String
      StackMap stack: java.lang.Exception
        11: pop
        12: .line 143
      StackMap locals:
      StackMap stack:
            aload 2 /* hostName */
            areturn
        end local 2 // java.lang.String hostName
        end local 1 // java.security.Principal principal
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0       this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;
            0   13     1  principal  Ljava/security/Principal;
            3   13     2   hostName  Ljava/lang/String;
            7   10     3  princName  Lsun/security/krb5/PrincipalName;
            8   10     4  nameParts  [Ljava/lang/String;
      Exception table:
        from    to  target  type
           3    10      11  Class java.lang.Exception
    MethodParameters:
           Name  Flags
      principal  

  public boolean isRelated(boolean, java.security.AccessControlContext, java.security.Principal);
    descriptor: (ZLjava/security/AccessControlContext;Ljava/security/Principal;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=8, args_size=4
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
        start local 1 // boolean isClient
        start local 2 // java.security.AccessControlContext acc
        start local 3 // java.security.Principal p
         0: .line 151
            aload 3 /* p */
            ifnonnull 1
            iconst_0
            ireturn
         1: .line 155
      StackMap locals:
      StackMap stack:
            iload 1 /* isClient */
            aload 2 /* acc */
            invokedynamic run(ZLjava/security/AccessControlContext;)Ljava/security/PrivilegedExceptionAction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  ()Ljava/lang/Object;
                  sun/security/krb5/internal/ssl/Krb5KeyExchangeService.lambda$1(ZLjava/security/AccessControlContext;)Ljavax/security/auth/Subject; (6)
                  ()Ljavax/security/auth/Subject;
         2: .line 153
            invokestatic java.security.AccessController.doPrivileged:(Ljava/security/PrivilegedExceptionAction;)Ljava/lang/Object;
            checkcast javax.security.auth.Subject
            astore 4 /* subject */
        start local 4 // javax.security.auth.Subject subject
         3: .line 159
            aload 4 /* subject */
            ifnonnull 7
         4: .line 160
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            ifnull 6
            ldc "session"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 6
         5: .line 161
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            ldc "Kerberos credentials are not present in the current Subject; check if  javax.security.auth.useSubjectAsCreds system property has been set to false"
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
         6: .line 167
      StackMap locals: javax.security.auth.Subject
      StackMap stack:
            iconst_0
            ireturn
         7: .line 170
      StackMap locals:
      StackMap stack:
            aload 4 /* subject */
            ldc Ljava/security/Principal;
            invokevirtual javax.security.auth.Subject.getPrincipals:(Ljava/lang/Class;)Ljava/util/Set;
         8: .line 169
            astore 5 /* principals */
        start local 5 // java.util.Set principals
         9: .line 171
            aload 5 /* principals */
            aload 3 /* p */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 11
        10: .line 173
            iconst_1
            ireturn
        11: .line 175
      StackMap locals: java.util.Set
      StackMap stack:
            iload 1 /* isClient */
            ifeq 13
        12: .line 176
            iconst_0
            ireturn
        13: .line 178
      StackMap locals:
      StackMap stack:
            aload 4 /* subject */
            ldc Ljavax/security/auth/kerberos/KeyTab;
            invokevirtual javax.security.auth.Subject.getPrivateCredentials:(Ljava/lang/Class;)Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 7
            goto 17
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService int java.security.AccessControlContext java.security.Principal javax.security.auth.Subject java.util.Set top java.util.Iterator
      StackMap stack:
        14: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KeyTab
            astore 6 /* pc */
        start local 6 // javax.security.auth.kerberos.KeyTab pc
        15: .line 179
            aload 6 /* pc */
            invokevirtual javax.security.auth.kerberos.KeyTab.isBound:()Z
            ifne 17
        16: .line 180
            iconst_1
            ireturn
        end local 6 // javax.security.auth.kerberos.KeyTab pc
        17: .line 178
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 14
        18: .line 183
            iconst_0
            ireturn
        end local 5 // java.util.Set principals
        end local 4 // javax.security.auth.Subject subject
        19: .line 186
      StackMap locals: sun.security.krb5.internal.ssl.Krb5KeyExchangeService int java.security.AccessControlContext java.security.Principal
      StackMap stack: java.security.PrivilegedActionException
            astore 4 /* pae */
        start local 4 // java.security.PrivilegedActionException pae
        20: .line 187
            getstatic sun.security.krb5.internal.ssl.Krb5KeyExchangeService.debug:Lsun/security/ssl/Debug;
            ifnull 24
            ldc "session"
            invokestatic sun.security.ssl.Debug.isOn:(Ljava/lang/String;)Z
            ifeq 24
        21: .line 188
            getstatic java.lang.System.out:Ljava/io/PrintStream;
            new java.lang.StringBuilder
            dup
            ldc "Attempt to obtain subject failed! "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
        22: .line 189
            aload 4 /* pae */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
        23: .line 188
            invokevirtual java.io.PrintStream.println:(Ljava/lang/String;)V
        24: .line 191
      StackMap locals: java.security.PrivilegedActionException
      StackMap stack:
            iconst_0
            ireturn
        end local 4 // java.security.PrivilegedActionException pae
        end local 3 // java.security.Principal p
        end local 2 // java.security.AccessControlContext acc
        end local 1 // boolean isClient
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   25     0        this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;
            0   25     1    isClient  Z
            0   25     2         acc  Ljava/security/AccessControlContext;
            0   25     3           p  Ljava/security/Principal;
            3   19     4     subject  Ljavax/security/auth/Subject;
            9   19     5  principals  Ljava/util/Set<Ljava/security/Principal;>;
           15   17     6          pc  Ljavax/security/auth/kerberos/KeyTab;
           20   25     4         pae  Ljava/security/PrivilegedActionException;
      Exception table:
        from    to  target  type
           1     6      19  Class java.security.PrivilegedActionException
           7    10      19  Class java.security.PrivilegedActionException
          11    12      19  Class java.security.PrivilegedActionException
          13    16      19  Class java.security.PrivilegedActionException
          17    18      19  Class java.security.PrivilegedActionException
    MethodParameters:
          Name  Flags
      isClient  
      acc       
      p         

  public sun.security.ssl.ClientKeyExchange createClientExchange(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;)Lsun/security/ssl/ClientKeyExchange;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=5, args_size=5
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
        start local 1 // java.lang.String serverName
        start local 2 // java.security.AccessControlContext acc
        start local 3 // sun.security.ssl.ProtocolVersion protocolVerson
        start local 4 // java.security.SecureRandom rand
         0: .line 199
            new sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl
            dup
            aload 1 /* serverName */
            aload 2 /* acc */
            aload 3 /* protocolVerson */
            aload 4 /* rand */
            invokespecial sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.<init>:(Ljava/lang/String;Ljava/security/AccessControlContext;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;)V
            areturn
        end local 4 // java.security.SecureRandom rand
        end local 3 // sun.security.ssl.ProtocolVersion protocolVerson
        end local 2 // java.security.AccessControlContext acc
        end local 1 // java.lang.String serverName
        end local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    1     0            this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;
            0    1     1      serverName  Ljava/lang/String;
            0    1     2             acc  Ljava/security/AccessControlContext;
            0    1     3  protocolVerson  Lsun/security/ssl/ProtocolVersion;
            0    1     4            rand  Ljava/security/SecureRandom;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                Name  Flags
      serverName      
      acc             
      protocolVerson  
      rand            

  public sun.security.ssl.ClientKeyExchange createServerExchange(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;)Lsun/security/ssl/ClientKeyExchange;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=9, locals=8, args_size=8
        start local 0 // sun.security.krb5.internal.ssl.Krb5KeyExchangeService 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 206
            new sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl
            dup
            aload 1 /* protocolVersion */
            aload 2 /* clientVersion */
            aload 3 /* rand */
         1: .line 207
            aload 4 /* encodedTicket */
            aload 5 /* encrypted */
            aload 6 /* acc */
            aload 7 /* serviceCreds */
         2: .line 206
            invokespecial sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl.<init>:(Lsun/security/ssl/ProtocolVersion;Lsun/security/ssl/ProtocolVersion;Ljava/security/SecureRandom;[B[BLjava/security/AccessControlContext;Ljava/lang/Object;)V
            areturn
        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 this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    3     0             this  Lsun/security/krb5/internal/ssl/Krb5KeyExchangeService;
            0    3     1  protocolVersion  Lsun/security/ssl/ProtocolVersion;
            0    3     2    clientVersion  Lsun/security/ssl/ProtocolVersion;
            0    3     3             rand  Ljava/security/SecureRandom;
            0    3     4    encodedTicket  [B
            0    3     5        encrypted  [B
            0    3     6              acc  Ljava/security/AccessControlContext;
            0    3     7     serviceCreds  Ljava/lang/Object;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
                 Name  Flags
      protocolVersion  
      clientVersion    
      rand             
      encodedTicket    
      encrypted        
      acc              
      serviceCreds     

  private static sun.security.jgss.krb5.ServiceCreds lambda$0(java.security.AccessControlContext);
    descriptor: (Ljava/security/AccessControlContext;)Lsun/security/jgss/krb5/ServiceCreds;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=1
         0: .line 85
            getstatic sun.security.jgss.GSSCaller.CALLER_SSL_SERVER:Lsun/security/jgss/GSSCaller;
            aconst_null
            aload 0
         1: .line 84
            invokestatic sun.security.jgss.krb5.Krb5Util.getServiceCreds:(Lsun/security/jgss/GSSCaller;Ljava/lang/String;Ljava/security/AccessControlContext;)Lsun/security/jgss/krb5/ServiceCreds;
         2: .line 85
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception

  private static javax.security.auth.Subject lambda$1(boolean, java.security.AccessControlContext);
    descriptor: (ZLjava/security/AccessControlContext;)Ljavax/security/auth/Subject;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 156
            iload 0
            ifeq 1
            getstatic sun.security.jgss.GSSCaller.CALLER_SSL_CLIENT:Lsun/security/jgss/GSSCaller;
            goto 2
         1: .line 157
      StackMap locals:
      StackMap stack:
            getstatic sun.security.jgss.GSSCaller.CALLER_SSL_SERVER:Lsun/security/jgss/GSSCaller;
         2: .line 158
      StackMap locals:
      StackMap stack: sun.security.jgss.GSSCaller
            aload 1
         3: .line 155
            invokestatic sun.security.jgss.krb5.Krb5Util.getSubject:(Lsun/security/jgss/GSSCaller;Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
         4: .line 158
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
    Exceptions:
      throws java.lang.Exception
}
SourceFile: "Krb5KeyExchangeService.java"
NestMembers:
  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$1  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$2  sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl$3
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  ExchangerImpl = sun.security.krb5.internal.ssl.Krb5KeyExchangeService$ExchangerImpl of sun.security.krb5.internal.ssl.Krb5KeyExchangeService