public class org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault extends org.apache.isis.core.metamodel.facetapi.FacetAbstract implements org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacet
{
private final java.util.List evaluators;
private final org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository applicationUserRepository;
private final javax.inject.Provider queryResultsCacheProvider;
private final org.apache.isis.applib.services.user.UserService userService;
private static final java.lang.Class type()
{
return class "Lorg/apache/isis/extensions/secman/integration/facets/TenantedAuthorizationFacet;";
}
public void <init>(java.util.List, org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository, javax.inject.Provider, org.apache.isis.applib.services.user.UserService, org.apache.isis.core.metamodel.facetapi.FacetHolder)
{
java.util.List v;
javax.inject.Provider v;
java.lang.Class v;
org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault v;
org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository v;
org.apache.isis.applib.services.user.UserService v;
org.apache.isis.core.metamodel.facetapi.FacetHolder v;
v := @this: org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault;
v := @parameter: java.util.List;
v := @parameter: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository;
v := @parameter: javax.inject.Provider;
v := @parameter: org.apache.isis.applib.services.user.UserService;
v := @parameter: org.apache.isis.core.metamodel.facetapi.FacetHolder;
v = staticinvoke <org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.lang.Class type()>();
specialinvoke v.<org.apache.isis.core.metamodel.facetapi.FacetAbstract: void <init>(java.lang.Class,org.apache.isis.core.metamodel.facetapi.FacetHolder)>(v, v);
v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators> = v;
v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository applicationUserRepository> = v;
v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: javax.inject.Provider queryResultsCacheProvider> = v;
v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.applib.services.user.UserService userService> = v;
return;
}
public java.lang.String hides(org.apache.isis.core.metamodel.interactions.VisibilityContext)
{
org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault v;
java.lang.String v, v, v;
org.apache.isis.core.metamodel.interactions.VisibilityContext v;
org.apache.isis.applib.services.user.UserService v, v;
boolean v, v, v;
org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser v;
java.util.Iterator v;
org.apache.isis.core.metamodel.spec.ManagedObject v;
java.util.List v, v, v;
org.apache.isis.core.metamodel.interactions.InteractionHead v;
java.lang.Object v, v;
v := @this: org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault;
v := @parameter: org.apache.isis.core.metamodel.interactions.VisibilityContext;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators>;
if v == null goto label;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.applib.services.user.UserService userService>;
v = virtualinvoke v.<org.apache.isis.applib.services.user.UserService: boolean isCurrentUserWithSystemPrivileges()>();
if v == 0 goto label;
label:
return null;
label:
v = virtualinvoke v.<org.apache.isis.core.metamodel.interactions.VisibilityContext: org.apache.isis.core.metamodel.interactions.InteractionHead getHead()>();
v = virtualinvoke v.<org.apache.isis.core.metamodel.interactions.InteractionHead: org.apache.isis.core.metamodel.spec.ManagedObject getOwner()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.ManagedObject: java.lang.Object getPojo()>();
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.applib.services.user.UserService userService>;
v = virtualinvoke v.<org.apache.isis.applib.services.user.UserService: java.lang.String currentUserNameElseNobody()>();
v = virtualinvoke v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser findApplicationUser(java.lang.String)>(v);
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[])>("Could not locate application user for \u0001");
return v;
label:
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators>;
v = interfaceinvoke v.<java.util.List: 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 = interfaceinvoke v.<org.apache.isis.extensions.secman.applib.tenancy.spi.ApplicationTenancyEvaluator: java.lang.String hides(java.lang.Object,org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser)>(v, v);
if v == null goto label;
return v;
label:
return null;
}
public java.lang.String disables(org.apache.isis.core.metamodel.interactions.UsabilityContext)
{
org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault v;
java.lang.String v, v, v;
org.apache.isis.applib.services.user.UserService v, v;
boolean v, v, v;
org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser v;
java.util.Iterator v;
org.apache.isis.core.metamodel.spec.ManagedObject v;
java.util.List v, v, v;
org.apache.isis.core.metamodel.interactions.InteractionHead v;
java.lang.Object v, v;
org.apache.isis.core.metamodel.interactions.UsabilityContext v;
v := @this: org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault;
v := @parameter: org.apache.isis.core.metamodel.interactions.UsabilityContext;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators>;
if v == null goto label;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators>;
v = interfaceinvoke v.<java.util.List: boolean isEmpty()>();
if v != 0 goto label;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.applib.services.user.UserService userService>;
v = virtualinvoke v.<org.apache.isis.applib.services.user.UserService: boolean isCurrentUserWithSystemPrivileges()>();
if v == 0 goto label;
label:
return null;
label:
v = virtualinvoke v.<org.apache.isis.core.metamodel.interactions.UsabilityContext: org.apache.isis.core.metamodel.interactions.InteractionHead getHead()>();
v = virtualinvoke v.<org.apache.isis.core.metamodel.interactions.InteractionHead: org.apache.isis.core.metamodel.spec.ManagedObject getOwner()>();
v = interfaceinvoke v.<org.apache.isis.core.metamodel.spec.ManagedObject: java.lang.Object getPojo()>();
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.applib.services.user.UserService userService>;
v = virtualinvoke v.<org.apache.isis.applib.services.user.UserService: java.lang.String currentUserNameElseNobody()>();
v = virtualinvoke v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser findApplicationUser(java.lang.String)>(v);
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[])>("Could not locate application user for \u0001");
return v;
label:
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: java.util.List evaluators>;
v = interfaceinvoke v.<java.util.List: 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 = interfaceinvoke v.<org.apache.isis.extensions.secman.applib.tenancy.spi.ApplicationTenancyEvaluator: java.lang.String disables(java.lang.Object,org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser)>(v, v);
if v == null goto label;
return v;
label:
return null;
}
protected org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser findApplicationUser(java.lang.String)
{
java.lang.Object[] v;
javax.inject.Provider v;
java.lang.Object v, v;
java.util.concurrent.Callable v;
org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault v;
java.lang.String v;
v := @this: org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault;
v := @parameter: java.lang.String;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: javax.inject.Provider queryResultsCacheProvider>;
v = interfaceinvoke v.<javax.inject.Provider: java.lang.Object get()>();
v = staticinvoke <org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault$lambda_findApplicationUser_0__8: java.util.concurrent.Callable bootstrap$(org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault,java.lang.String)>(v, v);
v = newarray (java.lang.Object)[1];
v[0] = v;
v = virtualinvoke v.<org.apache.isis.applib.services.queryresultscache.QueryResultsCache: java.lang.Object execute(java.util.concurrent.Callable,java.lang.Class,java.lang.String,java.lang.Object[])>(v, class "Lorg/apache/isis/extensions/secman/integration/facets/TenantedAuthorizationFacetDefault;", "findApplicationUser", v);
return v;
}
protected org.apache.isis.extensions.secman.applib.user.dom.ApplicationUser findApplicationUserNoCache(java.lang.String)
{
java.util.Optional v;
java.lang.Object v;
org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault v;
java.lang.String v;
org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository v;
v := @this: org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault;
v := @parameter: java.lang.String;
v = v.<org.apache.isis.extensions.secman.integration.facets.TenantedAuthorizationFacetDefault: org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository applicationUserRepository>;
v = interfaceinvoke v.<org.apache.isis.extensions.secman.applib.user.dom.ApplicationUserRepository: java.util.Optional findByUsername(java.lang.String)>(v);
v = virtualinvoke v.<java.util.Optional: java.lang.Object orElse(java.lang.Object)>(null);
return v;
}
}