撤回消息
撤回消息
撤回指定消息,只有已发送成功的消息可被撤回。
默认情况下,融云对撤回消息的操作者不作限制。如需限制,可考虑以下方案:
- App 客户端自行限制撤回消息的操作者。例如,不允许 App 业务中的普通用户撤回他人发送的消息,允许 App 业务中的管 理员角色撤回他人发送的消息。
- 如需避免用户撤回非本人发送的消息,可以提交工单申请打开IMLib SDK 只允许撤回自己发送的消息。从融云服务端进行限制,禁止用户撤回非本人发送的消息。
方法
recallMessage(
message: RCIMIWMessage,
callback: IRCIMIWRecallMessageCallback
): Promise<number>;
参数说明
参数名 | 参数类型 | 描述 |
---|---|---|
message | RCIMIWMessage | 需要被撤回的消息 |
callback | IRCIMIWRecallMessageCallback | 接口调用 结果回调。 |
返回值
返回值 | 描述 |
---|---|
number | 当次接口操作的状态码。0 代表调用成功 具体结果需要实现接口回调,非 0 代表当前接口调用操作失败,不会触发接口回调,详细错误参考错误码 |
代码示例
const callback = {
onMessageRecalled: (code: number, message: RCIMIWMessage) => {
//...
},
};
let code = await engine.recallMessage(message, callback);
监听消息撤回事件
用于监听已接收的消息被撤回的事件。当接受到的某条消息被撤回时,会通过此监听器回调。
方法
setOnRemoteMessageRecalledListener(listener?: (message: RCIMIWMessage) => void): void;
参数说明
参数名 | 参数类型 | 描述 |
---|---|---|
message | RCIMIWMessage | 原本的消息会变为撤回消息 |
代码示例
engine?.setOnRemoteMessageRecalledListener((message: RCIMIWMessage) => {
//...
});