add docs folder.

Signed-off-by: chaoq <chaoq@gxtech.ltd>
This commit is contained in:
2025-09-17 15:55:45 +08:00
parent 0ca9d5011f
commit 202ebef35d
8 changed files with 4991 additions and 0 deletions

463
docs/livekit-api-docs.md Normal file
View File

@@ -0,0 +1,463 @@
# GXRTC服务器API文档
## 接口标准定义:
### 标准返回JSON 模版:
| Key | Value | 说明 |
| ---- | ----- | ---- |
| meta | {"code": 400, "message": "params face_img is required"} |
| code | 参考HTTP status code规范https://developer.mozilla.org/en-US/docs/Web/HTTP/Status |
| message | 用于客户端将提示给用户显示|
| data | {} | map KV结构key 一定为string,Value可为任意对象可理解为Golang中的map[string]interface{} |
异常返回示例:
```bash
{"meta": {"code": 400, "message": "params face_img is required"}}
```
正常返回结构体参考:
```bash
{
"meta": {
"code": 200
},
"data": {
"imgs": [
"........"
]
}
}
```
### 服务定义:
- 服务器API根路径https://meeting.cnsdt.com/api/v1
- 服务API返回值说明
- 服务端所有API Respose返回格式默认为json
- json结构
- 异常返回示例:
```json
{
"meta": {
"code": 403,
"error": "user unauthorized",
"message": "用户没有登录,不能使用"
}
}
```
- 正常返回示例:
```json
{
"meta": {
"code": 200
},
"data": {
"rooms": [
{
"sid": "RM_44AJticWDN3t",
"name": "thehome",
"empty_timeout": 300,
"departure_timeout": 20,
"creation_time": 1731684825,
"turn_password": "3b4QxehgfMm7RvjTjDI75ot22IhMgIrBFeWmSl8NUgyA",
"enabled_codecs": [
{
"mime": "audio/opus"
},
{
"mime": "audio/red"
},
{
"mime": "video/VP8"
},
{
"mime": "video/H264"
},
{
"mime": "video/VP9"
},
{
"mime": "video/AV1"
}
]
}
]
}
}
```
## API: 获取access_token
### Request:
- API Path: `/room/token`
- Method: `POST`
- Content Type: `form`
- Params:
- uid: `string` 用户ID
- room: `string` 房间ID
- Example:
```bash
curl -XPOST https://{{API_ROOT}}/api/v1/room/token -d "uid=xtqxk&room=thehome"
```
### Response:
- Example:
```json
{
"meta": {
"code": 200
},
"data": {
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE3MzE2ODg3OTgsImlzcyI6IkFQSTdaOUNQamhtdVo4eCIsIm5iZiI6MTczMTY4NTE5OCwic3ViIjoieHRxeGsiLCJ2aWRlbyI6eyJyb29tIjoidGhlaG9tZSIsInJvb21Kb2luIjp0cnVlfX0.GfNtz3u7kXQRJ3Rkg4usQOF2uDdJSrXfJmD3aewB-4M"
}
}
```
## API: 创建房间
### Request:
- API Path: `/room/`
- Method: `POST`
- Content Type: `form`
- Params:
- room: `string` 房间ID目前与名称重叠未来房间ID会由服务器指定客户端仅支持传递房间名称
- Example:
```bash
curl -XPOST https://{{API_ROOT}}/api/v1/room/ -d "room=thehome"
```
### Response:
- Example:
```json
{
"meta": {
"code": 200
},
"data": {
"sid": "RM_44AJticWDN3t",
"name": "thehome",
"empty_timeout": 300,
"departure_timeout": 20,
"creation_time": 1731684825,
"turn_password": "3b4QxehgfMm7RvjTjDI75ot22IhMgIrBFeWmSl8NUgyA",
"enabled_codecs": [
{
"mime": "audio/opus"
},
{
"mime": "audio/red"
},
{
"mime": "video/VP8"
},
{
"mime": "video/H264"
},
{
"mime": "video/VP9"
},
{
"mime": "video/AV1"
}
]
}
}
```
## API: 获取所有房间列表
### Request:
- API Path: `/room/`
- Method: `GET`
- Example:
```bash
curl -XGET https://{{API_ROOT}}/api/v1/room/
```
### Response:
```json
{
"meta": {
"code": 200
},
"data": {
"rooms": [
{
"sid": "RM_44AJticWDN3t",
"name": "thehome",
"empty_timeout": 300,
"departure_timeout": 20,
"creation_time": 1731684825,
"turn_password": "3b4QxehgfMm7RvjTjDI75ot22IhMgIrBFeWmSl8NUgyA",
"enabled_codecs": [
{
"mime": "audio/opus"
},
{
"mime": "audio/red"
},
{
"mime": "video/VP8"
},
{
"mime": "video/H264"
},
{
"mime": "video/VP9"
},
{
"mime": "video/AV1"
}
]
}
]
}
}
```
## API: 解散房间
### Request:
- API Path: `/room/{{room}}`
- Method: `DELETE`
- Params:
- room: `string` 房间ID目前与名称重叠未来房间ID会由服务器指定客户端仅支持传递房间名称
- Example:
```bash
curl -XDELETE https://{{API_ROOT}}/api/v1/room/thehome
```
### Response:
- Example:
成功返回被删除的房音详情
```json
{
"meta": {
"code": 200
},
"data": {
"sid": "RM_44AJticWDN3t",
"name": "thehome",
"empty_timeout": 300,
"departure_timeout": 20,
"creation_time": 1731684825,
"turn_password": "3b4QxehgfMm7RvjTjDI75ot22IhMgIrBFeWmSl8NUgyA",
"enabled_codecs": [
{
"mime": "audio/opus"
},
{
"mime": "audio/red"
},
{
"mime": "video/VP8"
},
{
"mime": "video/H264"
},
{
"mime": "video/VP9"
},
{
"mime": "video/AV1"
}
]
}
}
```
失败返回错误信息,如房间不存在,或没有权限等
## API: 获取房间参与者列表
### Request:
- API Path: `/room/{{room}}/participants`
- Method: `GET`
- Params:
- room: `string` 房间ID
- Example:
```bash
curl -XGET https://{{API_ROOT}}/api/v1/room/{{room}}/participants
```
### Response:
- Example:
```json
{
"meta": {
"code": 200
},
"data": {
"participants": [
{
"sid": "user1",
"name": "Alice",
"joined_at": 1731684825,
"...":"..."
},
{
"sid": "user2",
"name": "Bob",
"joined_at": 1731684830,
"...":"..."
}
]
}
}
```
- participants: `[]ParticipantInfo`, 返回[ParticipantInfo](structs.md#ParticipantInfo)列表
## API: 从房间中移除参与者
### Request:
- API Path: `/room/{{room}}/participant/{{uid}}`
- Method: `DELETE`
- Params:
- room: `string` 房间ID
- uid: `string` 用户ID
- Example:
```bash
curl -XDELETE https://{{API_ROOT}}/api/v1/room/{{room}}/participant/{{uid}}
```
### Response:
- Example:
当成功时失败时code不为200
```json
{
"meta": {
"code": 200
}
}
```
## API: 获取房间中指定用户的详情
### Request:
- API Path: `/room/{{room}}/participant/{{uid}}`
- Method: `GET`
- Params:
- room: `string` 房间ID
- uid: `string` 用户ID
- Example:
```bash
curl -XGET https://{{API_ROOT}}/api/v1/room/{{room}}/participant/{{uid}}
```
### Response:
- Example:
```json
{
"meta": {
"code": 200
},
"data": { // ParticipantInfo
"sid": "user1",
"name": "Alice",
"joined_at": 1731684825,
"...":"..."
}
}
```
- data : `ParticipantInfo`, 返回[ParticipantInfo](structs.md#ParticipantInfo)
## API: 将房间中的用户禁音/解禁
### Request:
- API Path: `/room/{{room}}/participant/{{uid}}/mute`
- Method: `POST/DELETE`, POST:禁音DELETE解禁
- Params:
- room: `string` 房间ID
- uid: `string` 用户ID
- Example:
```bash
curl -XPOST https://{{API_ROOT}}/api/v1/room/{{room}}/participant/{{uid}}/mute
```
### Response:
- Example:
当成功时失败时code不为200
```json
{
"meta": {
"code": 200
}
}
```
## API: 更新房间中的用户信息
### Request:
- API Path: `/room/{{room}}/participant/{{uid}}/info`
- Method: `POST`
- Params:
- room: `string` 房间ID
- uid: `string` 用户ID
- Form:
- attrs: `string`, json 格式的key,value结构{"nickname":"rick","gender":"male"}
- metadata: `string`, 任意格式的字符串
- Example:
```bash
curl -XPOST https://{{API_ROOT}}/api/v1/room/{{room}}/participant/{{uid}}/info -d "metadata=metadata_string&attrs=%7B%22nickname%22%3A%22rick%22%2C%22gender%22%3A%22male%22%7D"
```
### Response:
- Example:
```json
{
"meta": {
"code": 200
},
"data": { // ParticipantInfo
"sid": "user1",
"name": "Alice",
"joined_at": 1731684825,
"...":"..."
}
}
```
- data : `ParticipantInfo`, 返回[ParticipantInfo](structs.md#ParticipantInfo)
## API: 更新房间中的用户权限
### Request:
- API Path: `/room/{{room}}/participant/{{uid}}/permissions`
- Method: `POST`
- Params:
- room: `string` 房间ID
- uid: `string` 用户ID
- Form:
- permission: `string`, json 格式的key,value结构permission结构体参考[permission](structs.md#participantpermission)
- Example:
```bash
curl -XPOST https://{{API_ROOT}}/api/v1/room/{{room}}/participant/{{uid}}/info -d "permission="%7B%22can_subscribe%22%3Atrue%2C%22can_publish%22%3Afalse%7D""
```
### Response:
- Example:
```json
{
"meta": {
"code": 200
},
"data": { // ParticipantInfo
"sid": "user1",
"name": "Alice",
"joined_at": 1731684825,
"...":"..."
}
}
```
- data : `ParticipantInfo`, 返回[ParticipantInfo](structs.md#ParticipantInfo)