io.bdeploy.common.security.ScopedPermission Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of api Show documentation
Show all versions of api Show documentation
Public API including dependencies, ready to be used for integrations and plugins.
package io.bdeploy.common.security;
import javax.annotation.Generated;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonProperty;
/**
* Describes access rights to a given resource. Access rights can either be global or restricted (=scoped) to a given
* resource. Global permissions take precedence over scoped permissions. Thus a user having global read permissions is allowed to
* access any scoped resource with READ permissions. In contrast to that a user that has scoped READ permissions is not able to
* access a resource requiring global read permissions.
*/
public final class ScopedPermission {
/**
* Available permissions. Permissions are inclusive meaning that higher permissions
* include the lower ones. Thus a given resource must only define the lowest required
* permission and not multiple ones.
*/
public enum Permission {
/**
* Permission for users allowed to *only* see/download clients.
*/
CLIENT(1),
/**
* The resource can be viewed but not modified.
*/
READ(2),
/**
* The resource can be modified. Includes READ permissions.
*/
WRITE(3),
/**
* New resources can be created and existing ones can be deleted.
* Includes WRITE and READ permissions.
*/
ADMIN(4);
int level;
/**
* Creates a new permission with the given level. Higher level means higher permissions.
*/
Permission(int level) {
this.level = level;
}
}
public final String scope;
public final ScopedPermission.Permission permission;
/**
* Creates a new global permission.
*
* @param permission the permission
*/
public ScopedPermission(ScopedPermission.Permission permission) {
this(null, permission);
}
/**
* Creates a new scoped permission allowing access to a particular resource.
*
* @param scope the scope of the resource
* @param permission the permission
*/
@JsonCreator
public ScopedPermission(@JsonProperty("scope") String scope,
@JsonProperty("permission") ScopedPermission.Permission permission) {
this.scope = scope;
this.permission = permission;
}
@Override
public String toString() {
if (scope == null) {
return permission.name() + " (<>)";
}
return permission.name() + " (" + scope + ")";
}
@Generated("Eclipse")
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((permission == null) ? 0 : permission.hashCode());
result = prime * result + ((scope == null) ? 0 : scope.hashCode());
return result;
}
@Generated("Eclipse")
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
ScopedPermission other = (ScopedPermission) obj;
if (permission != other.permission) {
return false;
}
if (scope == null) {
if (other.scope != null) {
return false;
}
} else if (!scope.equals(other.scope)) {
return false;
}
return true;
}
/**
* Returns whether or not this is a global scoped permission
*/
public boolean isGlobal() {
return scope == null;
}
/**
* Checks whether or not this permission satisfies the given one. Permissions are inclusive and ADMIN is the highest one.
* The ADMIN permission implicitly grants WRITE and READ and the WRITE permission
* implicitly grants READ permission.
*
*
* - If this token is a global one then the scoped of the other one is ignored.
* Just the permission without the scoped is checked.
* - If this token is a scoped one and the other one is a global then always {@code false} will be returned.
* - If both are scoped permissions then the scope must match. If so the permission will be compared.
*
*
* @param other
* the permission to check
* @return {@code true} if this permission satisfies the other one and {@code false} otherwise
*/
public boolean satisfies(ScopedPermission other) {
// If this is a global token the scope can be ignored
// We just need to verify that we have the requested permission
if (isGlobal()) {
return comparePermission(other.permission) >= 0;
}
// If the other one is a global token access is not possible
if (other.isGlobal()) {
return false;
}
// When both are scoped they must be equal
if (!scope.equals(other.scope)) {
return false;
}
// Same scope, compare permissions
return comparePermission(other.permission) >= 0;
}
/**
* Compares this permission with the other one.
*
* @param other the other permission
* @return -1 if the this permission provides lower a permission level than the other one, 0 if the permissions are equal and
* 1 if
* this permission provides a higher permission level
*/
private int comparePermission(Permission other) {
return Integer.compare(permission.level, other.level);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy