IM 即时通讯(增强版)
Web
动态与公告
IM UIKit 更新日志
NIM SDK 更新日志
新手接入指南
产品介绍
简介
产品优势
主要功能
功能介绍
账号集成与登录
基础消息功能
群组功能
聊天室功能
圈组功能
多端登录与互踢策略
海外数据中心
IM 平滑迁移方案
接口及业务限制
体验 Demo
下载 SDK 与 Demo 源码
快速开始
跑通 IM Demo 源码
实现单聊消息收发(不含 UI)
实现聊天室登录(不含 UI)
实现圈组消息收发(不含 UI)
含 UI 集成
什么是 IM UIKit
IM UIKit 功能列表
快速集成 IM UIKit
非React框架快速集成
非React框架集成 IM UIKit
非 React 框架自定义示渲染
组件导入
初始化
全局上下文
登录相关
会话列表相关
集成会话列表界面
自定义会话列表界面 UI
会话消息相关
集成会话界面
实现自定义消息收发
自定义会话界面 UI
用户资料相关
集成用户资料组件
通讯录相关
集成通讯录界面
自定义通讯录界面 UI
搜素组件相关
集成搜索组件
自定义搜索组件 UI
主题样式设置
语言设置
初始化(兼容 NIM SDK)
常见问题
如何解决样式冲突
不含 UI 集成
集成 SDK
IM 登录与初始化相关
初始化并登录 IM
注销登录与销毁实例
多端登录与互踢
消息收发
历史消息
消息扩展
最近会话
服务端会话服务
用户资料托管
好友关系托管
在线状态订阅
系统通知
群组功能
群组概述
群组管理
群成员管理
群消息管理
超大群功能
超大群概述
超大群管理
超大群成员管理
超大群消息管理
反垃圾
聊天室功能
聊天室概述
聊天室初始化与登录相关
初始化并登录聊天室
注销登录与销毁实例
聊天室标签功能
聊天室消息管理
聊天室成员管理
聊天室信息管理
聊天室队列服务
圈组功能
圈组概述
初始化与登录
通用接口校验说明
服务器相关
服务器概述
服务器管理
服务器成员管理
游客功能
服务器未读数管理
频道相关
频道概述
频道管理
频道黑白名单
频道分组
频道分组黑白名单
频道未读数管理
实时互动频道
搜索服务器与频道
身份组相关
身份组概述
身份组应用场景
服务器身份组
频道身份组
频道用户定制权限
频道分组身份组
自定义权限项
成员权限查询与判定
身份组相关查询
圈组订阅机制
圈组消息相关
圈组消息收发
圈组消息撤回
圈组消息更新
圈组消息删除
消息正在输入
获取频道最后一条消息
会话消息回复(Thread)
圈组快捷评论
圈组消息搜索
查询历史消息
查询@我的消息
圈组系统通知相关
圈组系统通知概述
圈组系统通知收发
圈组系统通知更新
圈组内容审核
圈组第三方回调
圈组相关抄送
圈组各端接口命名差异
融合存储方案
最佳实践
聊天室重要消息投递
API 参考
NIM SDK API 参考
状态码
IM 控制台指南
创建应用
注册 IM 账号
升级服务
服务协议

身份组概述

更新时间: 2023/03/14 15:18:44

身份组是拥有完善且灵活的配置机制的权限管理系统,它包含两大元素:权限组和拥有这些权限的用户。身份组适用于在不同维度(例如社区维度和房间维度)对用户进行差异化的权限管控。

身份组适用于对各类大型线上社区进行权限管控,具体场景可参见身份组应用场景

身份组类型

身份组分为两类,在ERoleType枚举内定义。

分类
API 关键字
说明

@everyone身份组

EVERYONE

  • 在用户创建圈组服务器时默认自动创建。
  • 所有圈组服务器成员默认自动成为@everyone身份组的成员。
  • @everyone身份组不可删除。
  • @everyone身份组的权限配置只有服务器创建者可修改。
  • 每一个 @everyone 身份组的权限项都会有默认值(默认开启或关闭)。如默认关闭,服务器创建者可手动开启。具体默认值请参见下文的身份组权限项
自定义身份组 CUSTOM 用户可在服务器、频道分组和频道这三个维度创建自定义身份组。
  • 服务器自定义身份组:即服务器维度的自定义身份组,其权限项对用户在服务器维度的操作进行管控。需要用户手动创建。创建后默认没有成员,需要再手动添加身份组成员。
  • 频道分组自定义身份组:即频道分组维度的自定义身份组,其权限项可对用户在频道分组维度的操作进行管控。
  • 频道自定义身份组:即频道维度的自定义身份组,其权限项可对用户在频道维度的操作进行管控。
为自定义身份组配置权限时,只有身份组创建者已拥有的权限才是可配置的,且默认开启。创建者没有的权限,在新建身份组中默认关闭,且不可修改

身份组功能概览

身份组与其他模块的联系.png

功能
说明 相关文档
服务器身份组 在服务器维度对多个用户进行权限管控,服务器可理解为社区 服务器身份组
频道分组身份组 在频道分组维度对多个用户进行权限管控 频道分组身份组
频道身份组 在频道维度对多个用户进行权限管控,频道可理解为社区中的小组或房间 频道身份组
用户定制权限 为频道成员专门定制权限(包含多个权限项),对其在频道维度的操作进行个人化的权限管控 用户定制权限
自定义权限 添加自定义权限项,实现符合应用特殊需求的权限管控能力 自定义权限
身份组相关查询 与身份组相关的查询能力,如查询身份组列表、身份组成员等 身份组相关查询
身份组资料内容审核 对身份组的资料进行内容安全审核 身份组资料内容审核

身份组权限项

身份组的权限项列表在QChatRoleAuth中定义。权限分为服务器专有的权限和非服务器专有(即在服务器维度和频道维度都可配置)。

枚举值 说明 是否服务器专有 @everyone 身份组中是否默认开启
accountInfoOther 修改他人的服务器成员信息的权限
accountInfoSelf 修改自己的服务器成员信息的权限
banServerMember 封禁其他成员访问当前服务器的权限
manageInviteApplyHistory 查看申请或邀请历史的权限,有这个权限才可以查询服务器级别的申请或邀请记录
manageInviteApply 处理加入服务器申请的权限
manageServer 管理服务器的权限,拥有该权限可修改服务器信息(包括基本属性,服务器名称、图标、成员数、邀请模式等)
inviteServer 邀请他人加入服务器的权限
kickServer 将其他成员踢出服务器的权限
deleteMsg 删除他人消息的权限
manageBlackWhiteList 管理黑白名单的权限
manageChannel 管理频道的权限,拥有该权限可创建、修改或删除频道
manageRole 管理身份组的权限,拥有该权限可创建、修改或删除身份组
recallMsg 撤回他人消息的权限
remindEveryone @所有成员的权限
remindOther @某个成员的权限
mentionedRole @身份组
sendMsg 发送消息的权限
RTCChannelCloseOtherShareScreen 在实时互动频道关闭他人屏幕共享的权限
RTCChannelConnect 在实时互动频道建立用户自己的连接的权限
RTCChannelDisconnectOther 在实时互动频道断开他人连接的权限
RTCChannelOpenCamera 在实时互动频道开启摄像头的权限
RTCChannelOpenCloseEveryoneCamera 在实时互动频道开启或关闭全员摄像头的权限
RTCChannelOpenCloseEveryoneMicrophone 在实时互动频道开启或关闭全员麦克风的权限
RTCChannelOpenCloseOtherCamera 在实时互动频道开启或关闭他人摄像头的权限
RTCChannelOpenCloseOtherMicrophone 在实时互动频道开启或关闭他人麦克风的权限
RTCChannelOpenMicrophone 在实时互动频道开启麦克风的权限
RTCChannelOpenShareScreen 在实时互动频道打开自己屏幕共享的权限

除上述身份组预定义的权限项,您还可通过云信 IM 服务端 API 创建自定义权限项,满足您的应用在自身业务场景下对于用户操作管控的特有需求。实现通过自定义权限管控用户操作的流程说明,请参见自定义权限

成员权限查询与判定

服务器成员可同时属于多个身份组,同一权限在用户所属的多个身份组中的状态(开启、关闭或继承)不同时,用户实际拥有的最终权限遵循特定的判定规则,具体请参见成员权限查询与判定。

此文档是否对你有帮助?
有帮助
我要吐槽
  • 身份组类型
  • 身份组功能概览
  • 身份组权限项
  • 成员权限查询与判定