public class org.apache.zookeeper.client.ZooKeeperSaslClient extends java.lang.Object
{
public static final java.lang.String LOGIN_CONTEXT_NAME_KEY;
public static final java.lang.String ENABLE_CLIENT_SASL_KEY;
public static final java.lang.String ENABLE_CLIENT_SASL_DEFAULT;
private volatile boolean initializedLogin;
private static final org.slf4j.Logger LOG;
private org.apache.zookeeper.Login login;
private javax.security.sasl.SaslClient saslClient;
private boolean isSASLConfigured;
private final org.apache.zookeeper.client.ZKClientConfig clientConfig;
private byte[] saslToken;
private org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState;
private boolean gotLastPacket;
private final java.lang.String configStatus;
public static boolean isEnabled()
{
java.lang.String v;
boolean v;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.sasl.client", "true");
v = staticinvoke <java.lang.Boolean: boolean parseBoolean(java.lang.String)>(v);
return v;
}
public org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState getSaslState()
{
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState>;
return v;
}
public java.lang.String getLoginContext()
{
org.apache.zookeeper.Login v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
java.lang.String v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
if v == null goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
v = virtualinvoke v.<org.apache.zookeeper.Login: java.lang.String getLoginContextName()>();
return v;
label:
return null;
}
public void <init>(java.lang.String, org.apache.zookeeper.client.ZKClientConfig) throws javax.security.auth.login.LoginException
{
javax.security.auth.login.LoginException v, v, v, v;
byte[] v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
javax.security.sasl.SaslClient v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v, v;
java.lang.SecurityException v;
java.lang.String v, v, v, v, v, v, v, v, v, v, v, v, v, v, v;
org.apache.zookeeper.client.ZKClientConfig v;
javax.security.auth.login.Configuration v;
java.lang.RuntimeException v;
java.lang.IllegalArgumentException v;
javax.security.auth.login.AppConfigurationEntry[] v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: java.lang.String;
v := @parameter: org.apache.zookeeper.client.ZKClientConfig;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean initializedLogin> = 0;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login> = null;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean isSASLConfigured> = 1;
v = newarray (byte)[0];
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] saslToken> = v;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState INITIAL>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean gotLastPacket> = 0;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.sasl.clientconfig", "Client");
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZKClientConfig clientConfig> = v;
v = null;
v = null;
label:
v = staticinvoke <javax.security.auth.login.Configuration: javax.security.auth.login.Configuration getConfiguration()>();
v = virtualinvoke v.<javax.security.auth.login.Configuration: javax.security.auth.login.AppConfigurationEntry[] getAppConfigurationEntry(java.lang.String)>(v);
label:
goto label;
label:
v := @caughtexception;
v = v;
goto label;
label:
v := @caughtexception;
v = v;
label:
if v == null goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Will attempt to SASL-authenticate using Login Context section \'\u0001\'");
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: java.lang.String configStatus> = v;
v = specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient createSaslClient(java.lang.String,java.lang.String)>(v, v);
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient> = v;
goto label;
label:
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getProperty(java.lang.String)>("zookeeper.sasl.clientconfig");
if v == null goto label;
if v == null goto label;
v = new javax.security.auth.login.LoginException;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getJaasConfKey()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.RuntimeException)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Zookeeper client cannot authenticate using the \u section of the supplied JAAS configuration: \'\u0001\' because of a RuntimeException: \u0001");
specialinvoke v.<javax.security.auth.login.LoginException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new javax.security.auth.login.LoginException;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Client cannot SASL-authenticate because the specified JAAS configuration section \'\u0001\' could not be found.");
specialinvoke v.<javax.security.auth.login.LoginException: void <init>(java.lang.String)>(v);
throw v;
label:
if v == null goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.RuntimeException)>("Will not attempt to authenticate using SASL ", v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001(\u)");
goto label;
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>("Will not attempt to authenticate using SASL ") <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u0001(unknown error)");
label:
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: java.lang.String configStatus> = v;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean isSASLConfigured> = 0;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getJaasConfKey()>();
if v == null goto label;
if v == null goto label;
v = new javax.security.auth.login.LoginException;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.sasl.clientconfig", "Client");
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getJaasConfKey()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String,java.lang.RuntimeException)>(v, v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("Zookeeper client cannot authenticate using the \'\u0001\' section of the supplied JAAS configuration: \'\u0001\' because of a RuntimeException: \u0001");
specialinvoke v.<javax.security.auth.login.LoginException: void <init>(java.lang.String)>(v);
throw v;
label:
v = new javax.security.auth.login.LoginException;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.sasl.clientconfig", "Client");
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getJaasConfKey()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String,java.lang.String)>(v, v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("No JAAS configuration section named \'\u0001\' was found in specified JAAS configuration file: \'\u0001\'.");
specialinvoke v.<javax.security.auth.login.LoginException: void <init>(java.lang.String)>(v);
throw v;
label:
return;
catch java.lang.SecurityException from label to label with label;
catch java.lang.IllegalArgumentException from label to label with label;
}
public java.lang.String getConfigStatus()
{
org.apache.zookeeper.client.ZooKeeperSaslClient v;
java.lang.String v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: java.lang.String configStatus>;
return v;
}
public boolean isComplete()
{
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v, v;
boolean v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState>;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState COMPLETE>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
public boolean isFailed()
{
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v, v;
boolean v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState>;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
if v != v goto label;
v = 1;
goto label;
label:
v = 0;
label:
return v;
}
private javax.security.sasl.SaslClient createSaslClient(java.lang.String, java.lang.String) throws javax.security.auth.login.LoginException
{
java.lang.Throwable v;
javax.security.auth.login.LoginException v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.Login v, v, v, v;
javax.security.sasl.SaslClient v;
java.lang.String v, v;
org.apache.zookeeper.client.ZKClientConfig v;
boolean v;
org.slf4j.Logger v, v, v;
org.apache.zookeeper.SaslClientCallbackHandler v;
java.lang.Exception v;
javax.security.auth.Subject v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean initializedLogin>;
if v != 0 goto label;
entermonitor v;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
if v != null goto label;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("JAAS loginContext is: {}", v);
v = new org.apache.zookeeper.Login;
v = new org.apache.zookeeper.SaslClientCallbackHandler;
specialinvoke v.<org.apache.zookeeper.SaslClientCallbackHandler: void <init>(java.lang.String,java.lang.String)>(null, "Client");
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZKClientConfig clientConfig>;
specialinvoke v.<org.apache.zookeeper.Login: void <init>(java.lang.String,javax.security.auth.callback.CallbackHandler,org.apache.zookeeper.common.ZKConfig)>(v, v, v);
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login> = v;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
virtualinvoke v.<org.apache.zookeeper.Login: void startThreadIfNeeded()>();
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean initializedLogin> = 1;
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
v = virtualinvoke v.<org.apache.zookeeper.Login: javax.security.auth.Subject getSubject()>();
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
v = staticinvoke <org.apache.zookeeper.util.SecurityUtils: javax.security.sasl.SaslClient createSaslClient(javax.security.auth.Subject,java.lang.String,java.lang.String,java.lang.String,org.slf4j.Logger,java.lang.String)>(v, v, "zookeeper", "zk-sasl-md5", v, "Client");
label:
return v;
label:
v := @caughtexception;
throw v;
label:
v := @caughtexception;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Throwable)>("Exception while trying to create SASL client.", v);
return null;
catch java.lang.Throwable from label to label with label;
catch javax.security.auth.login.LoginException from label to label with label;
catch java.lang.Exception from label to label with label;
}
public void respondToServer(byte[], org.apache.zookeeper.ClientCnxn)
{
byte[] v, v, v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.ClientCnxn v;
javax.security.sasl.SaslException v;
javax.security.sasl.SaslClient v, v, v, v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v;
java.lang.String v, v, v;
boolean v, v, v, v;
org.slf4j.Logger v, v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: byte[];
v := @parameter: org.apache.zookeeper.ClientCnxn;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
if v != null goto label;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>("saslClient is unexpectedly null. Cannot respond to server\'s SASL message; ignoring.");
return;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
v = interfaceinvoke v.<javax.security.sasl.SaslClient: boolean isComplete()>();
if v != 0 goto label;
label:
v = specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] createSaslToken(byte[])>(v);
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] saslToken> = v;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] saslToken>;
if v == null goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] saslToken>;
specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: void sendSaslPacket(byte[],org.apache.zookeeper.ClientCnxn)>(v, v);
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
v = virtualinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: java.lang.String getLoginContext()>();
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String,java.lang.Object,java.lang.Object)>("SASL authentication failed using login context \'{}\'.", v, v);
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean gotLastPacket> = 1;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
v = interfaceinvoke v.<javax.security.sasl.SaslClient: boolean isComplete()>();
if v == 0 goto label;
if v != null goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
v = interfaceinvoke v.<javax.security.sasl.SaslClient: java.lang.String getMechanismName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("GSSAPI");
if v == 0 goto label;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean gotLastPacket> = 1;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
v = interfaceinvoke v.<javax.security.sasl.SaslClient: java.lang.String getMechanismName()>();
v = virtualinvoke v.<java.lang.String: boolean equals(java.lang.Object)>("GSSAPI");
if v != 0 goto label;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean gotLastPacket> = 1;
label:
virtualinvoke v.<org.apache.zookeeper.ClientCnxn: void saslCompleted()>();
label:
return;
catch javax.security.sasl.SaslException from label to label with label;
}
private byte[] createSaslToken() throws javax.security.sasl.SaslException
{
byte[] v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState INTERMEDIATE>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] saslToken>;
v = specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] createSaslToken(byte[])>(v);
return v;
}
private byte[] createSaslToken(byte[]) throws javax.security.sasl.SaslException
{
java.lang.Throwable v;
byte[] v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
javax.security.sasl.SaslException v, v, v;
org.apache.zookeeper.Login v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v, v;
java.lang.String v, v, v;
boolean v;
java.security.PrivilegedActionException v;
org.slf4j.Logger v;
javax.security.auth.Subject v;
org.apache.zookeeper.client.ZooKeeperSaslClient$1 v;
java.lang.Object v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: byte[];
if v != null goto label;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v = new javax.security.sasl.SaslException;
specialinvoke v.<javax.security.sasl.SaslException: void <init>(java.lang.String)>("Error in authenticating with a Zookeeper Quorum member: the quorum member\'s saslToken is null.");
throw v;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
v = virtualinvoke v.<org.apache.zookeeper.Login: javax.security.auth.Subject getSubject()>();
if v == null goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
entermonitor v;
label:
v = new org.apache.zookeeper.client.ZooKeeperSaslClient$1;
specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient$1: void <init>(org.apache.zookeeper.client.ZooKeeperSaslClient,byte[])>(v, v);
v = staticinvoke <javax.security.auth.Subject: java.lang.Object doAs(javax.security.auth.Subject,java.security.PrivilegedExceptionAction)>(v, v);
label:
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.security.PrivilegedActionException)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("An error: (\u) occurred when evaluating Zookeeper Quorum Member\'s  received SASL token.");
v = virtualinvoke v.<java.security.PrivilegedActionException: java.lang.String toString()>();
v = virtualinvoke v.<java.lang.String: boolean contains(java.lang.CharSequence)>("(Mechanism level: Server not found in Kerberos database (7) - UNKNOWN_SERVER)");
if v == 0 goto label;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u This may be caused by Java\'s being unable to resolve the Zookeeper Quorum Member\'s hostname correctly. You may want to try to adding \'-Dsun.net.spi.nameservice.provider.1=dns,sun\' to your client\'s JVMFLAGS environment.");
label:
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.String)>(v) <java.lang.invoke.StringConcatFactory: java.lang.invoke.CallSite makeConcatWithConstants(java.lang.invoke.MethodHandles$Lookup,java.lang.String,java.lang.invoke.MethodType,java.lang.String,java.lang.Object[])>("\u Zookeeper Client will go to AUTH_FAILED state.");
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v = new javax.security.sasl.SaslException;
specialinvoke v.<javax.security.sasl.SaslException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = new javax.security.sasl.SaslException;
specialinvoke v.<javax.security.sasl.SaslException: void <init>(java.lang.String)>("Cannot make SASL token without subject defined. For diagnosis, please look for WARNs and ERRORs in your log related to the Login class.");
throw v;
catch java.security.PrivilegedActionException from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void sendSaslPacket(byte[], org.apache.zookeeper.ClientCnxn) throws javax.security.sasl.SaslException
{
byte[] v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.slf4j.Logger v;
org.apache.zookeeper.ClientCnxn v;
org.apache.zookeeper.proto.GetSASLRequest v;
java.io.IOException v;
javax.security.sasl.SaslException v;
java.lang.Integer v;
org.apache.zookeeper.proto.SetSASLResponse v;
int v;
org.apache.zookeeper.client.ZooKeeperSaslClient$ServerSaslResponseCallback v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: byte[];
v := @parameter: org.apache.zookeeper.ClientCnxn;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
v = lengthof v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("ClientCnxn:sendSaslPacket:length={}", v);
v = new org.apache.zookeeper.proto.GetSASLRequest;
specialinvoke v.<org.apache.zookeeper.proto.GetSASLRequest: void <init>()>();
virtualinvoke v.<org.apache.zookeeper.proto.GetSASLRequest: void setToken(byte[])>(v);
v = new org.apache.zookeeper.proto.SetSASLResponse;
specialinvoke v.<org.apache.zookeeper.proto.SetSASLResponse: void <init>()>();
v = new org.apache.zookeeper.client.ZooKeeperSaslClient$ServerSaslResponseCallback;
specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient$ServerSaslResponseCallback: void <init>()>();
label:
virtualinvoke v.<org.apache.zookeeper.ClientCnxn: void sendPacket(org.apache.jute.Record,org.apache.jute.Record,org.apache.zookeeper.AsyncCallback,int)>(v, v, v, 102);
label:
goto label;
label:
v := @caughtexception;
v = new javax.security.sasl.SaslException;
specialinvoke v.<javax.security.sasl.SaslException: void <init>(java.lang.String,java.lang.Throwable)>("Failed to send SASL packet to server.", v);
throw v;
label:
return;
catch java.io.IOException from label to label with label;
}
private void sendSaslPacket(org.apache.zookeeper.ClientCnxn) throws javax.security.sasl.SaslException
{
byte[] v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.slf4j.Logger v;
org.apache.zookeeper.ClientCnxn v;
org.apache.zookeeper.proto.GetSASLRequest v;
java.io.IOException v;
javax.security.sasl.SaslException v;
java.lang.Integer v;
org.apache.zookeeper.proto.SetSASLResponse v;
int v;
org.apache.zookeeper.client.ZooKeeperSaslClient$ServerSaslResponseCallback v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: org.apache.zookeeper.ClientCnxn;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] saslToken>;
v = lengthof v;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("ClientCnxn:sendSaslPacket:length={}", v);
v = new org.apache.zookeeper.proto.GetSASLRequest;
specialinvoke v.<org.apache.zookeeper.proto.GetSASLRequest: void <init>()>();
v = specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: byte[] createSaslToken()>();
virtualinvoke v.<org.apache.zookeeper.proto.GetSASLRequest: void setToken(byte[])>(v);
v = new org.apache.zookeeper.proto.SetSASLResponse;
specialinvoke v.<org.apache.zookeeper.proto.SetSASLResponse: void <init>()>();
v = new org.apache.zookeeper.client.ZooKeeperSaslClient$ServerSaslResponseCallback;
specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient$ServerSaslResponseCallback: void <init>()>();
label:
virtualinvoke v.<org.apache.zookeeper.ClientCnxn: void sendPacket(org.apache.jute.Record,org.apache.jute.Record,org.apache.zookeeper.AsyncCallback,int)>(v, v, v, 102);
label:
goto label;
label:
v := @caughtexception;
v = new javax.security.sasl.SaslException;
specialinvoke v.<javax.security.sasl.SaslException: void <init>(java.lang.String,java.lang.Throwable)>("Failed to send SASL packet to server due to IOException:", v);
throw v;
label:
return;
catch java.io.IOException from label to label with label;
}
public org.apache.zookeeper.Watcher$Event$KeeperState getKeeperState()
{
org.apache.zookeeper.Watcher$Event$KeeperState v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
javax.security.sasl.SaslClient v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v, v, v, v, v;
boolean v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
if v == null goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState>;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
if v != v goto label;
v = <org.apache.zookeeper.Watcher$Event$KeeperState: org.apache.zookeeper.Watcher$Event$KeeperState AuthFailed>;
return v;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
v = interfaceinvoke v.<javax.security.sasl.SaslClient: boolean isComplete()>();
if v == 0 goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState>;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState INTERMEDIATE>;
if v != v goto label;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState COMPLETE>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v = <org.apache.zookeeper.Watcher$Event$KeeperState: org.apache.zookeeper.Watcher$Event$KeeperState SaslAuthenticated>;
return v;
label:
return null;
}
public void initialize(org.apache.zookeeper.ClientCnxn) throws javax.security.sasl.SaslException
{
byte[] v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.apache.zookeeper.ClientCnxn v;
javax.security.sasl.SaslException v;
javax.security.sasl.SaslClient v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState v, v, v, v;
boolean v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v := @parameter: org.apache.zookeeper.ClientCnxn;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
if v != null goto label;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState FAILED>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
v = new javax.security.sasl.SaslException;
specialinvoke v.<javax.security.sasl.SaslException: void <init>(java.lang.String)>("saslClient failed to initialize properly: it\'s null.");
throw v;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState>;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState INITIAL>;
if v != v goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: javax.security.sasl.SaslClient saslClient>;
v = interfaceinvoke v.<javax.security.sasl.SaslClient: boolean hasInitialResponse()>();
if v == 0 goto label;
specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: void sendSaslPacket(org.apache.zookeeper.ClientCnxn)>(v);
goto label;
label:
v = newarray (byte)[0];
specialinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: void sendSaslPacket(byte[],org.apache.zookeeper.ClientCnxn)>(v, v);
label:
v = <org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState INTERMEDIATE>;
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZooKeeperSaslClient$SaslState saslState> = v;
label:
return;
}
public boolean clientTunneledAuthenticationInProgress()
{
org.apache.zookeeper.client.ZooKeeperSaslClient v;
org.slf4j.Logger v;
javax.security.auth.login.AppConfigurationEntry[] v;
java.lang.SecurityException v;
java.lang.String v, v;
org.apache.zookeeper.client.ZKClientConfig v, v;
javax.security.auth.login.Configuration v, v;
boolean v, v, v, v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean isSASLConfigured>;
if v != 0 goto label;
return 0;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZKClientConfig clientConfig>;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getJaasConfKey()>();
if v != null goto label;
v = staticinvoke <javax.security.auth.login.Configuration: javax.security.auth.login.Configuration getConfiguration()>();
if v == null goto label;
v = staticinvoke <javax.security.auth.login.Configuration: javax.security.auth.login.Configuration getConfiguration()>();
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.client.ZKClientConfig clientConfig>;
v = virtualinvoke v.<org.apache.zookeeper.client.ZKClientConfig: java.lang.String getProperty(java.lang.String,java.lang.String)>("zookeeper.sasl.clientconfig", "Client");
v = virtualinvoke v.<javax.security.auth.login.Configuration: javax.security.auth.login.AppConfigurationEntry[] getAppConfigurationEntry(java.lang.String)>(v);
if v == null goto label;
label:
v = virtualinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean isComplete()>();
if v != 0 goto label;
v = virtualinvoke v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean isFailed()>();
if v != 0 goto label;
label:
return 1;
label:
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: boolean gotLastPacket>;
if v != 0 goto label;
label:
return 1;
label:
return 0;
label:
v := @caughtexception;
v = <org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Throwable)>("Could not retrieve login configuration", v);
return 0;
catch java.lang.SecurityException from label to label with label;
catch java.lang.SecurityException from label to label with label;
}
public void shutdown()
{
org.apache.zookeeper.Login v, v;
org.apache.zookeeper.client.ZooKeeperSaslClient v;
v := @this: org.apache.zookeeper.client.ZooKeeperSaslClient;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
if null == v goto label;
v = v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login>;
virtualinvoke v.<org.apache.zookeeper.Login: void shutdown()>();
v.<org.apache.zookeeper.client.ZooKeeperSaslClient: org.apache.zookeeper.Login login> = null;
label:
return;
}
static void <clinit>()
{
org.slf4j.Logger v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/zookeeper/client/ZooKeeperSaslClient;");
<org.apache.zookeeper.client.ZooKeeperSaslClient: org.slf4j.Logger LOG> = v;
return;
}
}