# 流式API
通过流式API,您可以实时接收各种信息(例如,你的时间线中的新帖文,收到的消息,关注等),并进行各种操作。
## 连接到流
要使用流式API,您需要使用**websocket**连接到Misskey服务器。
请使用参数`i`连接到以下URL,并在websocket连接中包含认证信息。例如:
```
%WS_URL%/streaming?i=xxxxxxxxxxxxxxx
```
认证信息是您的API密钥,从应用程序连接到流时需要引用的用户访问令牌
---
您可以省略身份验证信息。此时无需登录即可使用,但是可以接收的信息和可以执行的操作将受到限制。例:
```
%WS_URL%/streaming
```
---
通过连接到流,您可以执行后文所示的API操作并订阅帖子。 但是此时例如时间线上的新帖子等还无法接收到。 要实现此功能,您需要连接到后文所述的流的**频道**。
**所有流交互都是JSON格式。**
## 频道
频道是Misskey的流API中的概念。这是一种分离发送和接收信息的机制。 您无法仅通过连接到Misskey流来实时接收时间线帖子。 需要通过连接到流中的频道,您才能够接收和发送各种消息。
### 连接到频道
要连接到频道,请将JSON数据发送到流:
```json
{
type: 'connect',
body: {
channel: 'xxxxxxxx',
id: 'foobar',
params: {
...
}
}
}
```
其中:
* `channel`中可以设置您要连接的频道名。频道类型将在后面说明。
* `id`设置用于与频道通信的ID。因为流中有着各种消息,因此需要确定消息来自哪个频道。该ID可以是UUID或随机数。
* `params`是连接到频道时传的参数。连接不同的频道时需要不同的参数。连接到无需参数的频道时,该属性为可选。
ID对应的是“频道的连接”,而不是频道。因为在某些情况下会使用不同的参数对同一频道进行多个连接。
### 从频道接收消息
例如,当有新帖子时,时间线的频道将发送一条消息。通过接收此消息,您可以实时知道时间线上有新帖子。
当频道发出消息时,以下数据将以JSON格式传输到流中:
```json
{
type: 'channel',
body: {
id: 'foobar',
type: 'something',
body: {
some: 'thing'
}
}
}
```
其中:
* `id`为前文所述连接到频道时所设置的ID。因此可以知道此消息来自哪个频道。
* `type`为所设的消息类型。不同的频道会有不同类型的消息。
* `body`为所设的消息内容。不同的频道中的消息内容也会有不同。
### 向频道发送消息
根据频道的不同,您不仅可以接收消息,而且还可以发送消息并执行某些操作。
要将消息发送到频道,请将JSON格式数据发送到流:
```json
{
type: 'channel',
body: {
id: 'foobar',
type: 'something',
body: {
some: 'thing'
}
}
}
```
其中:
* `id`为前文所述连接到频道时想要设置的ID。因此您可以决定此消息发送到哪个频道。
* `type`为想要设置的消息类型。不同的频道会接受不同类型的消息。
* `body`为想要设置的消息内容。不同的频道接受的消息内容也会不同。
### 断开频道连接
要断开与频道的连接,请将JSON格式数据发送到流:
```json
{
type: 'disconnect',
body: {
id: 'foobar'
}
}
```
其中:
* `id`为前文所述连接到频道时想要设置的ID。
## 通过流发送API请求
使用流的方式可以在不使用http请求的条件下来发送API请求。因此,您可以使用更简洁的代码来提高效率。
要通过流发送API请求,请将如下所示的JSON格式数据发送到流:
```json
{
type: 'api',
body: {
id: 'xxxxxxxxxxxxxxxx',
endpoint: 'notes/create',
data: {
text: 'yee haw!'
}
}
}
```
其中:
* `id`是一个唯一的ID,用来识别不同请求所对应的回应。可以使用UUID或者简单的随机数生成方法。
* `endpoint`包含请求要指定发送的API终端。
* `data`包含需要发送的终端参数。
### 接收回应
当你向API发送请求时,会受到流发送的如下格式的回应:
```json
{
type: 'api:xxxxxxxxxxxxxxxx',
body: {
...
}
}
```
其中:
* `xxxxxxxxxxxxxxxx`部分包含该请求之前设置过的`id`。因此,可以判断出回应是对应的哪个请求。
* `body`包含回应的数据。
## 帖子抓取
Misskey提供一种被称为“帖子抓取”的机制。该功能以流的形式接受指定帖子的事件。
例如,假设您获得了时间线的数据并将其显示给用户。而现在有人对时间线中的某一个帖子做出了回应。
但是,由于客户端无法知道某个帖子有回应,因此无法在时间线上的帖子中反映并实时显示出来。
为了解决此问题,Misskey引入了帖子抓取的机制。抓取帖子时,您可以接收与该帖子相关的事件,因此您可以将帖子的回应实时反映出来。
### 抓取帖子
要抓取帖子,请向流发送下列格式的消息:
```json
{
type: 'subNote',
body: {
id: 'xxxxxxxxxxxxxxxx'
}
}
```
其中:
* 请将`id`的值设置为需要抓取的帖子`id`值
发送此消息表示您已请求Misskey抓取该贴子,并且您将收到与该帖子有关的事件。
例如,如果帖子有回应,您将收到以下消息:
```json
{
type: 'noteUpdated',
body: {
id: 'xxxxxxxxxxxxxxxx',
type: 'reacted',
body: {
reaction: 'like',
userId: 'yyyyyyyyyyyyyyyy'
}
}
}
```
其中:
* `body`里的`id`用来表示触发事件的帖子的ID。
* `body`里的`type`用来表示事件类型。
* `body`里的`body`用来表示事件详细内容。
#### 事件类型
##### `reacted`
在帖子有回应时触发。
* `reaction`用来表示回应的类型。
* `userId`用来表示做出回应的用户的ID。
例:
```json
{
type: 'noteUpdated',
body: {
id: 'xxxxxxxxxxxxxxxx',
type: 'reacted',
body: {
reaction: 'like',
userId: 'yyyyyyyyyyyyyyyy'
}
}
}
```
##### `deleted`
帖子删除时触发。
* `deletedAt`表示删除的日期和时间。
例:
```json
{
type: 'noteUpdated',
body: {
id: 'xxxxxxxxxxxxxxxx',
type: 'deleted',
body: {
deletedAt: '2018-10-22T02:17:09.703Z'
}
}
}
```
##### `pollVoted`
帖子附带的问卷调查被投票时触发。
* `choice`表示选择项ID。
* `userId`表示投票的用户ID。
例:
```json
{
type: 'noteUpdated',
body: {
id: 'xxxxxxxxxxxxxxxx',
type: 'pollVoted',
body: {
choice: 2,
userId: 'yyyyyyyyyyyyyyyy'
}
}
}
```
### 取消帖子抓取
如果希望该帖子不再出现在屏幕上,并且您不再需要接收与该帖子相关的事件,可以发送取消帖子抓取的请求。
请发送以下消息:
```json
{
type: 'unsubNote',
body: {
id: 'xxxxxxxxxxxxxxxx'
}
}
```
其中:
* 请将`id`的值设置为需要取消抓取的帖子`id`值。
发送此消息后,将不再接收与该帖子相关的其他事件。
# 频道列表
## `main`
将会发送帐户的基本信息。该频道没有参数。
### 发送的事件列表
#### `renote`
当您的帖子被转发时会触发该事件。转发自己的帖子不会触发。
#### `mention`
有人提及您时会触发该事件。
#### `readAllNotifications`
这个事件表示您的所有通知都被设为已读。此事件可用于关闭“未读通知图标”等情况。
#### `meUpdated`
该事件表示您的个人信息已更新。
#### `follow`
当您关注某人时会触发该事件。
#### `unfollow`
当您取消关注某人时会触发该事件。
#### `followed`
当您被某人关注时会触发该事件。
## `homeTimeline`
首页的时间线上发布的信息将会传到这里。该频道没有参数。
### 发送的事件列表
#### `note`
当时间线有新帖子时触发此事件。
## `localTimeline`
本地的时间线上发布的信息将会传到这里。该频道没有参数。
### 发送的事件列表
#### `note`
当本地的时间线有新帖子时触发此事件。
## `hybridTimeline`
社交时间线上发布的信息将会传到这里。该频道没有参数。
### 发送的事件列表
#### `note`
当社交时间线有新帖子时触发此事件。
## `globalTimeline`
全局时间线上发布的信息将会传到这里。该频道没有参数。
### 发送的事件列表
#### `note`
全局时间线有新帖子时触发此事件。