Update Permissions.md

This commit is contained in:
Karlatemp 2021-05-15 00:35:42 +08:00
parent 55281ed228
commit f8b6aebcb5
No known key found for this signature in database
GPG Key ID: 21FBDDF664FF06F8

View File

@ -1,6 +1,8 @@
# Mirai Console Backend - Permissions # Mirai Console Backend - Permissions
权限系统。 Mirai Console 权限系统。
> 优先使用 Mirai Console 权限系统管理权限是最好的选择
[`PermissionService`]: ../backend/mirai-console/src/permission/PermissionService.kt [`PermissionService`]: ../backend/mirai-console/src/permission/PermissionService.kt
[`Permission`]: ../backend/mirai-console/src/permission/Permission.kt [`Permission`]: ../backend/mirai-console/src/permission/Permission.kt
@ -25,7 +27,7 @@ interface Permission {
} }
``` ```
「权限」表示的意义是 “做一项工作的能力”。如 “执行指令 /stop”“操作数据库” 都叫作权限。 「权限」表示的意义是 “做一项工作的能力”。如 “执行指令 /stop”“操作数据库” 都叫作权限。
[`Permission`] 对象由 Console 内置或者由特定权限插件实现。其他插件不能实现 [`Permission`] 接口,只能从 `PermissionService` 注册并获取。 [`Permission`] 对象由 Console 内置或者由特定权限插件实现。其他插件不能实现 [`Permission`] 接口,只能从 `PermissionService` 注册并获取。
@ -40,11 +42,13 @@ data class PermissionId(
[`PermissionId`] 是 [`Permission`] 的唯一标识符。知道 [`PermissionId`] 就可以获取到对应的 [`Permission`]。 [`PermissionId`] 是 [`Permission`] 的唯一标识符。知道 [`PermissionId`] 就可以获取到对应的 [`Permission`]。
字符串表示为 "$namespace:$name",如 "console:command.stop", "\*:\*" 字符串表示为 `$namespace:$name`,如 `console:command.stop`, `*:*`
> 一般情况下使用位于插件对象(`JvmPlugin`) 的 `permissionId` 为插件分配一个 [`PermissionId`]
#### 命名空间 #### 命名空间
命名空间(“namespace”)用于限定权限的创建者,避免冲突。 命名空间(`namespace`)用于限定权限的创建者,避免冲突。
一些常见命名空间: 一些常见命名空间:
@ -68,7 +72,7 @@ data class PermissionId(
#### 根权限 #### 根权限
[`RootPermission`] 是所有权限的父权限。其 ID 为 "\*:\*" [`RootPermission`] 是所有权限的父权限。其 ID 为 `*:*`
## 被许可人 ## 被许可人
@ -108,6 +112,8 @@ interface PermitteeId {
在 [`AbstractPermitteeId`] 查看其子类。 在 [`AbstractPermitteeId`] 查看其子类。
**注意**: 对应 [权限服务][`PermissionService`] 没明确说明可以自行实现时, 不要轻易实现 [`PermitteeId`]
#### 字符串表示 #### 字符串表示
当使用 `PermitteeId.asString` 时, 不同的类型的返回值如下表所示. 这些格式也适用于 [权限指令](#使用内置权限服务指令). 当使用 `PermitteeId.asString` 时, 不同的类型的返回值如下表所示. 这些格式也适用于 [权限指令](#使用内置权限服务指令).
@ -139,7 +145,15 @@ interface PermitteeId {
## 权限服务 ## 权限服务
[`PermissionService`] 承载权限的授权和管理。Console 内置一个实现,而权限服务可以由插件提供(见 [扩展](Extensions.md))。 [`PermissionService`] 承载权限的授权和管理。 Console 的权限系统完全由 [`PermissionService`] 提供支持。
权限服务可以由插件提供(见 [扩展](Extensions.md))。
在没有任何提供权限服务的插件时会使用 Console 内置实现。
在整个运行时 Console 只会使用同一个权限服务,如果安装多个提供权限服务的插件很有可能导致崩溃。
> 如果运行于 JVM,
> 推荐使用 [Karlatemp/LuckPerms-Mirai](https://github.com/Karlatemp/LuckPerms-Mirai)
> 以得到更好的使用体验 (支持权限组, 权限检查状态 verbose 等)
### 判断权限 ### 判断权限
@ -156,13 +170,19 @@ fun Permission.testPermission(PermitteeId): Boolean
在 Java请查看 [`PermissionService`] 中的伴生对象。 在 Java请查看 [`PermissionService`] 中的伴生对象。
> 查看使用示例: [Him188/mirai-console-example-plugin](https://github.com/Him188/mirai-console-example-plugin/blob/master/src/main/kotlin/org/example/my/plugin/MyPluginMain.kt#L116)
### 注册权限 ### 注册权限
每一条指令都会默认自动创建一个权限。 每一条指令都会默认自动创建一个权限。
如果希望手动注册一个其他用途的权限,使用 `PermissionService.register` 如果希望手动注册一个其他用途的权限,使用 `PermissionService.register`
**注意**:权限只能在插件 [启用](Plugins.md#启用) 之后才能注册。否则会得到一个异常。 **注意**
- 权限只能在插件 [启用](Plugins.md#启用) 之后才能注册。否则会得到一个异常。
- 使用 `PermissionService.register` 时对于同一个 [`PermissionId`] 只能注册一次, 如果多次注册会得到一个异常
### 使用内置权限服务指令 ### 使用内置权限服务指令