chronocat/packages/shell/static/openapi.yaml

412 lines
11 KiB
YAML
Raw Normal View History

2024-03-03 18:06:09 +00:00
openapi: 3.1.0
info:
title: Chronocat Satori
2024-03-10 13:04:15 +00:00
version: 0.2.0
2024-03-03 18:06:09 +00:00
description: |
# Chronocat Satori OpenAPI 定义
这是一份 Chronocat Satori OpenAPI 的完整定义文件。
任何时候,你都可以从 <https://chronocat.vercel.app/openapi.yaml> 获取到此文件。
contact:
name: Team Chrononeko
url: https://github.com/chrononeko
license:
name: AGPL-3.0
url: https://www.gnu.org/licenses/agpl-3.0.html
externalDocs:
description: Chronocat 文档
url: https://chronocat.vercel.app
servers:
- url: '{protocol}://{host}:{port}/{version}'
description: Chronocat Satori 服务
variables:
protocol:
default: http
host:
default: localhost
port:
default: '5500'
version:
default: v1
tags:
- name: Channel
description: 「频道」——消息的集合。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
2024-03-19 15:48:50 +00:00
# - name: ChannelMember
# description: 「频道成员」——用户在特定频道内的信息。
# externalDocs:
# description: 概念介绍
# url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
2024-03-03 18:06:09 +00:00
- name: Guild
description: 「群组」——用户的集合。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
- name: GuildMember
description: 「群组成员」——用户在特定群组内的信息。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
- name: GuildRole
description: 「群组角色」——用户在群组内的角色或权限。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
- name: Login
description: 「登录信息」——实现侧当前的状态。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
- name: Message
description: 「消息」——频道中发送的内容。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
- name: Reaction
description: 「表态」——用户对消息的回应。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
- name: User
description: 「用户」——群组内的个体。
externalDocs:
description: 概念介绍
url: https://chronocat.vercel.app/develop/satori/fundamentals/resources
security:
- satori: []
paths:
/:
get:
summary: Satori 欢迎页
description: 展示 Satori 欢迎页面。无任何实际用途。
responses:
'200':
description: 成功返回 Satori 欢迎页
content:
text/html:
schema:
type: string
const: <html>Satori 欢迎页的 HTML 内容)</html>
security:
- {}
/assets/{assetData}:
get:
operationId: assets
summary: 获取单个资源
description: |
获取单个资源。该 URL 通常为 Satori 服务生成并在事件携带的消息元素中出现。
如果客户端无法通过此链接访问到 Chronocat Satori 服务,则需修改配置文件中的 `self_url` 项。
parameters:
- name: assetData
in: path
description: 资源信息。通常为 Satori 服务生成。
required: true
schema:
type: string
responses:
'200':
description: 成功获取资源
content:
'*/*': {}
security:
- {}
/unsafe.channel.mute:
post:
operationId: channelMute
tags:
- Channel
summary: 频道全体禁言
description: 频道全体禁言。
requestBody:
description: 要全体禁言的频道
content:
application/json:
schema:
$ref: '#/components/schemas/ChannelMutePayload'
responses:
'200':
description: 禁言成功
'500':
$ref: '#/components/responses/500'
/user.channel.create:
post:
operationId: userChannelCreate
tags:
- Channel
summary: 创建私聊频道
description: 创建一个私聊频道。
requestBody:
description: 要私聊的用户
content:
application/json:
schema:
$ref: '#/components/schemas/UserPayload'
responses:
'200':
description: 成功获取创建的私聊频道
content:
application/json:
schema:
$ref: '#/components/schemas/Channel'
'500':
$ref: '#/components/responses/500'
2024-03-19 15:48:50 +00:00
# /unsafe.channel.member.mute:
# post:
# operationId: channelMemberMute
# tags:
# - ChannelMember
# summary: 频道用户禁言
# description: 频道用户禁言。
# requestBody:
# description: 要禁言的用户
# content:
# application/json:
# schema:
# $ref: '#/components/schemas/ChannelMemberMutePayload'
# responses:
# '200':
# description: 禁言成功
# '500':
# $ref: '#/components/responses/500'
2024-03-03 18:06:09 +00:00
/guild.list:
post:
operationId: guildList
tags:
- Guild
summary: 获取群组列表
description: 获取当前用户加入的全部群组。
requestBody:
description: 分页
content:
application/json:
schema:
$ref: '#/components/schemas/Next'
responses:
'200':
description: 全部群组的分页列表
content:
application/json:
schema:
type: array
items:
$ref: '#/components/schemas/GuildListResponse'
'500':
$ref: '#/components/responses/500'
/guild.approve:
post:
operationId: guildApprove
tags:
- Guild
summary: 处理群组邀请
description: 处理来自群组的邀请。
requestBody:
description: 处理邀请
content:
application/json:
schema:
$ref: '#/components/schemas/ApprovePayload'
responses:
'200':
description: 成功处理邀请
'500':
$ref: '#/components/responses/500'
/unsafe.guild.remove:
post:
operationId: guildRemove
tags:
- Guild
summary: 删除群组
description: 删除群组。
requestBody:
description: 群组
content:
application/json:
schema:
$ref: '#/components/schemas/GuildRemovePayload'
responses:
'200':
description: 成功删除群组
'500':
$ref: '#/components/responses/500'
/guild.member.list:
post:
operationId: guildMemberList
tags:
- GuildMember
summary: 获取群组成员列表
description: 获取群组成员列表。
requestBody:
description: 群组
content:
application/json:
schema:
$ref: '#/components/schemas/GuildMemberListPayload'
responses:
'200':
description: 成功获取群组成员列表
content:
application/json:
schema:
$ref: '#/components/schemas/GuildMemberListResponse'
'500':
$ref: '#/components/responses/500'
2024-03-19 15:48:50 +00:00
/guild.member.mute:
post:
operationId: guildMemberMute
tags:
- GuildMember
summary: 群组用户禁言
description: 群组用户禁言。
requestBody:
description: 用户禁言参数
content:
application/json:
schema:
$ref: '#/components/schemas/GuildMemberMutePayload'
responses:
'200':
description: 禁言成功
'500':
$ref: '#/components/responses/500'
2024-03-03 18:06:09 +00:00
/login.get:
post:
operationId: loginGet
tags:
- Login
summary: 获取登录信息
description: 获取登录信息。
responses:
'200':
description: 成功获取登录信息
content:
application/json:
schema:
$ref: '#/components/schemas/Login'
'500':
$ref: '#/components/responses/500'
/message.create:
post:
operationId: messageCreate
tags:
- Message
summary: 发送消息
description: 发送一条消息。
requestBody:
description: 发送的目标和消息内容
content:
application/json:
schema:
$ref: '#/components/schemas/MessageCreatePayload'
responses:
'200':
description: 成功发送消息
content:
application/json:
schema:
type: array
items:
$ref: '#/components/schemas/Message'
'500':
$ref: '#/components/responses/500'
/friend.list:
post:
operationId: friendList
tags:
- User
summary: 获取好友列表
description: 获取好友列表。
requestBody:
description: 分页
content:
application/json:
schema:
$ref: '#/components/schemas/Next'
responses:
'200':
description: 全部好友的分页列表
content:
application/json:
schema:
type: array
items:
$ref: '#/components/schemas/FriendListResponse'
'500':
$ref: '#/components/responses/500'
/friend.approve:
post:
operationId: friendApprove
tags:
- User
summary: 处理好友申请
description: 处理好友申请。
requestBody:
description: 处理邀请
content:
application/json:
schema:
$ref: '#/components/schemas/ApprovePayload'
responses:
'200':
description: 成功处理邀请
'500':
$ref: '#/components/responses/500'
/unsafe.friend.remove:
post:
operationId: friendRemove
tags:
- User
summary: 删除好友
description: 删除好友。
requestBody:
description: 用户
content:
application/json:
schema:
$ref: '#/components/schemas/UserPayload'
responses:
'200':
description: 成功删除好友
'500':
$ref: '#/components/responses/500'
components:
securitySchemes:
satori:
description: Satori 服务密码
type: http
scheme: bearer
in: header
bearerFormat: string
responses:
'500':
description: Chronocat 内部错误 (500)
content:
text/plain:
schema:
type: string
const: 500 internal error