Simple Robot v4.10.0 Help

API权限信息

ApiPermission

在API模块中,有一个类型 ApiPermission ,它代表了一个频道服务器中、 针对一个接口(例如 /guilds/{guild_id}/members/{user_id}) 的授权信息。

可以通过 GetApiPermissionListApi 获取到指定频道中针对所有接口的授权信息, 并作为 ApiPermissions 类型返回。

ApiPermissions

ApiPermissions 是对一组 ApiPermission 的包装。 除了能够对内部的 ApiPermission 进行迭代以外,还额外提供了一些API用于判断是否包含或寻找某些授权信息。

我们以 GetGuildApi (获取频道信息详情) 为例:

// 可迭代的 apiPermissions.forEach { apiPermission -> } // 获取到对 GetGuildApi 的全部授权信息(仅匹配path、忽略method的所有API) val apiPermissionList = apiPermissions[GetGuildApi] // get(...) // 寻找对 GetGuildApi 的授权信息 val apiPermissionOrNull = apiPermissions.find(GetGuildApi) // 判断是否包含对 GetGuildApi 的授权信息 val isContains = GetGuildApi in apiPermissions // contains(...)
for (ApiPermission apiPermission : apiPermissions) { // 可迭代的 } // 获取到对 GetGuildApi (的相同path的所有API) 的全部授权信息(忽略method) var apiPermissionList = apiPermissions.get(GetGuildApi.Factory); // 寻找对 GetGuildApi 的授权信息 var apiPermissionOrNull = apiPermissions.find(GetGuildApi.Factory); // 判断是否包含对 GetGuildApi 的授权信息 var isContains = apiPermissions.contains(GetGuildApi.Factory);

ApiDescription

可以看到,这些额外的API可以将一个 API 实现的伴生对象(通常命名为 Factory) 作为参数。 实际上,它们的参数类型是 ApiDescription—— 一个用于描述API信息的类型,也是用来跟 ApiPermissions 进行配合的。

在API模块中,所有 QQGuildApi 实现的伴生对象均会实现此接口并提供此API的基本信息,以便于在 ApiPermissions 中使用。

ApiPermissionDemand

在API模块中, DemandApiPermissionApi 可以用来创建一个 API 接口权限授权链接。

此API请求成功后的返回值类型即为 ApiPermissionDemand

Last modified: 18 January 2025