public class sun.security.ssl.krb5.Krb5ProxyImpl implements sun.security.ssl.Krb5Proxy
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: sun.security.ssl.krb5.Krb5ProxyImpl
  super_class: java.lang.Object
{
  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
         0: .line 49
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/Krb5ProxyImpl;

  public javax.security.auth.Subject getClientSubject(java.security.AccessControlContext);
    descriptor: (Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
        start local 1 // java.security.AccessControlContext acc
         0: .line 54
            getstatic sun.security.jgss.GSSCaller.CALLER_SSL_CLIENT:Lsun/security/jgss/GSSCaller;
            aload 1 /* acc */
            invokestatic sun.security.jgss.krb5.Krb5Util.getSubject:(Lsun/security/jgss/GSSCaller;Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            areturn
        end local 1 // java.security.AccessControlContext acc
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            0    1     1   acc  Ljava/security/AccessControlContext;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
      Name  Flags
      acc   

  public javax.security.auth.Subject getServerSubject(java.security.AccessControlContext);
    descriptor: (Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
        start local 1 // java.security.AccessControlContext acc
         0: .line 60
            getstatic sun.security.jgss.GSSCaller.CALLER_SSL_SERVER:Lsun/security/jgss/GSSCaller;
            aload 1 /* acc */
            invokestatic sun.security.jgss.krb5.Krb5Util.getSubject:(Lsun/security/jgss/GSSCaller;Ljava/security/AccessControlContext;)Ljavax/security/auth/Subject;
            areturn
        end local 1 // java.security.AccessControlContext acc
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            0    1     1   acc  Ljava/security/AccessControlContext;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
      Name  Flags
      acc   

  public java.lang.Object getServiceCreds(java.security.AccessControlContext);
    descriptor: (Ljava/security/AccessControlContext;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
        start local 1 // java.security.AccessControlContext acc
         0: .line 67
            getstatic sun.security.jgss.GSSCaller.CALLER_SSL_SERVER:Lsun/security/jgss/GSSCaller;
            aconst_null
            aload 1 /* acc */
            invokestatic sun.security.jgss.krb5.Krb5Util.getServiceCreds:(Lsun/security/jgss/GSSCaller;Ljava/lang/String;Ljava/security/AccessControlContext;)Lsun/security/jgss/krb5/ServiceCreds;
         1: .line 66
            astore 2 /* serviceCreds */
        start local 2 // sun.security.jgss.krb5.ServiceCreds serviceCreds
         2: .line 68
            aload 2 /* serviceCreds */
            areturn
        end local 2 // sun.security.jgss.krb5.ServiceCreds serviceCreds
        end local 1 // java.security.AccessControlContext acc
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    3     0          this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            0    3     1           acc  Ljava/security/AccessControlContext;
            2    3     2  serviceCreds  Lsun/security/jgss/krb5/ServiceCreds;
    Exceptions:
      throws javax.security.auth.login.LoginException
    MethodParameters:
      Name  Flags
      acc   

  public java.lang.String getServerPrincipalName(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
        start local 1 // java.lang.Object serviceCreds
         0: .line 73
            aload 1 /* serviceCreds */
            checkcast sun.security.jgss.krb5.ServiceCreds
            invokevirtual sun.security.jgss.krb5.ServiceCreds.getName:()Ljava/lang/String;
            areturn
        end local 1 // java.lang.Object serviceCreds
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            0    1     1  serviceCreds  Ljava/lang/Object;
    MethodParameters:
              Name  Flags
      serviceCreds  

  public java.lang.String getPrincipalHostName(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.ssl.krb5.Krb5ProxyImpl this
        start local 1 // java.security.Principal principal
         0: .line 78
            aload 1 /* principal */
            ifnonnull 2
         1: .line 79
            aconst_null
            areturn
         2: .line 81
      StackMap locals:
      StackMap stack:
            aconst_null
            astore 2 /* hostName */
        start local 2 // java.lang.String hostName
         3: .line 84
            new sun.security.krb5.PrincipalName
            dup
            aload 1 /* principal */
            invokeinterface java.security.Principal.getName:()Ljava/lang/String;
         4: .line 85
            iconst_3
         5: .line 84
            invokespecial sun.security.krb5.PrincipalName.<init>:(Ljava/lang/String;I)V
         6: .line 83
            astore 3 /* princName */
        start local 3 // sun.security.krb5.PrincipalName princName
         7: .line 86
            aload 3 /* princName */
            invokevirtual sun.security.krb5.PrincipalName.getNameStrings:()[Ljava/lang/String;
            astore 4 /* nameParts */
        start local 4 // java.lang.String[] nameParts
         8: .line 87
            aload 4 /* nameParts */
            arraylength
            iconst_2
            if_icmplt 12
         9: .line 88
            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 90
            goto 12
      StackMap locals: sun.security.ssl.krb5.Krb5ProxyImpl java.security.Principal java.lang.String
      StackMap stack: java.lang.Exception
        11: pop
        12: .line 93
      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.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   13     0       this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            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 java.security.Permission getServicePermission(java.lang.String, java.lang.String);
    descriptor: (Ljava/lang/String;Ljava/lang/String;)Ljava/security/Permission;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
        start local 1 // java.lang.String principalName
        start local 2 // java.lang.String action
         0: .line 100
            new javax.security.auth.kerberos.ServicePermission
            dup
            aload 1 /* principalName */
            aload 2 /* action */
            invokespecial javax.security.auth.kerberos.ServicePermission.<init>:(Ljava/lang/String;Ljava/lang/String;)V
            areturn
        end local 2 // java.lang.String action
        end local 1 // java.lang.String principalName
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    1     0           this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            0    1     1  principalName  Ljava/lang/String;
            0    1     2         action  Ljava/lang/String;
    MethodParameters:
               Name  Flags
      principalName  
      action         

  public boolean isRelated(javax.security.auth.Subject, java.security.Principal);
    descriptor: (Ljavax/security/auth/Subject;Ljava/security/Principal;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=6, args_size=3
        start local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
        start local 1 // javax.security.auth.Subject subject
        start local 2 // java.security.Principal princ
         0: .line 105
            aload 2 /* princ */
            ifnonnull 1
            iconst_0
            ireturn
         1: .line 107
      StackMap locals:
      StackMap stack:
            aload 1 /* subject */
            ldc Ljava/security/Principal;
            invokevirtual javax.security.auth.Subject.getPrincipals:(Ljava/lang/Class;)Ljava/util/Set;
         2: .line 106
            astore 3 /* principals */
        start local 3 // java.util.Set principals
         3: .line 108
            aload 3 /* principals */
            aload 2 /* princ */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 5
         4: .line 110
            iconst_1
            ireturn
         5: .line 112
      StackMap locals: java.util.Set
      StackMap stack:
            aload 1 /* 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 5
            goto 9
      StackMap locals: sun.security.ssl.krb5.Krb5ProxyImpl javax.security.auth.Subject java.security.Principal java.util.Set top java.util.Iterator
      StackMap stack:
         6: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast javax.security.auth.kerberos.KeyTab
            astore 4 /* pc */
        start local 4 // javax.security.auth.kerberos.KeyTab pc
         7: .line 113
            aload 4 /* pc */
            invokevirtual javax.security.auth.kerberos.KeyTab.isBound:()Z
            ifne 9
         8: .line 114
            iconst_1
            ireturn
        end local 4 // javax.security.auth.kerberos.KeyTab pc
         9: .line 112
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
        10: .line 117
            iconst_0
            ireturn
        end local 3 // java.util.Set principals
        end local 2 // java.security.Principal princ
        end local 1 // javax.security.auth.Subject subject
        end local 0 // sun.security.ssl.krb5.Krb5ProxyImpl this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   11     0        this  Lsun/security/ssl/krb5/Krb5ProxyImpl;
            0   11     1     subject  Ljavax/security/auth/Subject;
            0   11     2       princ  Ljava/security/Principal;
            3   11     3  principals  Ljava/util/Set<Ljava/security/Principal;>;
            7    9     4          pc  Ljavax/security/auth/kerberos/KeyTab;
    MethodParameters:
         Name  Flags
      subject  
      princ    
}
SourceFile: "Krb5ProxyImpl.java"