API
API模块
所有的 QQ频道API 封装与实现都在 API 模块 (simbot-component-qq-guild-api) 中, 这些实现均在包路径 love.forte.simbot.qguild.api 下, 并实现接口 love.forte.simbot.qguild.api.QQGuildApi。
API定义
使用API
在 API模块、stdlib模块和核心组件模块中都可以 '使用' API。
首先何为 '使用API'? 即提供一些所需参数,对此API发起请求并得到预期的结果或错误。
API模块中使用
在API模块中直接使用API,通常需要提供如下参数:
HttpClient: 用于发起请求的 KtorHttpClient对象。token: QQ频道API中用于鉴权的客户端access_token。 它通过API定期刷新,可在Bot中获取。 如果API还支持旧格式,那么可以在官方文档中找到,比如Bot 100000.aaaabbbbccccdddd。server: 可选 。QQ频道API有正式频道和沙箱频道之分,可通过此参数选择不同的服务器地址。在一些特殊需求下,也可以通过此方式自定义一个第三方服务器地址。appId: 可选 。如果提供,会将其添加到请求头X-Union-Appid中。这是新的access_token访问方式所要求的。
对 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模块中使用 中的方式一致即可。
日志
你可以通过开启名称前缀为 love.forte.simbot.qguild.api 的 DEBUG 级别日志来查看所有API在进行请求过程的部分详细信息, 例如出入参等。
在 JVM 中,日志系统委托给了 SLF4J2 API ,在native平台中,可以通过 LoggerFactory.defaultLoggerLevel 修改全局的默认日志级别。
JVM中默认会为日志中的部分片段染色。 如果希望关闭日志中的染色,添加JVM参数: