public class org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider extends java.lang.Object implements org.apache.nifi.registry.security.authorization.UserGroupProvider
{
private static final org.slf4j.Logger logger;
private static final java.lang.String OS_TYPE_ERROR;
private static final java.lang.String SYS_CHECK_ERROR;
private static final java.util.Map usersById;
private static final java.util.Map usersByName;
private static final java.util.Map groupsById;
public static final java.lang.String REFRESH_DELAY_PROPERTY;
private static final long MINIMUM_SYNC_INTERVAL_MILLISECONDS;
public static final java.lang.String EXCLUDE_USER_PROPERTY;
public static final java.lang.String EXCLUDE_GROUP_PROPERTY;
public static final java.lang.String COMMAND_TIMEOUT_PROPERTY;
private static final java.lang.String DEFAULT_COMMAND_TIMEOUT;
private long fixedDelay;
private java.util.regex.Pattern excludeUsers;
private java.util.regex.Pattern excludeGroups;
private int timeoutSeconds;
private final java.util.concurrent.ScheduledExecutorService scheduler;
private org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider selectedShellCommands;
private org.apache.nifi.registry.security.authorization.shell.ShellRunner shellRunner;
public void <init>()
{
java.util.concurrent.ScheduledExecutorService v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
specialinvoke v.<java.lang.Object: void <init>()>();
v = staticinvoke <java.util.concurrent.Executors: java.util.concurrent.ScheduledExecutorService newScheduledThreadPool(int)>(2);
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.concurrent.ScheduledExecutorService scheduler> = v;
return;
}
public java.util.Set getUsers() throws org.apache.nifi.registry.security.authorization.exception.AuthorizationAccessException
{
java.lang.Throwable v;
org.slf4j.Logger v;
java.util.Collection v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.HashSet v;
java.util.Map v, v, v;
int v;
java.lang.String v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
v = interfaceinvoke v.<java.util.Map: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("getUsers has user set of size: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = new java.util.HashSet;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
specialinvoke v.<java.util.HashSet: void <init>(java.util.Collection)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.nifi.registry.security.authorization.User getUser(java.lang.String) throws org.apache.nifi.registry.security.authorization.exception.AuthorizationAccessException
{
java.lang.Throwable v;
org.slf4j.Logger v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v, v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.lang.String;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
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[])>("getUser (by id) user not found: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
goto label;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (org.apache.nifi.registry.security.authorization.User,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[])>("getUser (by id) found user: \u for id: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.nifi.registry.security.authorization.User getUserByIdentity(java.lang.String) throws org.apache.nifi.registry.security.authorization.exception.AuthorizationAccessException
{
java.lang.Throwable v;
org.slf4j.Logger v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v, v, v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.lang.String;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
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[])>("getUser (by name) user not found: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
goto label;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.User: java.lang.String getIdentity()>();
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[])>("getUser (by name) found user: \u for name: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public java.util.Set getGroups() throws org.apache.nifi.registry.security.authorization.exception.AuthorizationAccessException
{
java.lang.Throwable v;
org.slf4j.Logger v;
java.util.Collection v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.HashSet v;
java.util.Map v, v, v;
int v;
java.lang.String v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
v = interfaceinvoke v.<java.util.Map: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("getGroups has group set of size: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = new java.util.HashSet;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
specialinvoke v.<java.util.HashSet: void <init>(java.util.Collection)>(v);
exitmonitor v;
label:
return v;
label:
v := @caughtexception;
exitmonitor v;
throw v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.nifi.registry.security.authorization.Group getGroup(java.lang.String) throws org.apache.nifi.registry.security.authorization.exception.AuthorizationAccessException
{
java.lang.Throwable v;
org.slf4j.Logger v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.Map v, v;
java.lang.Object v;
java.lang.String v, v, v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.lang.String;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
v = interfaceinvoke v.<java.util.Map: java.lang.Object get(java.lang.Object)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
if v != null goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
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[])>("getGroup (by id) group not found: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
goto label;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.Group: java.lang.String getName()>();
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[])>("getGroup (by id) found group: \u for id: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
label:
return v;
catch java.lang.Throwable from label to label with label;
}
public org.apache.nifi.registry.security.authorization.UserAndGroups getUserAndGroups(java.lang.String) throws org.apache.nifi.registry.security.authorization.exception.AuthorizationAccessException
{
java.lang.Object[] v, v;
java.util.HashSet v;
java.lang.String v, v, v, v;
boolean v, v, v;
org.slf4j.Logger v, v, v;
java.util.Iterator v;
java.util.Set v, v;
org.apache.nifi.registry.security.authorization.User v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.lang.Object v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$1 v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.lang.String;
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.User getUserByIdentity(java.lang.String)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("Retrieved user {} for identity {}", v);
v = new java.util.HashSet;
specialinvoke v.<java.util.HashSet: void <init>()>();
if v == null goto label;
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Set getGroups()>();
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 = virtualinvoke v.<org.apache.nifi.registry.security.authorization.Group: java.util.Set getUsers()>();
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.User: java.lang.String getIdentifier()>();
v = interfaceinvoke v.<java.util.Set: boolean contains(java.lang.Object)>(v);
if v == 0 goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = newarray (java.lang.Object)[2];
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.User: java.lang.String getIdentity()>();
v[0] = v;
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.Group: java.lang.String getName()>();
v[1] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("User {} belongs to group {}", v);
interfaceinvoke v.<java.util.Set: boolean add(java.lang.Object)>(v);
goto label;
label:
v = interfaceinvoke v.<java.util.Set: boolean isEmpty()>();
if v == 0 goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object)>("User {} belongs to no groups", v);
label:
v = new org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$1;
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$1: void <init>(org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider,org.apache.nifi.registry.security.authorization.User,java.util.Set)>(v, v, v);
return v;
}
public void initialize(org.apache.nifi.registry.security.authorization.UserGroupProviderInitializationContext) throws org.apache.nifi.registry.security.exception.SecurityProviderCreationException
{
org.apache.nifi.registry.security.authorization.UserGroupProviderInitializationContext v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: org.apache.nifi.registry.security.authorization.UserGroupProviderInitializationContext;
return;
}
public void onConfigured(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext) throws org.apache.nifi.registry.security.exception.SecurityProviderCreationException
{
java.lang.Object[] v;
long v, v, v;
java.lang.Integer v;
java.lang.Runnable v;
int v, v, v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v, v, v, v, v;
java.util.regex.PatternSyntaxException v;
org.slf4j.Logger v, v, v, v;
org.apache.nifi.registry.security.exception.SecurityProviderCreationException v, v;
org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider v;
java.lang.Exception v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.concurrent.TimeUnit v;
org.apache.nifi.registry.security.authorization.shell.ShellRunner v, v;
org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext v;
java.util.regex.Pattern v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Configuring ShellUserGroupProvider");
v = specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: long getDelayProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext,java.lang.String,java.lang.String)>(v, "Refresh Delay", "5 mins");
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: long fixedDelay> = v;
v = specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: int getTimeoutProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext,java.lang.String,java.lang.String)>(v, "Command Timeout", "60 seconds");
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: int timeoutSeconds> = v;
v = new org.apache.nifi.registry.security.authorization.shell.ShellRunner;
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: int timeoutSeconds>;
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellRunner: void <init>(int)>(v);
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellRunner shellRunner> = v;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = newarray (java.lang.Object)[1];
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: int timeoutSeconds>;
v = staticinvoke <java.lang.Integer: java.lang.Integer valueOf(int)>(v);
v[0] = v;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String,java.lang.Object[])>("Configured ShellRunner with command timeout of \'{}\' seconds", v);
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider getCommandsProvider()>();
if v != null goto label;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider getCommandsProviderFromName(java.lang.String)>(null);
virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: void setCommandsProvider(org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider)>(v);
label:
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellRunner shellRunner>;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider: java.lang.String getSystemCheck()>();
virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellRunner: java.util.List runShell(java.lang.String,java.lang.String)>(v, "Supported System Check");
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider: java.lang.String getSystemCheck()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.lang.Exception,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[])>("initialize exception: \u system check command: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
v = new org.apache.nifi.registry.security.exception.SecurityProviderCreationException;
specialinvoke v.<org.apache.nifi.registry.security.exception.SecurityProviderCreationException: void <init>(java.lang.String,java.lang.Throwable)>("System check failed - cannot provide users and groups.", v);
throw v;
label:
v = specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.lang.String getProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext,java.lang.String,java.lang.String)>(v, "Exclude Groups", "");
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>(v);
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.regex.Pattern excludeGroups> = v;
v = specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.lang.String getProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext,java.lang.String,java.lang.String)>(v, "Exclude Users", "");
v = staticinvoke <java.util.regex.Pattern: java.util.regex.Pattern compile(java.lang.String)>(v);
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.regex.Pattern excludeUsers> = v;
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.nifi.registry.security.exception.SecurityProviderCreationException;
specialinvoke v.<org.apache.nifi.registry.security.exception.SecurityProviderCreationException: void <init>(java.lang.Throwable)>(v);
throw v;
label:
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: void refreshUsersAndGroups()>();
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.concurrent.ScheduledExecutorService scheduler>;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$lambda_onConfigured_0__76: java.lang.Runnable bootstrap$(org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider)>(v);
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: long fixedDelay>;
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: long fixedDelay>;
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.concurrent.ScheduledFuture scheduleWithFixedDelay(java.lang.Runnable,long,long,java.util.concurrent.TimeUnit)>(v, v, v, v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String)>("Completed configuration of ShellUserGroupProvider");
return;
catch java.lang.Exception from label to label with label;
catch java.util.regex.PatternSyntaxException from label to label with label;
}
private static org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider getCommandsProviderFromName(java.lang.String)
{
org.slf4j.Logger v, v;
org.apache.nifi.registry.security.exception.SecurityProviderCreationException v;
org.apache.nifi.registry.security.authorization.shell.OsxShellCommands v;
org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider v;
org.apache.nifi.registry.security.authorization.shell.NssShellCommands v;
java.lang.String v;
boolean v, v;
v := @parameter: java.lang.String;
if v != null goto label;
v = staticinvoke <java.lang.System: java.lang.String getProperty(java.lang.String)>("os.name");
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("Linux");
if v == 0 goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Selected Linux command set.");
v = new org.apache.nifi.registry.security.authorization.shell.NssShellCommands;
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.NssShellCommands: void <init>()>();
v = v;
goto label;
label:
v = virtualinvoke v.<java.lang.String: boolean startsWith(java.lang.String)>("Mac OS X");
if v == 0 goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>("Selected OSX command set.");
v = new org.apache.nifi.registry.security.authorization.shell.OsxShellCommands;
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.OsxShellCommands: void <init>()>();
v = v;
goto label;
label:
v = new org.apache.nifi.registry.security.exception.SecurityProviderCreationException;
specialinvoke v.<org.apache.nifi.registry.security.exception.SecurityProviderCreationException: void <init>(java.lang.String)>("Unsupported operating system.");
throw v;
label:
return v;
}
private java.lang.String getProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext, java.lang.String, java.lang.String)
{
org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext v;
java.lang.String v, v, v;
org.apache.nifi.registry.util.PropertyValue v;
boolean v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext: org.apache.nifi.registry.util.PropertyValue getProperty(java.lang.String)>(v);
if v == null goto label;
v = interfaceinvoke v.<org.apache.nifi.registry.util.PropertyValue: boolean isSet()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.nifi.registry.util.PropertyValue: java.lang.String getValue()>();
goto label;
label:
v = v;
label:
return v;
}
private long getDelayProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext, java.lang.String, java.lang.String)
{
java.lang.Object[] v, v;
long v;
byte v;
java.lang.Long v;
java.lang.String v, v, v, v, v;
boolean v;
double v;
org.apache.nifi.registry.security.exception.SecurityProviderCreationException v, v;
java.lang.IllegalArgumentException v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.concurrent.TimeUnit v;
org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext v;
org.apache.nifi.registry.util.PropertyValue v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext: org.apache.nifi.registry.util.PropertyValue getProperty(java.lang.String)>(v);
v = interfaceinvoke v.<org.apache.nifi.registry.util.PropertyValue: boolean isSet()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.nifi.registry.util.PropertyValue: java.lang.String getValue()>();
goto label;
label:
v = v;
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit MILLISECONDS>;
v = staticinvoke <org.apache.nifi.registry.util.FormatUtils: double getPreciseTimeDuration(java.lang.String,java.util.concurrent.TimeUnit)>(v, v);
v = staticinvoke <java.lang.Math: long round(double)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.nifi.registry.security.exception.SecurityProviderCreationException;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("The %s \'%s\' is not a valid time interval.", v);
specialinvoke v.<org.apache.nifi.registry.security.exception.SecurityProviderCreationException: void <init>(java.lang.String)>(v);
throw v;
label:
v = v cmp 10000L;
if v >= 0 goto label;
v = new org.apache.nifi.registry.security.exception.SecurityProviderCreationException;
v = newarray (java.lang.Object)[3];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(10000L);
v[2] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("The %s \'%s\' is below the minimum value of \'%d ms\'", v);
specialinvoke v.<org.apache.nifi.registry.security.exception.SecurityProviderCreationException: void <init>(java.lang.String)>(v);
throw v;
label:
return v;
catch java.lang.IllegalArgumentException from label to label with label;
}
private int getTimeoutProperty(org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext, java.lang.String, java.lang.String)
{
java.lang.Object[] v;
org.apache.nifi.registry.security.exception.SecurityProviderCreationException v;
long v;
java.lang.IllegalArgumentException v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.concurrent.TimeUnit v;
org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext v;
int v;
java.lang.String v, v, v, v;
org.apache.nifi.registry.util.PropertyValue v;
boolean v;
double v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext;
v := @parameter: java.lang.String;
v := @parameter: java.lang.String;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.AuthorizerConfigurationContext: org.apache.nifi.registry.util.PropertyValue getProperty(java.lang.String)>(v);
v = interfaceinvoke v.<org.apache.nifi.registry.util.PropertyValue: boolean isSet()>();
if v == 0 goto label;
v = interfaceinvoke v.<org.apache.nifi.registry.util.PropertyValue: java.lang.String getValue()>();
goto label;
label:
v = v;
label:
v = <java.util.concurrent.TimeUnit: java.util.concurrent.TimeUnit SECONDS>;
v = staticinvoke <org.apache.nifi.registry.util.FormatUtils: double getPreciseTimeDuration(java.lang.String,java.util.concurrent.TimeUnit)>(v, v);
v = staticinvoke <java.lang.Math: long round(double)>(v);
label:
goto label;
label:
v := @caughtexception;
v = new org.apache.nifi.registry.security.exception.SecurityProviderCreationException;
v = newarray (java.lang.Object)[2];
v[0] = v;
v[1] = v;
v = staticinvoke <java.lang.String: java.lang.String format(java.lang.String,java.lang.Object[])>("The %s \'%s\' is not a valid time interval.", v);
specialinvoke v.<org.apache.nifi.registry.security.exception.SecurityProviderCreationException: void <init>(java.lang.String)>(v);
throw v;
label:
v = staticinvoke <java.lang.Math: int toIntExact(long)>(v);
return v;
catch java.lang.IllegalArgumentException from label to label with label;
}
public void preDestruction() throws org.apache.nifi.registry.security.exception.SecurityProviderDestructionException
{
org.slf4j.Logger v, v;
java.lang.Exception v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
org.apache.nifi.registry.security.authorization.shell.ShellRunner v;
java.util.concurrent.ScheduledExecutorService v;
java.lang.String v, v, v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
label:
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.concurrent.ScheduledExecutorService scheduler>;
interfaceinvoke v.<java.util.concurrent.ScheduledExecutorService: java.util.List shutdownNow()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
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[])>("Error shutting down refresh scheduler: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellRunner shellRunner>;
virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellRunner: void shutdown()>();
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = virtualinvoke v.<java.lang.Exception: java.lang.String getMessage()>();
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[])>("Error shutting down ShellRunner: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void warn(java.lang.String,java.lang.Throwable)>(v, v);
label:
return;
catch java.lang.Exception from label to label with label;
catch java.lang.Exception from label to label with label;
}
public org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider getCommandsProvider()
{
org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider selectedShellCommands>;
return v;
}
public void setCommandsProvider(org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider)
{
org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider;
v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider selectedShellCommands> = v;
return;
}
private void refreshUsersAndGroups()
{
java.lang.Long v;
java.util.Map v, v, v, v, v, v, v, v, v, v, v, v, v;
boolean v, v;
java.util.Collection v, v;
java.util.List v, v;
org.apache.nifi.registry.security.authorization.shell.ShellRunner v, v;
java.lang.Throwable v, v, v;
java.util.HashMap v, v, v, v;
long v, v, v, v;
java.util.function.Function v, v;
java.util.TreeSet v, v;
int v, v;
java.lang.String v, v, v, v, v;
org.slf4j.Logger v, v, v, v, v, v, v, v;
java.io.IOException v;
org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.function.Consumer v, v;
java.util.Comparator v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
label:
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellRunner shellRunner>;
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider selectedShellCommands>;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider: java.lang.String getUsersList()>();
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellRunner: java.util.List runShell(java.lang.String,java.lang.String)>(v, "Get Users List");
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellRunner shellRunner>;
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider selectedShellCommands>;
v = interfaceinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellCommandsProvider: java.lang.String getGroupsList()>();
v = virtualinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellRunner: java.util.List runShell(java.lang.String,java.lang.String)>(v, "Get Groups List");
label:
goto label;
label:
v := @caughtexception;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (java.io.IOException)>(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[])>("refreshUsersAndGroups shell exception: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void error(java.lang.String)>(v);
return;
label:
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: void rebuildUsers(java.util.List,java.util.Map,java.util.Map,java.util.Map)>(v, v, v, v);
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: void rebuildGroups(java.util.List,java.util.Map)>(v, v);
specialinvoke v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: void reconcilePrimaryGroups(java.util.Map,java.util.Map)>(v, v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("=== Users by id...");
v = new java.util.TreeSet;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$getIdentity__79: java.util.function.Function bootstrap$()>();
v = staticinvoke <java.util.Comparator: java.util.Comparator comparing(java.util.function.Function)>(v);
specialinvoke v.<java.util.TreeSet: void <init>(java.util.Comparator)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$lambda_refreshUsersAndGroups_1__80: java.util.function.Consumer bootstrap$()>();
interfaceinvoke v.<java.util.Set: void forEach(java.util.function.Consumer)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
v = interfaceinvoke v.<java.util.Map: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("users now size: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
interfaceinvoke v.<java.util.Map: void clear()>();
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
interfaceinvoke v.<java.util.Map: void putAll(java.util.Map)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
v = interfaceinvoke v.<java.util.Map: int size()>();
v = dynamicinvoke "makeConcatWithConstants" <java.lang.String (int)>(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[])>("groups now size: \u0001");
interfaceinvoke v.<org.slf4j.Logger: void debug(java.lang.String)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = interfaceinvoke v.<org.slf4j.Logger: boolean isTraceEnabled()>();
if v == 0 goto label;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
interfaceinvoke v.<org.slf4j.Logger: void trace(java.lang.String)>("=== Groups by id...");
v = new java.util.TreeSet;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$getName__77: java.util.function.Function bootstrap$()>();
v = staticinvoke <java.util.Comparator: java.util.Comparator comparing(java.util.function.Function)>(v);
specialinvoke v.<java.util.TreeSet: void <init>(java.util.Comparator)>(v);
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
interfaceinvoke v.<java.util.Set: boolean addAll(java.util.Collection)>(v);
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$lambda_refreshUsersAndGroups_2__78: java.util.function.Consumer bootstrap$()>();
interfaceinvoke v.<java.util.Set: void forEach(java.util.function.Consumer)>(v);
label:
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = staticinvoke <java.lang.System: long currentTimeMillis()>();
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger>;
v = v - v;
v = v / 1000L;
v = staticinvoke <java.lang.Long: java.lang.Long valueOf(long)>(v);
interfaceinvoke v.<org.slf4j.Logger: void info(java.lang.String,java.lang.Object)>("Refreshed users and groups, took {} seconds", v);
return;
catch java.io.IOException from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
private void rebuildUsers(java.util.List, java.util.Map, java.util.Map, java.util.Map)
{
java.util.function.Consumer v;
java.util.List v;
java.util.Map v, v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.util.List;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$lambda_rebuildUsers_3__81: java.util.function.Consumer bootstrap$(org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider,java.util.Map,java.util.Map,java.util.Map)>(v, v, v, v);
interfaceinvoke v.<java.util.List: void forEach(java.util.function.Consumer)>(v);
return;
}
private void rebuildGroups(java.util.List, java.util.Map)
{
java.util.function.Consumer v;
java.util.List v;
java.util.Map v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.util.List;
v := @parameter: java.util.Map;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$lambda_rebuildGroups_4__82: java.util.function.Consumer bootstrap$(org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider,java.util.Map)>(v, v);
interfaceinvoke v.<java.util.List: void forEach(java.util.function.Consumer)>(v);
return;
}
private void reconcilePrimaryGroups(java.util.Map, java.util.Map)
{
java.util.Map v, v;
java.util.function.BiConsumer v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.util.Map;
v := @parameter: java.util.Map;
v = staticinvoke <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider$lambda_reconcilePrimaryGroups_5__83: java.util.function.BiConsumer bootstrap$(org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider,java.util.Map)>(v, v);
interfaceinvoke v.<java.util.Map: void forEach(java.util.function.BiConsumer)>(v);
return;
}
private java.lang.String getUserIdentifierSeed(java.lang.String)
{
java.lang.String v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.lang.String;
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[])>("\u0001-user");
return v;
}
private java.lang.String getGroupIdentifierSeed(java.lang.String)
{
java.lang.String v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v := @parameter: java.lang.String;
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[])>("\u0001-group");
return v;
}
public long getRefreshDelay()
{
long v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = v.<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: long fixedDelay>;
return v;
}
void clearCaches()
{
java.lang.Throwable v, v, v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
java.util.Map v, v, v, v, v, v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
interfaceinvoke v.<java.util.Map: void clear()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName>;
interfaceinvoke v.<java.util.Map: void clear()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
entermonitor v;
label:
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
interfaceinvoke v.<java.util.Map: void clear()>();
exitmonitor v;
label:
goto label;
label:
v := @caughtexception;
exitmonitor v;
throw v;
label:
return;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
catch java.lang.Throwable from label to label with label;
}
public int userCacheSize()
{
int v;
java.util.Map v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById>;
v = interfaceinvoke v.<java.util.Map: int size()>();
return v;
}
public int groupCacheSize()
{
int v;
java.util.Map v;
org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider v;
v := @this: org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider;
v = <org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById>;
v = interfaceinvoke v.<java.util.Map: int size()>();
return v;
}
static void <clinit>()
{
org.slf4j.Logger v;
java.util.HashMap v, v, v;
v = staticinvoke <org.slf4j.LoggerFactory: org.slf4j.Logger getLogger(java.lang.Class)>(class "Lorg/apache/nifi/registry/security/authorization/shell/ShellUserGroupProvider;");
<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: org.slf4j.Logger logger> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersById> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map usersByName> = v;
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>()>();
<org.apache.nifi.registry.security.authorization.shell.ShellUserGroupProvider: java.util.Map groupsById> = v;
return;
}
}