public class org.apache.activemq.security.JaasDualAuthenticationBroker extends org.apache.activemq.broker.BrokerFilter implements org.apache.activemq.security.AuthenticationBroker
{
private final org.apache.activemq.security.JaasCertificateAuthenticationBroker sslBroker;
private final org.apache.activemq.security.JaasAuthenticationBroker nonSslBroker;
public void <init>(org.apache.activemq.broker.Broker, java.lang.String, java.lang.String)
{
org.apache.activemq.broker.EmptyBroker v, v;
org.apache.activemq.security.JaasDualAuthenticationBroker v;
org.apache.activemq.broker.Broker v;
org.apache.activemq.security.JaasAuthenticationBroker v;
java.lang.String v, v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
v := @this: org.apache.activemq.security.JaasDualAuthenticationBroker;
v := @parameter: org.apache.activemq.broker.Broker;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
specialinvoke v.<org.apache.activemq.broker.BrokerFilter: void <init>(org.apache.activemq.broker.Broker)>(v);
v = new org.apache.activemq.security.JaasAuthenticationBroker;
v = new org.apache.activemq.broker.EmptyBroker;
specialinvoke v.<org.apache.activemq.broker.EmptyBroker: void <init>()>();
specialinvoke v.<org.apache.activemq.security.JaasAuthenticationBroker: void <init>(org.apache.activemq.broker.Broker,java.lang.String)>(v, v);
v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasAuthenticationBroker nonSslBroker> = v;
v = new org.apache.activemq.security.JaasCertificateAuthenticationBroker;
v = new org.apache.activemq.broker.EmptyBroker;
specialinvoke v.<org.apache.activemq.broker.EmptyBroker: void <init>()>();
specialinvoke v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: void <init>(org.apache.activemq.broker.Broker,java.lang.String)>(v, v);
v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasCertificateAuthenticationBroker sslBroker> = v;
return;
}
public void addConnection(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.ConnectionInfo) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.security.SecurityContext v;
org.apache.activemq.command.ConnectionInfo v;
org.apache.activemq.security.JaasAuthenticationBroker v;
org.apache.activemq.security.JaasDualAuthenticationBroker v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
boolean v;
v := @this: org.apache.activemq.security.JaasDualAuthenticationBroker;
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 = specialinvoke v.<org.apache.activemq.security.JaasDualAuthenticationBroker: boolean isSSL(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo)>(v, v);
if v == 0 goto label;
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasCertificateAuthenticationBroker sslBroker>;
virtualinvoke v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: void addConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo)>(v, v);
goto label;
label:
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasAuthenticationBroker nonSslBroker>;
virtualinvoke v.<org.apache.activemq.security.JaasAuthenticationBroker: void addConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo)>(v, v);
label:
specialinvoke v.<org.apache.activemq.broker.BrokerFilter: void addConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo)>(v, v);
label:
return;
}
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.JaasAuthenticationBroker v;
org.apache.activemq.security.JaasDualAuthenticationBroker v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
boolean v;
v := @this: org.apache.activemq.security.JaasDualAuthenticationBroker;
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);
v = specialinvoke v.<org.apache.activemq.security.JaasDualAuthenticationBroker: boolean isSSL(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo)>(v, v);
if v == 0 goto label;
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasCertificateAuthenticationBroker sslBroker>;
virtualinvoke v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: void removeConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo,java.lang.Throwable)>(v, v, v);
goto label;
label:
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasAuthenticationBroker nonSslBroker>;
virtualinvoke v.<org.apache.activemq.security.JaasAuthenticationBroker: void removeConnection(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ConnectionInfo,java.lang.Throwable)>(v, v, v);
label:
return;
}
private boolean isSSL(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.ConnectionInfo) throws java.lang.Exception
{
org.apache.activemq.transport.TransportServer v;
org.apache.activemq.security.JaasDualAuthenticationBroker v;
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.command.ConnectionInfo v;
org.apache.activemq.broker.Connector v;
java.lang.Object v;
boolean v, v, v;
v := @this: org.apache.activemq.security.JaasDualAuthenticationBroker;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.ConnectionInfo;
v = 0;
v = virtualinvoke v.<org.apache.activemq.broker.ConnectionContext: org.apache.activemq.broker.Connector getConnector()>();
v = v instanceof org.apache.activemq.broker.TransportConnector;
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.broker.TransportConnector: org.apache.activemq.transport.TransportServer getServer()>();
v = interfaceinvoke v.<org.apache.activemq.transport.TransportServer: boolean isSslServer()>();
label:
if v != 0 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 = 1;
label:
return v;
}
public void removeDestination(org.apache.activemq.broker.ConnectionContext, org.apache.activemq.command.ActiveMQDestination, long) throws java.lang.Exception
{
org.apache.activemq.broker.ConnectionContext v;
org.apache.activemq.security.JaasAuthenticationBroker v;
long v;
org.apache.activemq.security.JaasDualAuthenticationBroker v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.security.JaasDualAuthenticationBroker;
v := @parameter: org.apache.activemq.broker.ConnectionContext;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: long;
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasCertificateAuthenticationBroker sslBroker>;
virtualinvoke v.<org.apache.activemq.security.JaasCertificateAuthenticationBroker: void removeDestination(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ActiveMQDestination,long)>(v, v, v);
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasAuthenticationBroker nonSslBroker>;
virtualinvoke v.<org.apache.activemq.security.JaasAuthenticationBroker: void removeDestination(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ActiveMQDestination,long)>(v, v, v);
specialinvoke v.<org.apache.activemq.broker.BrokerFilter: void removeDestination(org.apache.activemq.broker.ConnectionContext,org.apache.activemq.command.ActiveMQDestination,long)>(v, v, v);
return;
}
public org.apache.activemq.security.SecurityContext authenticate(java.lang.String, java.lang.String, java.security.cert.X509Certificate[]) throws java.lang.SecurityException
{
org.apache.activemq.security.SecurityContext v, v;
org.apache.activemq.security.JaasDualAuthenticationBroker v;
org.apache.activemq.security.JaasAuthenticationBroker v;
java.lang.String v, v;
java.security.cert.X509Certificate[] v;
org.apache.activemq.security.JaasCertificateAuthenticationBroker v;
v := @this: org.apache.activemq.security.JaasDualAuthenticationBroker;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v := @parameter: java.security.cert.X509Certificate[];
if v == null goto label;
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasCertificateAuthenticationBroker sslBroker>;
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);
return v;
label:
v = v.<org.apache.activemq.security.JaasDualAuthenticationBroker: org.apache.activemq.security.JaasAuthenticationBroker nonSslBroker>;
v = virtualinvoke v.<org.apache.activemq.security.JaasAuthenticationBroker: org.apache.activemq.security.SecurityContext authenticate(java.lang.String,java.lang.String,java.security.cert.X509Certificate[])>(v, v, v);
return v;
}
}