频道角色 QGRole
QQ频道中有一些针对 角色 的API。
API中的角色
在API模块中存在一些用来获取 Role 的API。
比如你可以通过 GetGuildRoleListApi 获取一个频道服务器中的角色列表。
组件库中的角色
在组件库模块中, QGRole 实现了simbot标准API中的 Role, 并提供了一些高级功能的封装。
QGRole的类型
QGRole 有两个子类型,用于在不同的场景下描述角色信息:
类型 | 描述 |
|---|---|
| 表示一个频道服务器中的角色 |
| 表示某个频道成员拥有的角色 |
根据不同的类型,部分API会产生的效果也不同。
获取QGRole
在 QGGuild 中,你可以通过属性 roles 获取到频道服务器中定义的所有 QGGuildRole。
在 QGMember 中,你可以通过属性 roles 获取这个成员所拥有的所有 QGMemberRole。
在 QGMemberRole 中,会额外提供一些属性来获取到它所属的成员ID和对应的 QGGuildRole 实例本身。
创建QGRole
创建QGGuildRole
在 QGGuild 中提供了一个API roleCreator 可以创建一个用于新建 QGGuildRole 的构建器。 前往 创建角色 参考代码示例。
创建QGMemberRole
实际上 QGMemberRole 作为一个"频道成员拥有的角色",与其说创建, 不如说是 "赋予":"赋予"一个角色给成员,并由此诞生 QGMemberRole。
想要赋予给用户一个角色,首先你得先拥有一个 QGGuildRole。 QGGuildRole 中提供了用于赋予角色的 API grantTo(...)。
赋予需要一个参数来代表目标成员,它可以是 QGMember、 Member 或 ID, 它们的可靠性依次递减 (类型越宽泛,越可能存在类型校验等异常)。
下面的示例中会以 QGGuildRole 和 QGMember 为例。
删除角色/移除角色授权
QGGuildRole 和 QGMemberRole 各自实现了 DeleteSupport ,因此它们支持 delete 操作。 根据它们的类型, delete 具有不同的含义:
类型 | 含义 |
|---|---|
| 删除这个频道中的角色 |
| 取消这个成员的角色(移除权限) |