Skip to content

Commit

Permalink
fix: update doc
Browse files Browse the repository at this point in the history
  • Loading branch information
jonssonyan committed Aug 18, 2023
1 parent 3e47a7d commit 48d6ec6
Showing 1 changed file with 215 additions and 36 deletions.
251 changes: 215 additions & 36 deletions vpress/api/api.md
Original file line number Diff line number Diff line change
@@ -1,7 +1,63 @@
# API文档

## 开发前必读

1. 接口认证和鉴权

除了开放接口,其余接口必须设置请求头`Authorization`用于认证和鉴权
`Authorization`值格式为`Bearer ${Token}`
`${Token}`可通过登录接口(`/api/auth/login`)获得

2. 通用返回对象

返回示例:

```json
{
"code": 20000,
"type": "success",
"message": "",
"data": {}
}
```

参数说明:

| 参数 | 必须 | 说明 |
|------|-----|--------------------------------------------------------------------|
| code | 是 | 状态码 20000/成功 50000/系统错误 50014/登录过期 50008/认证失败 50401/未认证 50403/暂无权限 |
| type | 是 | 类型 success/成功 error/错误 warning/警告 |
| data | 是 | 返回值 |

## 开放接口

### 验证码

接口地址: `/api/auth/generateCaptcha`

请求方式: `GET`

返回示例:

```json
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"captchaId": "VeC7Raoxo33hQTrnJT8s",
"captchaImg": ""
}
}
```

参数说明:

| 参数 | 必须 | 说明 |
|------------|-----|-------|
| captchaId || 验证码id |
| captchaImg || 验证码图片 |

### 登录

接口地址: `/api/auth/login`
Expand All @@ -14,8 +70,8 @@
{
"username": "sysadmin",
"pass": "123456",
"captchaId": "123",
"captchaCode": "2"
"captchaId": "y1mAtmYe4fErHN6vcYvo",
"captchaCode": "25"
}
```

Expand All @@ -30,8 +86,23 @@

返回示例:

```json
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhY2NvdW50Vm8iOnsiaWQiOjEsInF1b3RhIjowLCJkb3dubG9hZCI6MCwidXBsb2FkIjowLCJ1c2VybmFtZSI6InN5c2FkbWluIiwiZW1haWwiOiIiLCJyb2xlSWQiOjEsImRlbGV0ZWQiOjAsInByZXNldEV4cGlyZSI6MCwicHJlc2V0UXVvdGEiOjAsImxhc3RMb2dpblRpbWUiOjAsImV4cGlyZVRpbWUiOjAsImNyZWF0ZVRpbWUiOiIwMDAxLTAxLTAxVDAwOjAwOjAwWiIsInJvbGVzIjpbInN5c2FkbWluIiwiYWRtaW4iLCJ1c2VyIl19LCJleHAiOjE2OTIzODM4MzQsImlzcyI6InRyb2phbi1wYW5lbCJ9.ymvQ_VPsCvxjNpQUPTZ3fjWTZJk-URujCt3vSI-bnw8"
}
}
```

参数说明:

| 参数 | 必须 | 说明 |
|-------|-----|---------|
| token || 授权Token |

### 注册

接口地址: `/api/auth/register`
Expand All @@ -41,65 +112,88 @@
请求示例:

```json

{
"username": "123456",
"pass": "123456",
"captchaId": "BqEEo9jEdZrmfzz8K7R9",
"captchaCode": "9"
}
```

参数说明:

| 参数 | 必须 | 说明 |
|-------------|-----|-------|
| username || 用户名 |
| pass || 密码 |
| captchaId || 验证码id |
| captchaCode || 验证码值 |

返回示例:

参数说明:
```json
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
```

### 系统默认设置

接口地址: `/api/auth/setting`

请求方式: `POST`
请求方式: `GET`

请求示例:
返回示例:

```json

{
"code": 20000,
"type": "success",
"message": "",
"data": {
"registerEnable": 1,
"registerQuota": 0,
"registerExpireDays": 0,
"trafficRankEnable": 1,
"captchaEnable": 1,
"emailEnable": 0,
"systemName": "Trojan Panel"
}
}
```

参数说明:

返回示例:

参数说明:
| 参数 | 必须 | 说明 |
|--------------------|-----|------------------|
| registerEnable || 是否开放注册 |
| registerQuota || 注册用户默认配额 单位/MB |
| registerExpireDays || 注册用户过期天数 单位/天 |
| captchaEnable || 是否开启验证码登录 |
| emailEnable || 是否开启邮箱功能 0/否 1/是 |
| systemName || 系统名称 |

### 订阅

接口地址: `/api/subscribe/:token`

请求方式: `POST`
请求方式: `GET`

请求示例:

```json

```

参数说明:

返回示例:

参数说明:

### 验证码

接口地址: `/api/generateCaptcha`

请求方式: `POST`

请求示例:

```json

/api/auth/subscribe/NUNjOWtCZHhwWGpUYXZKSjRvNF9JTFBMU3VZWmphOTB4MEpmZWVicGt1UFBHZmRT
```

参数说明:

| 参数 | 必须 | 说明 |
|-------|-----|-------|
| token || Token |

返回示例:

参数说明:
Expand Down Expand Up @@ -220,7 +314,7 @@

接口地址: `/api/account/getAccountInfo`

请求方式: `POST`
请求方式: `GET`

请求示例:

Expand All @@ -232,8 +326,31 @@

返回示例:

```json
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"id": 1,
"username": "sysadmin",
"roles": [
"sysadmin",
"admin",
"user"
]
}
}
```

参数说明:

| 参数 | 必须 | 说明 |
|----------|-----|-----|
| id || 主键 |
| username || 用户名 |
| roles || 角色 |

### 分页查询账户

接口地址: `/api/account/selectAccountPage`
Expand Down Expand Up @@ -499,33 +616,95 @@
请求示例:

```json

{
"ip": "1.cybevo.cn",
"name": "测试服务器",
"grpcPort": 8100
}
```

参数说明:

| 参数 | 必须 | 说明 |
|----------|-----|-------|
| ip || 服务器IP |
| name || 服务器名称 |
| grpcPort || API端口 |

返回示例:

参数说明:
```json
{
"code": 20000,
"type": "success",
"message": "",
"data": null
}
```

### 分页查询服务器

接口地址: `/api/nodeServer/selectNodeServerPage`

请求方式: `POST`
请求方式: `GET`

请求示例:

```json

```
/api/nodeServer/selectNodeServerPage?pageNum=1&pageSize=20&ip=trojanpanel.github.io&name=测试服务器
```

参数说明:

| 参数 | 必须 | 说明 |
|----------|-----|-------|
| pageNum || 页号 |
| pageSize || 页大小 |
| ip || 服务器IP |
| name || 服务器名称 |

返回示例:

```json
{
"code": 20000,
"type": "success",
"message": "",
"data": {
"nodeServers": [
{
"id": 1,
"name": "测试服务器",
"ip": "1.cybevo.cn",
"grpcPort": 8100,
"createTime": "2023-08-19T01:24:22+08:00",
"status": 1,
"trojanPanelCoreVersion": "v2.1.2"
}
],
"pageNum": 1,
"pageSize": 20,
"total": 1
}
}
```

参数说明:

| 参数 | 必须 | 说明 |
|------------------------|-----|----------------------|
| nodeServers || 服务器对象 |
| id || 主键 |
| name || 服务器名称 |
| ip || 服务器名称 |
| grpcPort || API端口 |
| createTime || 创建时间 |
| status || 状态 0/异常 1/正常 |
| trojanPanelCoreVersion || Trojan Panel Core 版本 |
| pageNum || 页号 |
| pageSize || 页大小 |
| total || 总数 |

### 删除服务器

接口地址: `/api/nodeServer/deleteNodeServerById`
Expand Down

0 comments on commit 48d6ec6

Please sign in to comment.