本项目为酷 Q 的 CoolQ HTTP API 插件的 Python SDK,封装了 web server 相关的代码,让使用 Python 的开发者能方便地开发插件。仅支持 Python 3.x。
关于 CoolQ HTTP API 插件,见 richardchien/coolq-http-api。
首先安装 cqhttp
包:
pip install cqhttp
注意可能需要把 pip
换成 pip3
。本 SDK 依赖于 bottle
和 requests
包,因此它们也会被安装。
也可以 clone 本仓库之后用 python setup.py install
来安装。
目前 SDK 最新版(1.1.0+)已支持插件版本 3.0,且不再兼容旧版插件,如果你需要使用旧版插件,请安装 1.0.1 版本
pip install cqhttp==1.0.1
。
然后新建 Python 文件,运行 CQHttp 后端:
from cqhttp import CQHttp
bot = CQHttp(api_root='http://127.0.0.1:5700/',
access_token='your-token',
secret='your-secret')
@bot.on_message()
def handle_msg(context):
bot.send(context, '你好呀,下面一条是你刚刚发的:')
return {'reply': context['message'], 'at_sender': False}
@bot.on_event('group_increase')
def handle_group_increase(context):
bot.send(context, message='欢迎新人~', is_raw=True) # 发送欢迎新人
@bot.on_request('group', 'friend')
def handle_request(context):
return {'approve': True} # 同意所有加群、加好友请求
bot.run(host='127.0.0.1', port=8080)
首先创建 CQHttp
类的实例,传入 api_root
,即为酷 Q HTTP API 插件的监听地址,如果你不需要调用 API,也可以不传入。Access token 和签名密钥也在这里传入,如果没有配置 access_token
或 secret
项,则不传。
on_message
、on_event
、on_request
三个装饰器分别对应三个上报类型(post_type
),括号中指出要处理的消息类型(message_type
)、事件名(event
)、请求类型(request_type
),一次可指定多个,如果留空,则会处理所有这个上报类型的上报。上例中 handle_msg
函数将会在收到任意渠道的消息时被调用,handle_group_increase
函数会在群成员增加时调用。
上面三个装饰器装饰的函数,统一接受一个参数,即为上报的数据,具体数据内容见 事件上报;返回值可以是一个字典,会被自动作为 JSON 响应返回给 HTTP API 插件,具体见 上报请求的响应数据格式。
在设置了 api_root
的情况下,直接在 CQHttp
类的实例上就可以调用 API,例如 bot.send_private_msg(user_id=123456, message='hello')
,这里的 send_private_msg
即为 /send_private_msg
发送私聊消息 中的 /send_private_msg
,API 所需参数直接通过命名参数(keyword argument)传入。其它 API 见 API 描述。
为了简化发送消息的操作,提供了 send(context, message)
函数,这里的第一个参数 context
也就是上报数据,传入之后函数会自己判断当前需要发送到哪里(哪个好友,或哪个群),无需手动再指定,其它参数仍然可以从 keyword argument 指定,例如 auto_escape=True
。
每个 API 调用最后都会由 requests
库来发出请求,如果网络无法连接,它可能会抛出 ConnectionError
等异常,见 错误与异常。而一旦请求成功,本 SDK 会判断 HTTP 响应状态码,只有当状态码为 200,且 status
字段为 ok
或 async
时,会返回 data
字段的内容,否则抛出 cqhttp.Error
异常,在这个异常中你可以通过 status_code
和 retcode
属性来获取 HTTP 状态码和插件的 retcode
(如果状态码不为 200,则 retcode
为 None),具体响应状态码和 retcode
的含义,见 响应说明。
使用装饰器定义好处理函数之后,调用 bot.run()
即可运行。你需要传入 host
和 port
参数,来指定服务端需要运行在哪个地址,然后在 HTTP API 插件的配置文件中,在 post_url
项中配置此地址(http://host:port/
)。
本 SDK 的代码非常简单,如果发现有问题可以参考下源码,可以自行做一些修复,也欢迎提交 pull request 或 issue。