public class org.apache.activemq.security.JaasCertificateAuthenticationBroker extends org.apache.activemq.broker.BrokerFilter implements org.apache.activemq.security.AuthenticationBroker
{
private final java.lang.String jaasConfiguration;
public void <init>(org.apache.activemq.broker.Broker, java.lang.String)
{
org.apache.activemq.broker.Broker v;
java.lang.String v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
v := @this: org.apache.activemq.security.JaasCertificateAuthenticationBroker;
v := @parameter: org.apache.activemq.broker.Broker;
v := @parameter: java.lang.String;
specialinvoke v.<org.apache.activemq.broker.BrokerFilter: void <init>(org.apache.activemq.broker.Broker)>(v);
v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: java.lang.String jaasConfiguration> = v;
return;
}
public void addConnection(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.ConnectionInfo) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.security.SecurityContext v, v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.ConnectionInfo v;
java.lang.Thread v, v, v, v;
java.lang.SecurityException v;
java.lang.String v, v;
boolean v;
java.lang.Class v;
java.lang.Object v, v;
java.lang.ClassLoader v, v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
v := @this: org.apache.activemq.security.JaasCertificateAuthenticationBroker;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.ConnectionInfo;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.security.SecurityContext getSecurityContext()>();
if v != null goto label;
v = virtualinvoke v.<org.apache.activemq.command.ConnectionInfo: java.lang.Object getTransportContext()>();
v = v instanceof java.security.cert.X509Certificate[];
if v != 0 goto label;
v = new java.lang.SecurityException;
specialinvoke v.<java.lang.SecurityException: void <init>(java.lang.String)>("Unable to authenticate transport without SSL certificate.");
throw v;
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = virtualinvoke v.<java.lang.Thread: java.lang.ClassLoader getContextClassLoader()>();
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
v = class "Lorg/apache/activemq/security/JaasAuthenticationBroker;";
v = virtualinvoke v.<java.lang.Class: java.lang.ClassLoader getClassLoader()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
label:
v = virtualinvoke v.<org.apache.activemq.command.ConnectionInfo: java.lang.String getUserName()>();
v = virtualinvoke v.<org.apache.activemq.command.ConnectionInfo: java.lang.String getPassword()>();
v = virtualinvoke v.<org.apache.activemq.command.ConnectionInfo: java.lang.Object getTransportContext()>();
v = virtualinvoke v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: org.apache.activemq.security.SecurityContext authenticate(java.lang.String,java.lang.String,java.security.cert.X509Certificate[])>(v, v, v);
virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: void setSecurityContext(org.apache.activemq.security.SecurityContext)>(v);
label:
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
goto label;
label:
v := @caughtexception;
v = staticinvoke <java.lang.Thread: java.lang.Thread currentThread()>();
virtualinvoke v.<java.lang.Thread: void setContextClassLoader(java.lang.ClassLoader)>(v);
throw v;
label:
specialinvoke v.<org.apache.activemq.broker.BrokerFilter: void addConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo)>(v, v);
return;
catch java.lang.Throwable from label to label with label;
}
public void removeConnection(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.ConnectionInfo, java.lang.Throwable) throws java.lang.Exception
{
java.lang.Throwable v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.ConnectionInfo v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
v := @this: org.apache.activemq.security.JaasCertificateAuthenticationBroker;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.ConnectionInfo;
v := @parameter: java.lang.Throwable;
specialinvoke v.<org.apache.activemq.broker.BrokerFilter: void removeConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo,java.lang.Throwable)>(v, v, v);
virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: void setSecurityContext(org.apache.activemq.security.SecurityContext)>(null);
return;
}
public org.apache.activemq.security.SecurityContext authenticate(java.lang.String, java.lang.String, java.security.cert.X509Certificate[]) throws java.lang.SecurityException
{
javax.security.auth.login.LoginContext v;
java.lang.SecurityException v;
java.lang.String v, v, v, v, v, v;
boolean v, v;
java.util.Iterator v;
java.util.Set v;
org.apache.activemq.jaas.JaasCertificateCallbackHandler v;
java.lang.Exception v;
javax.security.auth.Subject v;
java.security.Principal v;
org.apache.activemq.security.JaasCertificateSecurityContext v;
java.lang.Object v;
java.security.cert.X509Certificate[] v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
v := @this: org.apache.activemq.security.JaasCertificateAuthenticationBroker;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.security.cert.X509Certificate[];
label:
v = new org.apache.activemq.jaas.JaasCertificateCallbackHandler;
specialinvoke v.<org.apache.activemq.jaas.JaasCertificateCallbackHandler: void <init>(java.security.cert.X509Certificate[])>(v);
v = new javax.security.auth.login.LoginContext;
v = v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: java.lang.String jaasConfiguration>;
specialinvoke v.<javax.security.auth.login.LoginContext: void <init>(java.lang.String,javax.security.auth.callback.CallbackHandler)>(v, v);
virtualinvoke v.<javax.security.auth.login.LoginContext: void login()>();
v = virtualinvoke v.<javax.security.auth.login.LoginContext: javax.security.auth.Subject getSubject()>();
v = "";
v = virtualinvoke v.<javax.security.auth.Subject: java.util.Set getPrincipals()>();
v = interfaceinvoke v.<java.util.Set: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = v instanceof org.apache.activemq.jaas.UserPrincipal;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.jaas.UserPrincipal: java.lang.String getName()>();
label:
v = new org.apache.activemq.security.JaasCertificateSecurityContext;
specialinvoke v.<org.apache.activemq.security.JaasCertificateSecurityContext: void <init>(java.lang.String,javax.security.auth.Subject,java.security.cert.X509Certificate[])>(v, v, v);
label:
return v;
label:
v := @caughtexception;
v = new java.lang.SecurityException;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
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[])>("User name [\u] or password is invalid. \u0001");
specialinvoke v.<java.lang.SecurityException: void <init>(java.lang.String,java.lang.Throwable)>(v, v);
throw v;
catch java.lang.Exception from label to label with label;
}
}