管理群组成员

您所在的位置:网站首页 group管理 管理群组成员

管理群组成员

2023-02-22 07:46| 来源: 网络整理| 查看: 265

# 管理群组成员

群组是支持多人沟通的即时通讯系统,本文介绍如何使用环信即时通讯 IM SDK 在实时互动 app 中实现群组成员管理相关功能。

# 技术原理

环信即时通讯 IM SDK 提供 Group、IGroupManager 和 IGroupManagerDelegate 类用于群组管理,支持你通过调用 API 在项目中实现如下功能:

群组加人 群组踢人 管理群主及群管理员 管理群组黑名单 管理群组禁言 管理群组白名单 # 前提条件

开始前,请确保满足以下条件:

完成 SDK 初始化,详见 快速开始; 了解环信即时通讯 IM 的使用限制,详见 使用限制; 了解群成员角色,详见 群组概述; 了解群组和群成员的数量限制,详见 套餐包详情 (opens new window)。 # 实现方法

本节介绍如何使用环信即时通讯 IM SDK 提供的 API 实现上述功能。

# 群组加人

根据创建群组时的群组类型 (GroupStyle) 和进群邀请是否需要对方同意 (inviteNeedConfirm) 设置,群组加人的处理逻辑有差别。具体规则可以参考 创建群组。

示例代码如下:

SDKClient.Instance.GroupManager.AddGroupMembers(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 群组踢人

仅群主和群管理员可以调用 DeleteGroupMembers 方法将指定成员移出群组。被移出后,该成员收到 IGroupManagerDelegate#OnUserRemovedFromGroup 回调,其他群成员收到 IGroupManagerDelegate#OnMemberExitedFromGroup 回调。被移出群组后,该用户还可以再次加入群组。

示例代码如下:

SDKClient.Instance.GroupManager.DeleteGroupMembers(groupId, list, new CallBack ( onSuccess: () => { }, onError: (code, desc) => { } )); # 管理群主和群管理员 # 变更群主

仅群主可以调用 ChangeGroupOwner 方法将权限移交给群组中指定成员。成功移交后,原群主变为普通成员,其他群成员收到 IGroupManagerDelegate#OnOwnerChangedFromGroup 回调。

示例代码如下:

SDKClient.Instance.GroupManager.ChangeGroupOwner(groupId, newOwner, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 添加群组管理员

仅群主可以调用 AddGroupAdmin 方法添加群管理员。成功添加后,新管理员及其他管理员收到 IGroupManagerDelegate#OnAdminAddedFromGroup 回调。

管理员除了不能解散群组等少数权限外,拥有对群组的绝大部分权限。

示例代码如下:

SDKClient.Instance.GroupManager.AddGroupAdmin(groupId, adminId, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 移除群组管理员权限

仅群主可以调用 RemoveGroupAdmin 方法移除群管理员。成功移除后,被移除的管理员及其他管理员收到 IGroupManagerDelegate#OnAdminRemovedFromGroup 回调。

示例代码如下:

SDKClient.Instance.GroupManager.RemoveGroupAdmin(groupId, adminId, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 管理群组黑名单 # 将成员加入群组黑名单

仅群主和群管理员可以调用 BlockGroupMembers 方法将指定成员添加至黑名单。被加入黑名单后,该成员收到 IGroupManagerDelegate#OnUserRemovedFromGroup 回调。其他群成员会收到该成员退出群组的回调,如需该回调,请联系商务开通。被加入黑名单后,该成员无法再收发群组消息并被移出群组,黑名单中的成员如想再次加入群组,群主或群管理员必须先将其移除黑名单。

示例代码如下:

SDKClient.Instance.GroupManager.BlockGroupMembers(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 将成员移出群组黑名单

仅群主和群管理员可以调用 UnBlockGroupMembers 方法将成员移出群组黑名单。指定用户被群主或者群管理员移出群黑名单后,可以再次申请加入群组。

示例代码如下:

SDKClient.Instance.GroupManager.UnBlockGroupMembers(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 获取群组的黑名单用户列表

仅群主和群管理员可以调用 GetGroupBlockListFromServer 方法获取当前群组的黑名单。默认最多取 200 个。

示例代码如下:

SDKClient.Instance.GroupManager.GetGroupBlockListFromServer(groupId, pageNum, pageSize, callback: new ValueCallBack( onSuccess: (list) => { }, onError: (code, desc) => { } )); # 管理群组禁言 # 将成员加入群组禁言列表

仅群主和群管理员可以调用 MuteGroupMembers 方法将指定成员添加至群组禁言列表。被禁言后,该成员和其他未操作的管理员或者群主收到 IGroupManagerDelegate#OnMuteListAddedFromGroup 回调。群成员被加入群禁言列表后,不能在该群组中发言,即使被加入群白名单也不能发言。

示例代码如下:

SDKClient.Instance.GroupManager.MuteGroupMembers(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 将成员移出群组禁言列表

仅群主和群管理员可以调用 UnMuteGroupMembers 方法将指定成员移出群组禁言列表。被解除禁言后,该成员和其他未做操作的群管理员或者群主收到 IGroupManagerDelegate#OnMuteListRemovedFromGroup 回调。

示例代码如下:

SDKClient.Instance.GroupManager.UnMuteGroupMembers(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 获取群组禁言列表

仅群主和群管理员可以调用 GetGroupMuteListFromServer 方法从服务器获取当前群组的禁言列表。

示例代码如下:

SDKClient.Instance.GroupManager.GetGroupMuteListFromServer(groupId, callback: new ValueCallBack( onSuccess: (list) => { }, onError: (code, desc) => { } )); # 开启群组全员禁言

仅群主和群管理员可以调用 MuteGroupAllMembers 方法开启全员禁言。群组全员禁言开启后,除了在白名单中的群成员,其他成员不能发言。

示例代码如下:

SDKClient.Instance.GroupManager.MuteGroupAllMembers(groupId, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 关闭群组全员禁言

仅群主和群管理员可以调用 UnMuteGroupAllMembers 方法取消全员禁言,示例代码如下:

SDKClient.Instance.GroupManager.UnMuteGroupAllMembers(groupId, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 管理群组白名单 # 将成员加入群组白名单

仅群主和群管理员可以调用 AddGroupAllowList 方法将指定群成员加入群白名单。白名单用户不受全员禁言的限制,但是如果白名单用户在群禁言列表中,则该用户不能发言。

示例代码如下:

SDKClient.Instance.GroupManager.AddGroupAllowList(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 将成员移出群组白名单

仅群主和群管理员可以调用 RemoveGroupAllowList 方法将指定群成员移出群白名单。

示例代码如下:

SDKClient.Instance.GroupManager.RemoveGroupAllowList(groupId, members, new CallBack( onSuccess: () => { }, onError: (code, desc) => { } )); # 检查自己是否在白名单中

所有群成员可以调用 CheckIfInGroupAllowList 方法检查自己是否在群白名单中,示例代码如下:

public void CheckIfInGroupAllowList(final String groupId, EMValueCallBack callBack) SDKClient.Instance.GroupManager.CheckIfInGroupAllowList(groupId, new ValueCallBack( onSuccess: (ret) => { }, onError: (code, desc)=> { } )); # 获取群组白名单

仅群主和群管理员可以调用 GetGroupAllowListFromServer 方法从服务器获取当前群组的白名单。

示例代码如下:

SDKClient.Instance.GroupManager.GetGroupAllowListFromServer(currentGroupId, callback: new ValueCallBack( onSuccess: (list) => { }, onError: (code, desc) => { } )); # 监听群组事件

详见 监听群组事件。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3