Skip to content

Commit

Permalink
Add REST API of Modifying Text or Custom Message
Browse files Browse the repository at this point in the history
  • Loading branch information
haoxiuwen committed Feb 22, 2024
1 parent 33af28f commit fcd1b72
Show file tree
Hide file tree
Showing 2 changed files with 135 additions and 0 deletions.
1 change: 1 addition & 0 deletions docs/.vuepress/sidebar/document.ts
Original file line number Diff line number Diff line change
Expand Up @@ -255,6 +255,7 @@ const documentSidebar = [
{ text: '上传和下载文件', link: 'message_download.html' },
{ text: '获取历史消息记录', link: 'message_historical.html' },
{ text: '撤回消息和单向删除会话', link: 'message_recall.html' },
{ text: '修改文本或自定义消息', link: 'message_modify_text_custom.html' },
{ text: '导入消息', link: 'message_import.html' }
]
},
Expand Down
134 changes: 134 additions & 0 deletions docs/document/server-side/message_modify_text_custom.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,134 @@
# 修改文本或自定义消息

本文展示如何调用环信 IM RESTful API 在服务端修改发送成功的文本消息或自定义消息。

**调用频率**:100 次/秒/App Key

:::tip
若使用该功能,需联系商务开通。
:::

## 前提条件

要调用环信即时通讯 REST API,请确保满足以下要求:

- 已在环信即时通讯控制台 [开通配置环信即时通讯 IM 服务](enable_and_configure_IM.html)
- 了解环信 IM REST API 的调用频率限制,详见 [接口频率限制](limitationapi.html)

## 认证方式

环信即时通讯 REST API 要求 Bearer HTTP 认证。每次发送 HTTP 请求时,都必须在请求头部填入如下 `Authorization` 字段:

`Authorization: Bearer YourAppToken`

为提高项目的安全性,环信使用 Token(动态密钥)对即将登录即时通讯系统的用户进行鉴权。本文涉及的所有消息管理 REST API 都需要使用 App Token 的鉴权方式,详见 [使用 App Token 鉴权](easemob_app_token.html)

## HTTP 请求

```http
PUT https://{host}/{org_name}/{app_name}/messages/rewrite/{msg_id}
```

### 路径参数

| 参数 | 类型 | 是否必需 | 描述 |
| :--------- | :----- | :------- | :----------------------- |
| `host` | String || 环信即时通讯 IM 分配的用于访问 RESTful API 的域名。详见 [获取环信即时通讯 IM 的信息](enable_and_configure_IM.html#获取环信即时通讯-im-的信息)|
| `org_name` | String || 环信即时通讯 IM 为每个公司(组织)分配的唯一标识。详见 [获取环信即时通讯 IM 的信息](enable_and_configure_IM.html#获取环信即时通讯-im-的信息)|
| `app_name` | String || 你在环信即时通讯云控制台创建应用时填入的应用名称。详见 [获取环信即时通讯 IM 的信息](enable_and_configure_IM.html#获取环信即时通讯-im-的信息)|
| `msg_id` | String|| 要修改的消息的 ID。|

### 请求 header

| 参数 | 类型 | 是否必需 | 描述 |
| :-------------- | :----- | :------- | :-------------- |
| `Content-Type` | String || 内容类型。请填 `application/json`|
| `Accept` | String || 内容类型。请填 `application/json`|
| `Authorization` | String || App 管理员的鉴权 token,格式为 `Bearer YourAppToken`,其中 `Bearer` 为固定字符,后面为英文空格和获取到的 app token。 |

### 请求 body

| 参数 | 类型 | 是否必需 | 描述 |
| :-------------- | :----- | :------- | :--------------- |
| `user`| String || 修改消息的用户。|
| `new_msg` | JSON || 修改后的消息。|
| `new_msg.type` | String || 修改的消息类型:<br/> - `txt`:文本消息;<br/> - `custom`:自定义消息。|
| `new_msg.msg` | String || 修改后的消息内容。|
| `new_ext` | JSON || 修改后的消息扩展信息。|
| `is_combine_ext` | Boolean || 修改后的消息扩展信息与原有扩展信息是合并还是替换。<br/> - (默认)`true`:合并;<br/> - `false`:替换。|

## HTTP 响应

### 响应 body

如果返回的 HTTP 状态码为 `200`,表示请求成功,响应 body 包含如下字段:

| 参数 | 类型 | 描述 |
| :---------------- | :----- | :------------------------------- |
| `path` | String | 请求路径,属于请求 URL 的一部分,开发者无需关注。 |
| `uri` | String | 请求 URL。 |
| `timestamp` | Long | HTTP 响应的 Unix 时间戳,单位为毫秒。 |
| `organization` | String | 环信即时通讯 IM 为每个公司(组织)分配的唯一标识,与请求参数 `org_name` 相同。 |
| `application` | String | 应用在系统内的唯一标识。该标识由系统生成,开发者无需关心。 |
| `action` | String | 请求方法。 |
| `data` | String | 值为 `success`,表示消息成功修改。|
| `duration` | Int | 从发送 HTTP 请求到响应的时长,单位为毫秒。 |
| `applicationName` | String | 你在环信即时通讯云控制台创建应用时填入的应用名称,与请求参数 `app_name` 相同。 |

如果返回的 HTTP 状态码非 `200`,表示请求失败,常见的异常类型如下表所示。

| 异常类型 | HTTP 状态码 | 错误信息 | 错误描述 |
| :-------- | :----- | :------ |:----- |
| `UnsupportedMessageTypeException` | 400 | The message is of a type that is currently not supported for modification. | 不支持修改的消息类型。目前只支持修改文本消息和自定义消息。 |
| `InvalidMessageIdException` | 400 | The provided message ID is not a valid number. | 消息 ID 必须是数字。 |
| `RewriteMessageNotAuthorizedException` | 401 | You are not authorized to edit this message. | 修改的消息 ID 不属于当前app。 |
| `EditLimitExceededException` | 403 | The message has reached its edit limit and cannot be modified further. | 当前消息修改次数达到上限。目前,每条消息最多可修改 10 次。 |
| `EditFeatureNotEnabledException` | 403 | The edit message feature is not enabled for this user or system. | 消息功能未开通 |
| `MessageUnavailableException` | 404 | The message is unavailable or has expired. | 修改的消息不存在或者已经过期。 |
| `RewriteMessageInternalErrorException` | 500 | An unknown error occurred while processing the request. | 内部服务异常,修改消息失败。 |

关于其他异常,你可以参考 [响应状态码](error.html) 了解可能的原因。

## 示例

### 请求示例

```bash
# 将 <YourAppToken> 替换为你在服务端生成的 App Token

curl -X PUT -i 'https://XXXX/XXXX/XXXX/messages/rewrite/1235807318835202004' \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Bearer <YourAppToken>' \
-d '{
"user": "user1",
"new_msg": {
"type": "txt",
"msg": "update message content"
}
"new_ext": {
"key": "value",
"old_key": "new_value"
}
"is_combine_ext": true
}'
```

### 响应示例

```json
{
"path": "/messages/rewrite/1235807318835202004",
"uri": "https://XXXX/XXXX/XXXX/messages/rewrite/1235807318835202004",
"timestamp": 1705372388118,
"organization": "XXXX",
"application": "ff678832-XXXX-XXXX-8130-58ac38cb6c15",
"action": "put",
"data": "success",
"duration": 49,
"applicationName": "XXXX"
}
```



0 comments on commit fcd1b72

Please sign in to comment.