io.quarkus.security.identity.SecurityIdentity Maven / Gradle / Ivy
package io.quarkus.security.identity;
import java.security.Permission;
import java.security.Principal;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.CompletionStage;
import io.quarkus.security.credential.Credential;
import io.smallrye.mutiny.Uni;
/**
* Interface that represents the currently logged in user.
*
* Instances of this class will always be available for injection even if no user is currently
* logged in. In this case {@link #isAnonymous()} will return true
, and the user
* will generally not have any roles (although some implementation may assign roles to anonymous users).
*
* Implementations should be immutable.
*/
public interface SecurityIdentity {
/**
* The attribute name that is used to store the underlying user representation.
*/
String USER_ATTRIBUTE = "quarkus.user";
/**
* @return the {@link Principal} representing the current user.
*/
Principal getPrincipal();
/**
* @param clazz {@link Principal} subclass
* @return the {@link Principal} subclass representing the current user.
*/
default T getPrincipal(Class clazz) {
return clazz.cast(getPrincipal());
}
/**
* @return true
if this identity represents an anonymous (i.e. not logged in) user
*/
boolean isAnonymous();
/**
* Returns the set of all roles held by the user. These roles must be resolvable in advance for every request.
*
* Note that roles are returned on a best effort basis. To actually check if
* a user holds a role {@link #hasRole(String)} should be used instead. Some API's (e.g. JAX-RS) do not allow
* for all roles to be returned, so if the underlying user representation does not support retrieving all the roles
* this method will not always be reliable. In general all built in Quarkus security extensions should provide this,
* unless it is documented otherwise.
*
*
* This set should either be unmodifiable, or a defensive copy so attempts to change the role set do not modify
* the underlying identity.
*
* @return The set of all roles held by the user
*/
Set getRoles();
/**
* Checks if a user has a given role. These roles must be resolvable in advance for every request.
*
* If more advanced authorization support is required than can be provided by a simple role based system
* then {@link #checkPermission(Permission)} and {@link #checkPermissionBlocking(Permission)} should be used
* instead.
*
*
* @return true
if the identity has the specified role.
*/
boolean hasRole(String role);
/**
* Gets the users credential of the given type, or null
if a credential of the given type is not
* present.
*
* @param credentialType The type of the credential
* @param The type of the credential
* @return The credential
*/
T getCredential(Class credentialType);
/**
* Returns a set of all credentials owned by this user.
*
* @return a set of all credentials
*/
Set getCredentials();
/**
* Gets an attribute from the identity.
*
* These can be arbitrary, and extensions are encouraged to use name spaced attribute names in a similar
* manner to package names.
*
* The `quarkus.` namespace is reserved
*
* The root
*
* @param name The attribute name
* @param The type of the attribute
* @return The attribute value
*/
T getAttribute(String name);
/**
* @return All the request attributes
*/
Map getAttributes();
/**
* Checks if a user holds a given permissions, and if so will return true
.
*
* This method is asynchronous, as it may involve calls to a remote resource.
*
* @param permission The permission
* @return A completion stage that will resolve to true if the user has the specified permission
*/
Uni checkPermission(Permission permission);
/**
* Checks if a user holds a given permissions, and if so will return true
.
*
* This method is a blocking version of {@link #checkPermission(Permission)}. By default it will
* just wait for the {@link CompletionStage} to be complete, however it is likely that some implementations
* will want to provide a more efficient version.
*
* @param permission The permission
* @return A completion stage that will resolve to true if the user has the specified permission
*/
default boolean checkPermissionBlocking(Permission permission) {
return checkPermission(permission).await().indefinitely();
}
}