public class org.apache.activemq.shiro.authz.DestinationActionPermissionResolver extends java.lang.Object implements org.apache.activemq.shiro.authz.ActionPermissionResolver
{
private java.lang.String permissionStringPrefix;
private boolean permissionStringCaseSensitive;
public void <init>()
{
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
specialinvoke v.<java.lang.Object: void <init>()>();
v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: boolean permissionStringCaseSensitive> = 1;
return;
}
public java.lang.String getPermissionStringPrefix()
{
java.lang.String v;
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v = v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.lang.String permissionStringPrefix>;
return v;
}
public void setPermissionStringPrefix(java.lang.String)
{
java.lang.String v;
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: java.lang.String;
v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.lang.String permissionStringPrefix> = v;
return;
}
public boolean isPermissionStringCaseSensitive()
{
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
boolean v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v = v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: boolean permissionStringCaseSensitive>;
return v;
}
public void setPermissionStringCaseSensitive(boolean)
{
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
boolean v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: boolean;
v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: boolean permissionStringCaseSensitive> = v;
return;
}
public java.util.Collection getPermissions(org.apache.activemq.shiro.authz.Action)
{
java.util.Collection v;
java.lang.IllegalArgumentException v;
org.apache.activemq.shiro.authz.Action v;
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
java.lang.Class v;
java.lang.String v, v;
boolean v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: org.apache.activemq.shiro.authz.Action;
v = v instanceof org.apache.activemq.shiro.authz.DestinationAction;
if v != 0 goto label;
v = new java.lang.IllegalArgumentException;
v = class "Lorg/apache/activemq/shiro/authz/DestinationAction;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
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[])>("Action argument must be a \u instance.");
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>(v);
throw v;
label:
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.util.Collection getPermissions(org.apache.activemq.shiro.authz.DestinationAction)>(v);
return v;
}
protected java.util.Collection getPermissions(org.apache.activemq.shiro.authz.DestinationAction)
{
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
java.util.Collection v;
java.lang.String v;
org.apache.activemq.shiro.authz.DestinationAction v;
org.apache.activemq.command.ActiveMQDestination v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: org.apache.activemq.shiro.authz.DestinationAction;
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationAction: org.apache.activemq.command.ActiveMQDestination getDestination()>();
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationAction: java.lang.String getVerb()>();
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.util.Collection createPermissions(org.apache.activemq.command.ActiveMQDestination,java.lang.String)>(v, v);
return v;
}
protected java.util.Collection createPermissions(org.apache.activemq.command.ActiveMQDestination, java.lang.String)
{
java.util.Collection v;
org.apache.shiro.authz.Permission v;
org.apache.activemq.command.ActiveMQDestination v, v;
java.util.HashSet v, v;
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
int v, v, v;
java.lang.String v, v;
java.util.LinkedHashSet v;
org.apache.activemq.command.ActiveMQDestination[] v;
boolean v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean isComposite()>();
if v == 0 goto label;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: org.apache.activemq.command.ActiveMQDestination[] getCompositeDestinations()>();
v = new java.util.LinkedHashSet;
v = lengthof v;
specialinvoke v.<java.util.LinkedHashSet: void <init>(int)>(v);
v = v;
v = lengthof v;
v = 0;
label:
if v >= v goto label;
v = v[v];
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.util.Collection createPermissions(org.apache.activemq.command.ActiveMQDestination,java.lang.String)>(v, v);
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
v = v + 1;
goto label;
label:
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>(int)>(1);
v = v;
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.lang.String createPermissionString(org.apache.activemq.command.ActiveMQDestination,java.lang.String)>(v, v);
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: org.apache.shiro.authz.Permission createPermission(java.lang.String)>(v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
label:
return v;
}
protected java.lang.String createPermissionString(org.apache.activemq.command.ActiveMQDestination, java.lang.String)
{
java.lang.IllegalArgumentException v;
org.apache.activemq.command.ActiveMQDestination v;
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
java.lang.StringBuilder v;
java.lang.String v, v, v, v, v, v;
boolean v, v, v, v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: org.apache.activemq.command.ActiveMQDestination;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean isComposite()>();
if v == 0 goto label;
v = new java.lang.IllegalArgumentException;
specialinvoke v.<java.lang.IllegalArgumentException: void <init>(java.lang.String)>("Use createPermissionStrings for composite destinations.");
throw v;
label:
v = new java.lang.StringBuilder;
specialinvoke v.<java.lang.StringBuilder: void <init>()>();
v = v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.lang.String permissionStringPrefix>;
if v == null goto label;
v = v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.lang.String permissionStringPrefix>;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: java.lang.String permissionStringPrefix>;
v = virtualinvoke v.<java.lang.String: boolean endsWith(java.lang.String)>(":");
if v != 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(":");
label:
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean isTemporary()>();
if v == 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("temp-");
label:
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: boolean isTopic()>();
if v == 0 goto label;
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("topic:");
goto label;
label:
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>("queue:");
label:
v = virtualinvoke v.<org.apache.activemq.command.ActiveMQDestination: java.lang.String getPhysicalName()>();
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(char)>(58);
virtualinvoke v.<java.lang.StringBuilder: java.lang.StringBuilder append(java.lang.String)>(v);
v = virtualinvoke v.<java.lang.StringBuilder: java.lang.String toString()>();
return v;
}
protected org.apache.shiro.authz.Permission createPermission(java.lang.String)
{
org.apache.activemq.shiro.authz.DestinationActionPermissionResolver v;
java.lang.String v;
boolean v;
org.apache.activemq.shiro.authz.ActiveMQWildcardPermission v;
v := @this: org.apache.activemq.shiro.authz.DestinationActionPermissionResolver;
v := @parameter: java.lang.String;
v = new org.apache.activemq.shiro.authz.ActiveMQWildcardPermission;
v = virtualinvoke v.<org.apache.activemq.shiro.authz.DestinationActionPermissionResolver: boolean isPermissionStringCaseSensitive()>();
specialinvoke v.<org.apache.activemq.shiro.authz.ActiveMQWildcardPermission: void <init>(java.lang.String,boolean)>(v, v);
return v;
}
}