endstone.permissions
Classes:
| Name | Description |
|---|---|
Permissible | Represents an object that may become a server operator and can be assigned permissions. |
Permission | Represents a unique permission that may be attached to a Permissible |
PermissionAttachment | Holds information about a permission attachment on a Permissible object |
PermissionAttachmentInfo | Holds information on a permission and which PermissionAttachment provides it |
PermissionDefault | Represents the possible default values for permissions |
PermissionLevel |
Permissible
Represents an object that may become a server operator and can be assigned permissions.
Methods:
| Name | Description |
|---|---|
add_attachment | Adds a new PermissionAttachment. |
has_permission | Checks if a permissions is available by name. Checks if a permissions is available by permission. |
is_permission_set | Checks if a permissions is set by name. Checks if a permissions is set by permission. |
recalculate_permissions | Recalculates the permissions. |
remove_attachment | Removes a given PermissionAttachment. |
Attributes:
| Name | Type | Description |
|---|---|---|
effective_permissions | set[PermissionAttachmentInfo] | Gets effective permissions. |
permission_level | PermissionLevel | Gets the permission level of this object |
effective_permissions
effective_permissions: set[PermissionAttachmentInfo]Gets effective permissions.
permission_level
permission_level: PermissionLevelGets the permission level of this object
add_attachment
add_attachment(plugin:Plugin, name:str, value:bool) -> PermissionAttachmentAdds a new PermissionAttachment.
add_attachment(plugin:Plugin) -> PermissionAttachmentAdds a new PermissionAttachment.
has_permission
has_permission(name:str) -> boolChecks if a permissions is available by name.
has_permission(perm:Permission) -> boolChecks if a permissions is available by permission.
is_permission_set
is_permission_set(name:str) -> boolChecks if a permissions is set by name.
is_permission_set(perm:Permission) -> boolChecks if a permissions is set by permission.
recalculate_permissions
recalculate_permissions() -> NoneRecalculates the permissions.
remove_attachment
remove_attachment(attachment:PermissionAttachment) -> NoneRemoves a given PermissionAttachment.
Permission
Permission(
name: str,
description: str | None = None,
default: PermissionDefault | None = None,
children: dict[str, bool] | None = None,
*args: dict[str, bool] | None,
**kwargs: dict[str, bool] | None
)Represents a unique permission that may be attached to a Permissible
Methods:
| Name | Description |
|---|---|
add_parent | Adds this permission to the specified parent permission. |
recalculate_permissibles | Recalculates all Permissibles that contain this permission. |
Attributes:
| Name | Type | Description |
|---|---|---|
children | dict[str, bool] | Gets the children of this permission. |
default | PermissionDefault | The default value of this permission. |
description | str | The brief description of this permission |
name | str | Gets the unique fully qualified name of this Permission. |
permissibles | set[Permissible] | Gets a set containing every Permissible that has this permission. |
children
children: dict[str, bool]Gets the children of this permission.
default
default: PermissionDefaultThe default value of this permission.
description
description: strThe brief description of this permission
name
name: strGets the unique fully qualified name of this Permission.
permissibles
permissibles: set[Permissible]Gets a set containing every Permissible that has this permission.
add_parent
add_parent(name:str, value:bool) -> PermissionAdds this permission to the specified parent permission.
add_parent(perm:Permission, value:bool) -> NoneAdds this permission to the specified parent permission.
recalculate_permissibles
recalculate_permissibles() -> NoneRecalculates all Permissibles that contain this permission.
PermissionAttachment
PermissionAttachment(plugin:Plugin, permissible:Permissible)Holds information about a permission attachment on a Permissible object
Methods:
| Name | Description |
|---|---|
remove | Removes this attachment from its registered Permissible. |
set_permission | Sets a permission to the given value, by its fully qualified name. Sets a permission to the given value. |
unset_permission | Removes the specified permission from this attachment by name. Removes the specified permission from this attachment. |
Attributes:
| Name | Type | Description |
|---|---|---|
permissible | Permissible | Gets the Permissible that this is attached to. |
permissions | dict[str, bool] | Gets a copy of all set permissions and values contained within this attachment. |
plugin | Plugin | Gets the plugin responsible for this attachment. |
removal_callback | Callable[[PermissionAttachment], None] | The callback to be called when this attachment is removed. |
permissible
permissible: PermissibleGets the Permissible that this is attached to.
permissions
permissions: dict[str, bool]Gets a copy of all set permissions and values contained within this attachment.
plugin
plugin: PluginGets the plugin responsible for this attachment.
removal_callback
removal_callback: typing.Callable[[PermissionAttachment], None]The callback to be called when this attachment is removed.
remove
remove() -> boolRemoves this attachment from its registered Permissible.
set_permission
set_permission(name:str, value:bool) -> NoneSets a permission to the given value, by its fully qualified name.
set_permission(perm:Permission, value:bool) -> NoneSets a permission to the given value.
unset_permission
unset_permission(name:str) -> NoneRemoves the specified permission from this attachment by name.
unset_permission(perm:Permission) -> NoneRemoves the specified permission from this attachment.
PermissionAttachmentInfo
PermissionAttachmentInfo(
permissible: Permissible,
permission: str,
attachment: PermissionAttachment,
value: bool,
)Holds information on a permission and which PermissionAttachment provides it
Attributes:
| Name | Type | Description |
|---|---|---|
attachment | PermissionAttachment | Gets the attachment providing this permission. |
permissible | Permissible | Get the permissible this is attached to |
permission | str | Gets the permission being set |
value | bool | Gets the value of this permission |
attachment
attachment: PermissionAttachmentGets the attachment providing this permission.
permissible
permissible: PermissibleGet the permissible this is attached to
permission
permission: strGets the permission being set
value
value: boolGets the value of this permission
PermissionDefault
PermissionDefault(value:int)Represents the possible default values for permissions
Attributes:
| Name | Type | Description |
|---|---|---|
CONSOLE | PermissionDefault | |
FALSE | PermissionDefault | |
NOT_OP | PermissionDefault | |
NOT_OPERATOR | PermissionDefault | |
OP | PermissionDefault | |
OPERATOR | PermissionDefault | |
TRUE | PermissionDefault | |
name | str | |
value | int |
CONSOLE
CONSOLE: PermissionDefault FALSE
FALSE: PermissionDefault NOT_OP
NOT_OP: PermissionDefault NOT_OPERATOR
NOT_OPERATOR: PermissionDefault OP
OP: PermissionDefault OPERATOR
OPERATOR: PermissionDefault TRUE
TRUE: PermissionDefault name
name: str value
value: int PermissionLevel
PermissionLevel(value:int)Attributes:
| Name | Type | Description |
|---|---|---|
CONSOLE | PermissionLevel | |
DEFAULT | PermissionLevel | |
OP | PermissionLevel | |
OPERATOR | PermissionLevel | |
name | str | |
value | int |
CONSOLE
CONSOLE: PermissionLevel DEFAULT
DEFAULT: PermissionLevel OP
OP: PermissionLevel OPERATOR
OPERATOR: PermissionLevel name
name: str value
value: int