public final class com.sun.jndi.ldap.sasl.LdapSasl
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: com.sun.jndi.ldap.sasl.LdapSasl
  super_class: java.lang.Object
{
  private static final java.lang.String SASL_CALLBACK;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "java.naming.security.sasl.callback"

  private static final java.lang.String SASL_AUTHZ_ID;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "java.naming.security.sasl.authorizationId"

  private static final java.lang.String SASL_REALM;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "java.naming.security.sasl.realm"

  private static final int LDAP_SUCCESS;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 0

  private static final int LDAP_SASL_BIND_IN_PROGRESS;
    descriptor: I
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: 14

  private static final byte[] NO_BYTES;
    descriptor: [B
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 230
            iconst_0
            newarray 8
            putstatic com.sun.jndi.ldap.sasl.LdapSasl.NO_BYTES:[B
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  private void <init>();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.sun.jndi.ldap.sasl.LdapSasl this
         0: .line 65
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 66
            return
        end local 0 // com.sun.jndi.ldap.sasl.LdapSasl this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lcom/sun/jndi/ldap/sasl/LdapSasl;

  public static com.sun.jndi.ldap.LdapResult saslBind(com.sun.jndi.ldap.LdapClient, com.sun.jndi.ldap.Connection, java.lang.String, java.lang.String, , java.lang.String, java.util.Hashtable<?, ?>, javax.naming.ldap.Control[]);
    descriptor: (Lcom/sun/jndi/ldap/LdapClient;Lcom/sun/jndi/ldap/Connection;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;Ljava/util/Hashtable;[Ljavax/naming/ldap/Control;)Lcom/sun/jndi/ldap/LdapResult;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=6, locals=22, args_size=8
        start local 0 // com.sun.jndi.ldap.LdapClient clnt
        start local 1 // com.sun.jndi.ldap.Connection conn
        start local 2 // java.lang.String server
        start local 3 // java.lang.String dn
        start local 4 // java.lang.Object pw
        start local 5 // java.lang.String authMech
        start local 6 // java.util.Hashtable env
        start local 7 // javax.naming.ldap.Control[] bindCtls
         0: .line 100
            aconst_null
            astore 8 /* saslClnt */
        start local 8 // javax.security.sasl.SaslClient saslClnt
         1: .line 101
            iconst_0
            istore 9 /* cleanupHandler */
        start local 9 // boolean cleanupHandler
         2: .line 105
            aload 6 /* env */
            ifnull 3
            aload 6 /* env */
            ldc "java.naming.security.sasl.callback"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast javax.security.auth.callback.CallbackHandler
            goto 4
      StackMap locals: javax.security.sasl.SaslClient int
      StackMap stack:
         3: aconst_null
         4: .line 104
      StackMap locals:
      StackMap stack: javax.security.auth.callback.CallbackHandler
            astore 10 /* cbh */
        start local 10 // javax.security.auth.callback.CallbackHandler cbh
         5: .line 106
            aload 10 /* cbh */
            ifnonnull 8
         6: .line 107
            new com.sun.jndi.ldap.sasl.DefaultCallbackHandler
            dup
            aload 3 /* dn */
            aload 4 /* pw */
            aload 6 /* env */
            ldc "java.naming.security.sasl.realm"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            invokespecial com.sun.jndi.ldap.sasl.DefaultCallbackHandler.<init>:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;)V
            astore 10 /* cbh */
         7: .line 108
            iconst_1
            istore 9 /* cleanupHandler */
         8: .line 112
      StackMap locals: javax.security.auth.callback.CallbackHandler
      StackMap stack:
            aload 6 /* env */
            ifnull 9
            aload 6 /* env */
            ldc "java.naming.security.sasl.authorizationId"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            goto 10
      StackMap locals:
      StackMap stack:
         9: aconst_null
      StackMap locals:
      StackMap stack: java.lang.String
        10: astore 11 /* authzId */
        start local 11 // java.lang.String authzId
        11: .line 113
            aload 5 /* authMech */
            invokestatic com.sun.jndi.ldap.sasl.LdapSasl.getSaslMechanismNames:(Ljava/lang/String;)[Ljava/lang/String;
            astore 12 /* mechs */
        start local 12 // java.lang.String[] mechs
        12: .line 116
            aload 6 /* env */
            ldc "jdk.internal.sasl.tlschannelbinding"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            ifnull 14
        13: .line 117
            new javax.naming.NamingException
            dup
            ldc "jdk.internal.sasl.tlschannelbinding property cannot be set explicitly"
            invokespecial javax.naming.NamingException.<init>:(Ljava/lang/String;)V
            athrow
        14: .line 121
      StackMap locals: java.lang.String java.lang.String[]
      StackMap stack:
            aload 6 /* env */
            astore 13 /* envProps */
        start local 13 // java.util.Hashtable envProps
        15: .line 125
            aload 1 /* conn */
            invokevirtual com.sun.jndi.ldap.Connection.isTlsConnection:()Z
            ifeq 28
        16: .line 128
            aload 6 /* env */
            ldc "com.sun.jndi.ldap.tls.cbtype"
            invokevirtual java.util.Hashtable.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
        17: .line 127
            invokestatic com.sun.jndi.ldap.sasl.TlsChannelBinding.parseType:(Ljava/lang/String;)Lcom/sun/jndi/ldap/sasl/TlsChannelBinding$TlsChannelBindingType;
        18: .line 126
            astore 14 /* cbType */
        start local 14 // com.sun.jndi.ldap.sasl.TlsChannelBinding$TlsChannelBindingType cbType
        19: .line 129
            aload 14 /* cbType */
            getstatic com.sun.jndi.ldap.sasl.TlsChannelBinding$TlsChannelBindingType.TLS_SERVER_END_POINT:Lcom/sun/jndi/ldap/sasl/TlsChannelBinding$TlsChannelBindingType;
            if_acmpne 28
        20: .line 131
            aload 1 /* conn */
            invokevirtual com.sun.jndi.ldap.Connection.getTlsServerCertificate:()Ljava/security/cert/X509Certificate;
            astore 15 /* cert */
        start local 15 // java.security.cert.X509Certificate cert
        21: .line 132
            aload 15 /* cert */
            ifnull 27
        22: .line 134
            aload 15 /* cert */
            invokestatic com.sun.jndi.ldap.sasl.TlsChannelBinding.create:(Ljava/security/cert/X509Certificate;)Lcom/sun/jndi/ldap/sasl/TlsChannelBinding;
        23: .line 133
            astore 16 /* tlsCB */
        start local 16 // com.sun.jndi.ldap.sasl.TlsChannelBinding tlsCB
        24: .line 135
            aload 6 /* env */
            invokevirtual java.util.Hashtable.clone:()Ljava/lang/Object;
            checkcast java.util.Hashtable
            astore 13 /* envProps */
        25: .line 136
            aload 13 /* envProps */
            ldc "jdk.internal.sasl.tlschannelbinding"
            aload 16 /* tlsCB */
            invokevirtual com.sun.jndi.ldap.sasl.TlsChannelBinding.getData:()[B
            invokevirtual java.util.Hashtable.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 16 // com.sun.jndi.ldap.sasl.TlsChannelBinding tlsCB
        26: .line 137
            goto 28
        27: .line 138
      StackMap locals: java.util.Hashtable com.sun.jndi.ldap.sasl.TlsChannelBinding$TlsChannelBindingType java.security.cert.X509Certificate
      StackMap stack:
            new javax.security.sasl.SaslException
            dup
            ldc "No suitable certificate to generate TLS Channel Binding data"
            invokespecial javax.security.sasl.SaslException.<init>:(Ljava/lang/String;)V
            athrow
        end local 15 // java.security.cert.X509Certificate cert
        end local 14 // com.sun.jndi.ldap.sasl.TlsChannelBinding$TlsChannelBindingType cbType
        28: .line 146
      StackMap locals:
      StackMap stack:
            aload 12 /* mechs */
            aload 11 /* authzId */
            ldc "ldap"
            aload 2 /* server */
            aload 13 /* envProps */
            aload 10 /* cbh */
        29: .line 145
            invokestatic javax.security.sasl.Sasl.createSaslClient:([Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;Ljava/util/Map;Ljavax/security/auth/callback/CallbackHandler;)Ljavax/security/sasl/SaslClient;
            astore 8 /* saslClnt */
        30: .line 148
            aload 8 /* saslClnt */
            ifnonnull 32
        31: .line 149
            new javax.naming.AuthenticationNotSupportedException
            dup
            aload 5 /* authMech */
            invokespecial javax.naming.AuthenticationNotSupportedException.<init>:(Ljava/lang/String;)V
            athrow
        32: .line 153
      StackMap locals:
      StackMap stack:
            aload 8 /* saslClnt */
            invokeinterface javax.security.sasl.SaslClient.getMechanismName:()Ljava/lang/String;
            astore 15 /* mechName */
        start local 15 // java.lang.String mechName
        33: .line 154
            aload 8 /* saslClnt */
            invokeinterface javax.security.sasl.SaslClient.hasInitialResponse:()Z
            ifeq 35
        34: .line 155
            aload 8 /* saslClnt */
            getstatic com.sun.jndi.ldap.sasl.LdapSasl.NO_BYTES:[B
            invokeinterface javax.security.sasl.SaslClient.evaluateChallenge:([B)[B
            goto 36
      StackMap locals: com.sun.jndi.ldap.LdapClient com.sun.jndi.ldap.Connection java.lang.String java.lang.String java.lang.Object java.lang.String java.util.Hashtable javax.naming.ldap.Control[] javax.security.sasl.SaslClient int javax.security.auth.callback.CallbackHandler java.lang.String java.lang.String[] java.util.Hashtable top java.lang.String
      StackMap stack:
        35: aconst_null
        36: .line 154
      StackMap locals:
      StackMap stack: byte[]
            astore 16 /* response */
        start local 16 // byte[] response
        37: .line 157
            aload 0 /* clnt */
            aconst_null
            aload 16 /* response */
            aload 7 /* bindCtls */
            aload 15 /* mechName */
            iconst_1
            invokevirtual com.sun.jndi.ldap.LdapClient.ldapBind:(Ljava/lang/String;[B[Ljavax/naming/ldap/Control;Ljava/lang/String;Z)Lcom/sun/jndi/ldap/LdapResult;
            astore 14 /* res */
        start local 14 // com.sun.jndi.ldap.LdapResult res
        38: .line 159
            goto 49
        39: .line 163
      StackMap locals: com.sun.jndi.ldap.LdapClient com.sun.jndi.ldap.Connection java.lang.String java.lang.String java.lang.Object java.lang.String java.util.Hashtable javax.naming.ldap.Control[] javax.security.sasl.SaslClient int javax.security.auth.callback.CallbackHandler java.lang.String java.lang.String[] java.util.Hashtable com.sun.jndi.ldap.LdapResult java.lang.String byte[]
      StackMap stack:
            aload 8 /* saslClnt */
        40: .line 164
            aload 14 /* res */
            getfield com.sun.jndi.ldap.LdapResult.serverCreds:[B
            ifnull 41
            aload 14 /* res */
            getfield com.sun.jndi.ldap.LdapResult.serverCreds:[B
            goto 42
      StackMap locals:
      StackMap stack: javax.security.sasl.SaslClient
        41: getstatic com.sun.jndi.ldap.sasl.LdapSasl.NO_BYTES:[B
        42: .line 163
      StackMap locals: com.sun.jndi.ldap.LdapClient com.sun.jndi.ldap.Connection java.lang.String java.lang.String java.lang.Object java.lang.String java.util.Hashtable javax.naming.ldap.Control[] javax.security.sasl.SaslClient int javax.security.auth.callback.CallbackHandler java.lang.String java.lang.String[] java.util.Hashtable com.sun.jndi.ldap.LdapResult java.lang.String byte[]
      StackMap stack: javax.security.sasl.SaslClient byte[]
            invokeinterface javax.security.sasl.SaslClient.evaluateChallenge:([B)[B
            astore 16 /* response */
        43: .line 165
            aload 14 /* res */
            getfield com.sun.jndi.ldap.LdapResult.status:I
            ifne 48
        44: .line 166
            aload 16 /* response */
            ifnull 52
        45: .line 167
            new javax.naming.AuthenticationException
            dup
        46: .line 168
            ldc "SASL client generated response after success"
        47: .line 167
            invokespecial javax.naming.AuthenticationException.<init>:(Ljava/lang/String;)V
            athrow
        48: .line 172
      StackMap locals:
      StackMap stack:
            aload 0 /* clnt */
            aconst_null
            aload 16 /* response */
            aload 7 /* bindCtls */
            aload 15 /* mechName */
            iconst_1
            invokevirtual com.sun.jndi.ldap.LdapClient.ldapBind:(Ljava/lang/String;[B[Ljavax/naming/ldap/Control;Ljava/lang/String;Z)Lcom/sun/jndi/ldap/LdapResult;
            astore 14 /* res */
        49: .line 159
      StackMap locals:
      StackMap stack:
            aload 8 /* saslClnt */
            invokeinterface javax.security.sasl.SaslClient.isComplete:()Z
            ifne 52
        50: .line 160
            aload 14 /* res */
            getfield com.sun.jndi.ldap.LdapResult.status:I
            bipush 14
            if_icmpeq 39
        51: .line 161
            aload 14 /* res */
            getfield com.sun.jndi.ldap.LdapResult.status:I
            ifeq 39
        52: .line 175
      StackMap locals:
      StackMap stack:
            aload 14 /* res */
            getfield com.sun.jndi.ldap.LdapResult.status:I
            ifne 69
        53: .line 176
            aload 8 /* saslClnt */
            invokeinterface javax.security.sasl.SaslClient.isComplete:()Z
            ifne 57
        54: .line 177
            new javax.naming.AuthenticationException
            dup
        55: .line 178
            ldc "SASL authentication not complete despite server claims"
        56: .line 177
            invokespecial javax.naming.AuthenticationException.<init>:(Ljava/lang/String;)V
            athrow
        57: .line 181
      StackMap locals:
      StackMap stack:
            aload 8 /* saslClnt */
            ldc "javax.security.sasl.qop"
            invokeinterface javax.security.sasl.SaslClient.getNegotiatedProperty:(Ljava/lang/String;)Ljava/lang/Object;
            checkcast java.lang.String
            astore 17 /* qop */
        start local 17 // java.lang.String qop
        58: .line 184
            aload 17 /* qop */
            ifnull 68
            aload 17 /* qop */
            ldc "auth-int"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifne 60
        59: .line 185
            aload 17 /* qop */
            ldc "auth-conf"
            invokevirtual java.lang.String.equalsIgnoreCase:(Ljava/lang/String;)Z
            ifeq 68
        60: .line 187
      StackMap locals: java.lang.String
      StackMap stack:
            new com.sun.jndi.ldap.sasl.SaslInputStream
            dup
            aload 8 /* saslClnt */
        61: .line 188
            aload 1 /* conn */
            getfield com.sun.jndi.ldap.Connection.inStream:Ljava/io/InputStream;
        62: .line 187
            invokespecial com.sun.jndi.ldap.sasl.SaslInputStream.<init>:(Ljavax/security/sasl/SaslClient;Ljava/io/InputStream;)V
            astore 18 /* newIn */
        start local 18 // java.io.InputStream newIn
        63: .line 189
            new com.sun.jndi.ldap.sasl.SaslOutputStream
            dup
            aload 8 /* saslClnt */
        64: .line 190
            aload 1 /* conn */
            getfield com.sun.jndi.ldap.Connection.outStream:Ljava/io/OutputStream;
        65: .line 189
            invokespecial com.sun.jndi.ldap.sasl.SaslOutputStream.<init>:(Ljavax/security/sasl/SaslClient;Ljava/io/OutputStream;)V
            astore 19 /* newOut */
        start local 19 // java.io.OutputStream newOut
        66: .line 192
            aload 1 /* conn */
            aload 18 /* newIn */
            aload 19 /* newOut */
            invokevirtual com.sun.jndi.ldap.Connection.replaceStreams:(Ljava/io/InputStream;Ljava/io/OutputStream;)V
        end local 19 // java.io.OutputStream newOut
        end local 18 // java.io.InputStream newIn
        67: .line 193
            goto 69
        68: .line 194
      StackMap locals:
      StackMap stack:
            aload 8 /* saslClnt */
            invokeinterface javax.security.sasl.SaslClient.dispose:()V
        end local 17 // java.lang.String qop
        69: .line 197
      StackMap locals:
      StackMap stack:
            aload 14 /* res */
            astore 21
        70: .line 204
            iload 9 /* cleanupHandler */
            ifeq 72
        71: .line 205
            aload 10 /* cbh */
            checkcast com.sun.jndi.ldap.sasl.DefaultCallbackHandler
            invokevirtual com.sun.jndi.ldap.sasl.DefaultCallbackHandler.clearPassword:()V
        72: .line 197
      StackMap locals: com.sun.jndi.ldap.LdapClient com.sun.jndi.ldap.Connection java.lang.String java.lang.String java.lang.Object java.lang.String java.util.Hashtable javax.naming.ldap.Control[] javax.security.sasl.SaslClient int javax.security.auth.callback.CallbackHandler java.lang.String java.lang.String[] java.util.Hashtable com.sun.jndi.ldap.LdapResult java.lang.String byte[] top top top top com.sun.jndi.ldap.LdapResult
      StackMap stack:
            aload 21
            areturn
        end local 16 // byte[] response
        end local 15 // java.lang.String mechName
        end local 14 // com.sun.jndi.ldap.LdapResult res
        73: .line 198
      StackMap locals: com.sun.jndi.ldap.LdapClient com.sun.jndi.ldap.Connection java.lang.String java.lang.String java.lang.Object java.lang.String java.util.Hashtable javax.naming.ldap.Control[] javax.security.sasl.SaslClient int javax.security.auth.callback.CallbackHandler java.lang.String java.lang.String[] java.util.Hashtable
      StackMap stack: javax.security.sasl.SaslException
            astore 14 /* e */
        start local 14 // javax.security.sasl.SaslException e
        74: .line 199
            new javax.naming.AuthenticationException
            dup
        75: .line 200
            aload 5 /* authMech */
        76: .line 199
            invokespecial javax.naming.AuthenticationException.<init>:(Ljava/lang/String;)V
            astore 15 /* ne */
        start local 15 // javax.naming.NamingException ne
        77: .line 201
            aload 15 /* ne */
            aload 14 /* e */
            invokevirtual javax.naming.NamingException.setRootCause:(Ljava/lang/Throwable;)V
        78: .line 202
            aload 15 /* ne */
            athrow
        end local 15 // javax.naming.NamingException ne
        end local 14 // javax.security.sasl.SaslException e
        79: .line 203
      StackMap locals:
      StackMap stack: java.lang.Throwable
            astore 20
        80: .line 204
            iload 9 /* cleanupHandler */
            ifeq 82
        81: .line 205
            aload 10 /* cbh */
            checkcast com.sun.jndi.ldap.sasl.DefaultCallbackHandler
            invokevirtual com.sun.jndi.ldap.sasl.DefaultCallbackHandler.clearPassword:()V
        82: .line 207
      StackMap locals: com.sun.jndi.ldap.LdapClient com.sun.jndi.ldap.Connection java.lang.String java.lang.String java.lang.Object java.lang.String java.util.Hashtable javax.naming.ldap.Control[] javax.security.sasl.SaslClient int javax.security.auth.callback.CallbackHandler java.lang.String java.lang.String[] java.util.Hashtable top top top top top top java.lang.Throwable
      StackMap stack:
            aload 20
            athrow
        end local 13 // java.util.Hashtable envProps
        end local 12 // java.lang.String[] mechs
        end local 11 // java.lang.String authzId
        end local 10 // javax.security.auth.callback.CallbackHandler cbh
        end local 9 // boolean cleanupHandler
        end local 8 // javax.security.sasl.SaslClient saslClnt
        end local 7 // javax.naming.ldap.Control[] bindCtls
        end local 6 // java.util.Hashtable env
        end local 5 // java.lang.String authMech
        end local 4 // java.lang.Object pw
        end local 3 // java.lang.String dn
        end local 2 // java.lang.String server
        end local 1 // com.sun.jndi.ldap.Connection conn
        end local 0 // com.sun.jndi.ldap.LdapClient clnt
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   83     0            clnt  Lcom/sun/jndi/ldap/LdapClient;
            0   83     1            conn  Lcom/sun/jndi/ldap/Connection;
            0   83     2          server  Ljava/lang/String;
            0   83     3              dn  Ljava/lang/String;
            0   83     4              pw  Ljava/lang/Object;
            0   83     5        authMech  Ljava/lang/String;
            0   83     6             env  Ljava/util/Hashtable<**>;
            0   83     7        bindCtls  [Ljavax/naming/ldap/Control;
            1   83     8        saslClnt  Ljavax/security/sasl/SaslClient;
            2   83     9  cleanupHandler  Z
            5   83    10             cbh  Ljavax/security/auth/callback/CallbackHandler;
           11   83    11         authzId  Ljava/lang/String;
           12   83    12           mechs  [Ljava/lang/String;
           15   83    13        envProps  Ljava/util/Hashtable<Ljava/lang/String;Ljava/lang/Object;>;
           19   28    14          cbType  Lcom/sun/jndi/ldap/sasl/TlsChannelBinding$TlsChannelBindingType;
           21   28    15            cert  Ljava/security/cert/X509Certificate;
           24   26    16           tlsCB  Lcom/sun/jndi/ldap/sasl/TlsChannelBinding;
           38   73    14             res  Lcom/sun/jndi/ldap/LdapResult;
           33   73    15        mechName  Ljava/lang/String;
           37   73    16        response  [B
           58   69    17             qop  Ljava/lang/String;
           63   67    18           newIn  Ljava/io/InputStream;
           66   67    19          newOut  Ljava/io/OutputStream;
           74   79    14               e  Ljavax/security/sasl/SaslException;
           77   79    15              ne  Ljavax/naming/NamingException;
      Exception table:
        from    to  target  type
          15    70      73  Class javax.security.sasl.SaslException
          15    70      79  any
          73    79      79  any
    Exceptions:
      throws java.io.IOException, javax.naming.NamingException
    Signature: (Lcom/sun/jndi/ldap/LdapClient;Lcom/sun/jndi/ldap/Connection;Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/String;Ljava/util/Hashtable<**>;[Ljavax/naming/ldap/Control;)Lcom/sun/jndi/ldap/LdapResult;
    MethodParameters:
          Name  Flags
      clnt      
      conn      
      server    
      dn        
      pw        
      authMech  
      env       
      bindCtls  

  private static java.lang.String[] getSaslMechanismNames(java.lang.String);
    descriptor: (Ljava/lang/String;)[Ljava/lang/String;
    flags: (0x000a) ACC_PRIVATE, ACC_STATIC
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // java.lang.String str
         0: .line 218
            new java.util.StringTokenizer
            dup
            aload 0 /* str */
            invokespecial java.util.StringTokenizer.<init>:(Ljava/lang/String;)V
            astore 1 /* parser */
        start local 1 // java.util.StringTokenizer parser
         1: .line 219
            new java.util.Vector
            dup
            bipush 10
            invokespecial java.util.Vector.<init>:(I)V
            astore 2 /* mechs */
        start local 2 // java.util.Vector mechs
         2: .line 220
            goto 4
         3: .line 221
      StackMap locals: java.util.StringTokenizer java.util.Vector
      StackMap stack:
            aload 2 /* mechs */
            aload 1 /* parser */
            invokevirtual java.util.StringTokenizer.nextToken:()Ljava/lang/String;
            invokevirtual java.util.Vector.addElement:(Ljava/lang/Object;)V
         4: .line 220
      StackMap locals:
      StackMap stack:
            aload 1 /* parser */
            invokevirtual java.util.StringTokenizer.hasMoreTokens:()Z
            ifne 3
         5: .line 223
            aload 2 /* mechs */
            invokevirtual java.util.Vector.size:()I
            anewarray java.lang.String
            astore 3 /* mechNames */
        start local 3 // java.lang.String[] mechNames
         6: .line 224
            iconst_0
            istore 4 /* i */
        start local 4 // int i
         7: goto 10
         8: .line 225
      StackMap locals: java.lang.String[] int
      StackMap stack:
            aload 3 /* mechNames */
            iload 4 /* i */
            aload 2 /* mechs */
            iload 4 /* i */
            invokevirtual java.util.Vector.elementAt:(I)Ljava/lang/Object;
            checkcast java.lang.String
            aastore
         9: .line 224
            iinc 4 /* i */ 1
      StackMap locals:
      StackMap stack:
        10: iload 4 /* i */
            aload 2 /* mechs */
            invokevirtual java.util.Vector.size:()I
            if_icmplt 8
        end local 4 // int i
        11: .line 227
            aload 3 /* mechNames */
            areturn
        end local 3 // java.lang.String[] mechNames
        end local 2 // java.util.Vector mechs
        end local 1 // java.util.StringTokenizer parser
        end local 0 // java.lang.String str
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   12     0        str  Ljava/lang/String;
            1   12     1     parser  Ljava/util/StringTokenizer;
            2   12     2      mechs  Ljava/util/Vector<Ljava/lang/String;>;
            6   12     3  mechNames  [Ljava/lang/String;
            7   11     4          i  I
    MethodParameters:
      Name  Flags
      str   
}
SourceFile: "LdapSasl.java"
InnerClasses:
  public final TlsChannelBindingType = com.sun.jndi.ldap.sasl.TlsChannelBinding$TlsChannelBindingType of com.sun.jndi.ldap.sasl.TlsChannelBinding