API
公告
站点迁移啦~!
为什么迁移?
作为由我们官方维护的组件库,分散在各自的文档站点中的确有好处:它们可以各自维护自己所需的东西、互不干扰。
但是缺点也很明显: 太过分散。
组件库与核心库之间的关系是比较紧密的, 我们希望你能够在一个站点内就可以查阅或搜索到所有你想要得知的信息。
API模块
所有的 QQ频道API 封装与实现都在 API 模块中, 这些实现均在包路径 love.forte.simbot.qguild.api
下, 并实现接口 love.forte.simbot.qguild.api.QQGuildApi
。
你可以前往 API模块 了解 API 模块的概述。
API定义
使用API
在 API模块、stdlib模块和核心组件模块中都可以 '使用' API。
首先何为 '使用API'? 即提供一些所需参数,对此API发起请求并得到预期的结果或错误。
API模块中使用
在API模块中直接使用API,通常需要提供如下参数:
HttpClient
: 用于发起请求的 KtorHttpClient
对象。token
: QQ频道API中用于鉴权的客户端token。可以在它们文档中找到,比如Bot 100000.aaaabbbbccccdddd
。server
: 可选 。QQ频道API有正式频道和沙箱频道之分,可通过此参数选择不同的服务器地址。在一些特殊需求下,也可以通过此方式自定义一个第三方服务器地址。
对 API 的请求是以扩展函数提供的(Java 中可以使用 ApiRequests
提供的静态方法):
request
: 直接返回原始的HttpResponse
结果,几乎不做校验requestText
: 返回请求到的原始JSON字符串,会校验HTTP响应状态是否为2xx
。requestData
: 会解析响应值为对应的实体对象后返回。会校验是否成功。
以 GetGuildApi
(获取频道服务器详情) 为例:
Stdlib模块中使用
在stdlib模块下,一个 Bot
类型中已经包括了上面我们提到的那些必要信息, 因此你可以使用 Bot.requestXxx(api)
或 api.requestXxxBy(bot)
来简化你的请求 (Java中可以使用 BotRequests
提供的静态方法)。
核心模块中使用
核心模块提供的 QGBot
可以直接使用属性 source
获取到stdlib模块中的 Bot
, 因此获取后如同 Stdlib模块中使用 中的方式一致即可。