mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-14 04:02:00 +01:00
Added PermissionHandler#getPermission
This commit is contained in:
parent
1b7f00f1b9
commit
7700c718aa
@ -12,8 +12,8 @@ import java.util.Objects;
|
||||
*/
|
||||
public class Permission {
|
||||
|
||||
private String permissionName;
|
||||
private NBTCompound data;
|
||||
private final String permissionName;
|
||||
private final NBTCompound data;
|
||||
|
||||
/**
|
||||
* Creates a new permission object with optional data.
|
||||
|
@ -43,7 +43,7 @@ public interface PermissionHandler {
|
||||
* Uses {@link Permission#equals(Object)} internally.
|
||||
*
|
||||
* @param permission the permission to check
|
||||
* @return true if the handler has the permission
|
||||
* @return true if the handler has the permission, false otherwise
|
||||
*/
|
||||
default boolean hasPermission(@NotNull Permission permission) {
|
||||
for (Permission permissionLoop : getAllPermissions()) {
|
||||
@ -54,22 +54,41 @@ public interface PermissionHandler {
|
||||
return false;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets the {@link Permission} with the name {@code permissionName}.
|
||||
*
|
||||
* @param permissionName the permission name
|
||||
* @return the permission from its name, null if not found
|
||||
*/
|
||||
@Nullable
|
||||
default Permission getPermission(@NotNull String permissionName) {
|
||||
for (Permission permission : getAllPermissions()) {
|
||||
// Verify permission name equality
|
||||
if (permission.getPermissionName().equals(permissionName)) {
|
||||
return permission;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gets if this handler has the permission with the name {@code permissionName} and which verify the optional
|
||||
* {@link PermissionVerifier}.
|
||||
*
|
||||
* @param permissionName the permission name
|
||||
* @param permissionVerifier the optional verifier
|
||||
* @return true if the handler has the permission
|
||||
* @param permissionVerifier the optional verifier,
|
||||
* null mean that only the permission name will be used
|
||||
* @return true if the handler has the permission, false otherwise
|
||||
*/
|
||||
default boolean hasPermission(@NotNull String permissionName, @Nullable PermissionVerifier permissionVerifier) {
|
||||
for (Permission permission : getAllPermissions()) {
|
||||
if (permission.getPermissionName().equals(permissionName)) {
|
||||
final Permission permission = getPermission(permissionName);
|
||||
|
||||
if (permission != null) {
|
||||
// Verify using the permission verifier
|
||||
return permissionVerifier != null ?
|
||||
permissionVerifier.isValid(permission.getNBTData()) :
|
||||
true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
@ -77,7 +96,7 @@ public interface PermissionHandler {
|
||||
* Gets if this handler has the permission with the name {@code permissionName}.
|
||||
*
|
||||
* @param permissionName the permission name
|
||||
* @return true if the handler has the permission
|
||||
* @return true if the handler has the permission, false otherwise
|
||||
*/
|
||||
default boolean hasPermission(@NotNull String permissionName) {
|
||||
return hasPermission(permissionName, null);
|
||||
|
Loading…
Reference in New Issue
Block a user