9.6 KiB
Python ChatOps 库: Opsdroid 和 Errbot
这篇文章由笔者和 Lacey Williams Henschel 共同编写。
ChatOps 是基于会话导向而进行的开发。它的想法是你可以编写能够对聊天窗口中的某些输入进行回复的可执行代码。作为一个开发者,你能够用 ChatOps 从 Slack 合并拉取请求,自动从收到的 Facebook 消息中给某人分配支持票或者通过 IRC 检查开发状态。
在 Python 世界,最为广泛使用的 ChatOps 库是 Opsdroid 和 Errbot。在这个月的 Python 专栏,让我们一起聊聊使用它们是怎样的体验,它们各自适用于什么方面以及如何着手使用它们。
Opsdroid
Opsdroid 是一个相对年轻的(始于 2016)Python 开源聊天机器人库。它有着良好的开发文档,不错的教程并且包含能够帮助你对接流行的聊天服务的插件。
它内建了什么
库本身并没有自带所有你需要上手的东西,但这是故意的。轻量级的框架鼓励你去运用它现存的连接器(Opsdroid 所谓的帮你接入聊天服务的插件)或者去编写你自己的,但是它并不会因自带你所不需要的的连接器而自贬身价。你可以轻松使用现有的 Opsdroid 连接器来接入:
- 命令行
- Cisco Spark
- GitHub
- Matrix
- Slack
- Telegram
- Websockets
Opsdroid 引用使聊天机器人能够展现它们的技能的函数。这些技能其实是 异步
Python 函数并使用 Opsdroid 叫做“匹配器”的匹配装饰器。你可以设置你的 Opsdroid 项目,来使用同样从你设置文件所在的代码基地来的技能。你也可以从外面的公共或私人仓库调用这些技能。
你同样可以激活一些现存的 Opsdroid 技能包括 seen,它会告诉你什么时候一个特定用户被聊天机器人所看到以及 weather,会将天气报告给用户。
最后,Opdroid 允许你使用现存的数据库模块设置数据库。现在 Opdroid 支持的数据库包括:
- Mongo
- Redis
- SQLite
你可以在你的 Opdroid 项目中的 configuration.yaml
文件设置数据库、技能和连接器。
Opsdroid 的优势
**Docker 支持:**从一开始 Opsdroid 就打算在 Docker 中良好运行。Docker 指导是它 安装文档 中的一部分。使用 Opsdroid 和 Docker Copmose 也很简单:将 Opsdroid 设置成一种服务,当你运行 docker-compose up
时,你的 Opsdroid 服务将会开启你的聊天机器人也将就绪。
version: "3"
services:
opsdroid:
container_name: opsdroid
build:
context: .
dockerfile: Dockerfile
丰富的连接器: Opsdroid 支持九种从外部接入像 Slack 和 Github 等服务的连接器。你所要做的一切就是在你的设置文件中激活那些连接器然后把必须的口令或者 API 密匙传过去。比如为了激活 Opsdroid 以在一个叫做 #updates
的 Slack 频道发帖,你需要将以下代码加入你设置文件的 connectors
部分:
- name: slack
api-token: "this-is-my-token"
default-room: "#updates"
在设置 Opsdroid 以接入 Slack 之前你需要添加一个机器人用户。
如果你需要接入一个 Opsdroid 不支持的服务,在文档里有有添加你自己的连接器的教程。
相当不错的文档: 特别是对于一个在积极开发中的新兴库来说,Opsdroid 的文档十分有帮助。这些文档包括一篇带你创建几个不同的基本技能的教程。Opsdroid 在技能,连接器,数据库,以及匹配器方面的文档也十分清晰。
**自然语言处理:**它所支持的技能和连接器的仓库为它的技能提供了富有帮助的示范代码。它同样提供了几个包括 Dialogflow,luis.ai,Recast.AI 以及 wit.ai 的 NLP API。
对 Opsdroid 可能的考虑
Opsdroid 对它的一部分连接器还没有激活全部的特性。比如说,Slack API 允许你向你的消息添加颜色柱,图片以及其他的“附件”。Opsdroid Slack 连接器并没有激活“附件”特性,所以如果那些特性对你来说很重要的话,你需要编写一个自定义的 Slack 连接器。如果连接器缺少一个你需要的特性,Opsdroid 将欢迎你的贡献。文档中可以使用更多的例子,特别是对于预料到的使用场景。
示例用法
hello/__init__.py
from opsdroid.matchers import match_regex
import random
@match_regex(r'hi|hello|hey|hallo')
async def hello(opsdroid, config, message):
text = random.choice(["Hi {}", "Hello {}", "Hey {}"]).format(message.user)
await message.respond(text)
configuration.yaml
connectors:
- name: websocket
skills:
- name: hello
repo: "https://github.com/<user_id>/hello-skill"
Errbot
Errbot 是一个功能齐全的开源聊天机器人。Errbot 发行于2012年并且拥有人们从一个成熟的项目能期待的一切,包括良好的文档,优秀的教程以及许多帮你连入现存的流行聊天服务的插件。
它内建了什么
不像采用了一个较轻量级途径的 Opsdroid,Errbot 安全地自带了你需要创建一个自定义机器人的一切东西。
Errbot 包括了对于本地 XMPP, IRC, Slack, Hipchat 以及 Telegram 服务的支持。它通过社区支持的后端列出了另外十种服务。
Errbot 的优势
良好的文档: Errbot 的文档成熟易读。
动态插件架构: Errbot 允许你通过和聊天机器人交谈安全安装,卸载,更新,激活以及禁用插件。这使得开发和添加特性十分简便。感谢 Errbot 的颗粒性授权系统,出于安全意识这所有的一切都可以被锁闭。
当某个人输入 !help
,Errbot 使用你的插件文档字符串来为可获取的命令生成文档,这使得了解每行命令的作用更加简便。
內建的管理和安全特性: Errbot 允许你限制拥有管理员权限甚至细粒度访问控制用户列表。比如说你可以限制特定用户或房间访问特定命令。
额外的插件框架: Errbot 支持钩子,回调,子命令,webhook,轮询以及其它多得多的特性。如果那些还不够,你甚至可以编写动态插件。当你需要基于在远程服务器上什么命令可以获取来激活聊天命令时,这个特性十分有用。
自带测试框架: Errbot 支持 pytest 同时也自带一些能使测试插件变的可能且简便的有用设施。它“测试你的插件”的文档出于深思熟虑并提供足够的资料让你上手。
对 Errbot 可能的考虑
首先 !: 默认情况下,Errbot 命令发出时以一个惊叹号打头(!help
以及 !hello
)。一些人可能会喜欢这样,但是另一些人可能认为这让人烦恼。谢天谢地,这很容易关掉。
插件元数据 首先,Errbot 的 Hello World 插件示例看上去易于使用。然而我无法加载我的插件直到我进一步阅读了教程并发现我还需要一个 .plug
文档,一个 Errbot 用来加载插件的文档。这可能比较吹毛求疵了,但是在我深挖文档之前,这对我来说都不是显而易见的。
示例用法
hello.py
import random
from errbot import BotPlugin, botcmd
class Hello(BotPlugin):
@botcmd
def hello(self, msg, args):
text = random.choice(["Hi {}", "Hello {}", "Hey {}"]).format(message.user)
return text
hello.plug
[Core]
Name = Hello
Module = hello
[Python]
Version = 2+
[Documentation]
Description = Example "Hello" plugin
你用过 Errbot 或 Opsdroid 吗?如果用过请留下关于你对于这些工具印象的留言。
via: https://opensource.com/article/18/3/python-chatops-libraries-opsdroid-and-errbot
作者:Jeff Triplett 译者:tomjlw 校对:校对者ID