Simple Robot v4.10.0 Help

Bot配置文件

{ "component": "simbot.telegram", "ticket": { // 你的*完整的*Bot Token, 别忘了前面的'bot' "token": "bot123456789:aaaabbbbcccc" }, // 一些可选地属性,config以及里面的属性都是可选的,且基本上默认为 `null`。 "config": { "server": null, "proxy": null, "longPolling": null } }

如果你希望通过长轮询的方式达成主动 订阅 事件的效果, 记得配置 longPolling.

{ "component": "simbot.telegram", "ticket": { // 你的*完整的*Bot Token, 别忘了前面的'bot' "token": "bot123456789:aaaabbbbcccc" }, // 一些可选地属性,config以及里面的属性都是可选的,且基本上默认为 `null`。 "config": { "server": null, "proxy": { "type": "http", "url": "http://localhost:7790" }, //配置长轮询来'订阅'事件 "longPolling": { // 长轮询内部的每次事件接收量上限 "limit": 100 } } }

属性描述

component

固定值 simbot.telegram必填 ,代表此配置文件为Telegram组件的。

ticket

bot的票据信息,是进行API请求的凭证,必填。

{ "ticket": { "token": "bot123456789:aaaabbbbcccc" } }
token

你的 完整的 Bot Token, 别忘了前面的 bot

config

其他可选配置。大部分属性和其本身都是可选的。

{ "config": null }
{ "config": {} }
server

String 类型,API请求时使用的服务器地址。

默认为 https://api.telegram.org, 也就是 Telegram 的官方API地址。

{ "config": { "server": null } }
proxy

ProxyConfiguration ,代理配置。

如果不为 null ,会为内部使用的 HttpClient 配置代理。 根据 type 值的不同有不同的可配置项。

type='http'

http代理,使用 url 配置代理地址。

{ "config": { "proxy": { "type": "http", "url": "http://127.0.0.1:7790" } } }
type='socks'

socks代理,使用 hostport 配置代理地址。

{ "config": { "proxy": { "type": "socks", "host": "127.0.0.1", "port": 7790 } } }
longPolling

Telegram 的 长轮询 配置。

配置 longPolling 可以主动拉取事件,以达到类似于 “事件订阅” 的效果。

{ "config": { "longPolling": null } }
{ "config": { "longPolling": { "limit": 100, "timeout": 1800, "allowedUpdates": null, "retry": null } } }

默认为 null ,即不进行长轮询。

limit

每次轮询拉取的最大事件数量。默认为 null, 使用 API 服务器的默认值 100

{ "config": { "longPolling": { "limit": 100, } } }
timeout

每次长轮询的超时时间,单位秒。默认 1800 ,即30分钟。

{ "config": { "longPolling": { "timeout": 1800, } } }
allowedUpdates

拉取的时间类型,字符串数组,默认为 null。 为 null 时拉取所有类型的事件。

{ "config": { "longPolling": { "allowedUpdates": ["message", "edited_channel_post"], } } }
retry

LongPolling.Retry 类型,为 HttpClient 配置重试。

handleRetry 不同, retry 是基于 Ktor 的 HttpRequestRetry 插件实现的,发生在 HttpClient 内部。

所有属性不可为 null ,但均可选,不配置则使用默认值。

maxRetries

最大重试次数,默认3

delayMillis

重试间隔,毫秒。默认5000

isDelayMillisMultiplyByRetryTimes

重试间隔是否递增。默认 false

{ "config": { "longPolling": { "retry": { "maxRetries": 3 "delayMillis":5000 "isDelayMillisMultiplyByRetryTimes": false } } } }
handleRetry

LongPolling.HandleRetry, 类型,当拉取事件过程中产生异常时候的重试策略。

retry 不同, handleRetry 是对一次整个API请求(长轮询) 的过程进行异常捕获,并根据策略 strategy 来决定是否继续尝试轮询。

此配置及其属性不可为 null ,但可选,不配置则使用默认值。 默认使用策略 TIMEOUT_ONLY ,即只有出现了 io.ktor.client.plugins.HttpRequestTimeoutException 才会忽略异常重新拉取。

strategy

LongPolling.HandleRetryStrategy 枚举类型,可选值:

NONE

遇到任何错误都会抛出异常、终止bot。

TIMEOUT_ONLY

如果遇到 io.ktor.client.plugins.HttpRequestTimeoutException 则重新拉取,否则抛出异常、终止bot。

ALL

遇到任何异常 (除了 kotlinx.coroutines.CancellationException) 都会继续重试。

delayMillis

每次重试之间等待的时间,单位毫秒,默认为 5000

{ "config": { "longPolling": { "handleRetry": { "strategy": "TIMEOUT_ONLY", "delayMillis": 5000 } } } }
Last modified: 18 January 2025