有奖捉虫:云通信与企业服务文档专题,速来> HOT

功能说明

App 后台可以通过该回调实时查看群成员拉其他用户入群的请求,包括:App 后台可以拦截群成员直接将其他用户拉入群的请求。

注意事项

要启用回调,必须配置回调 URL,并打开本条回调协议对应的开关,配置方法详见 第三方回调配置 文档。
回调的方向是即时通信 IM 后台向 App 后台发起 HTTP POST 请求。
App 后台在收到回调请求之后,务必校验请求 URL 中的参数 SDKAppID 是否是自己的 SDKAppID。
其他安全相关事宜请参考 第三方回调简介:安全考虑 文档。

可能触发该回调的场景

App 用户通过客户端发起将其他用户拉入群的请求。
App 管理员通过 REST API 添加用户到群组。

回调发生时机

即时通信 IM 后台将目标用户加入群组之前(如果存在关系链托管,且 App 在即时通信 IM 中配置了好友关系校验,则回调发生在好友关系校验通过之后)。

接口说明

请求 URL 示例

以下示例中 App 配置的回调 URL 为 https://www.example.com示例:
https://www.example.com?SdkAppid=$SDKAppID&CallbackCommand=$CallbackCommand&contenttype=json&ClientIP=$ClientIP&OptPlatform=$OptPlatform

请求参数说明

参数
说明
https
请求协议为 HTTPS,请求方式为 POST
www.example.com
回调 URL
SdkAppid
创建应用时在即时通信 IM 控制台分配的 SDKAppID
CallbackCommand
固定为 Group.CallbackBeforeInviteJoinGroup
contenttype
固定值为 JSON
ClientIP
客户端 IP,格式如:127.0.0.1
OptPlatform
客户端平台,取值参见 第三方回调简介:回调协议 中 OptPlatform 的参数含义

请求包示例

{
"CallbackCommand": "Group.CallbackBeforeInviteJoinGroup",
"GroupId": "@TGS#2J4SZEAEL",
"Type": "Public",
"Operator_Account": "leckie",
"DestinationMembers": [
{
"Member_Account": "jared"
},
{
"Member_Account": "leckie"
}
],
"EventTime": 1670574414123//毫秒级别,事件触发时间戳
}

请求包字段说明

字段
类型
说明
CallbackCommand
String
回调命令
GroupId
String
要将其他用户拉入的群组 ID
Type
String
请求创建的 群组类型介绍,例如 Public
Operator_Account
String
请求的操作者 UserID
DestinationMembers
Array
要拉入群组的 UserID 集合
EventTime
Integer
事件触发的毫秒级别时间戳

应答包示例

允许所有用户入群

App 后台同意所有请求中所有用户加入群。
{
"ActionStatus": "OK",
"ErrorInfo": "",
"ErrorCode": 0 // 表示允许继续处理加群请求
}

拦截部分成员入群

App 后台拒绝请求中的某些用户被拉入群,在 RefusedMembers_Account 中返回这些 Identifier。
{
"ActionStatus": "OK",
"ErrorInfo": "",
"ErrorCode": 0,
"RefusedMembers_Account": [ // 拒绝加入的用户列表
"jared"
]
}

应答包字段说明

字段
类型
属性
说明
ActionStatus
String
必填
请求处理的结果,OK 表示处理成功,FAIL 表示失败
ErrorCode
Integer
必填
错误码,0表示允许继续处理加群请求;1表示拒绝该请求。若业务希望使用指定错误码拒绝用户进群,将错误码 ErrorCode 和 ErrorInfo 传递至客户端,请将错误码 ErrorCode 设置在 [10100, 10200] 区间内
ErrorInfo
String
必填
错误信息
RefusedMembers_Account
Array
选填
拒绝加入的用户 ID 集合

参考