⚠️ 本文档由 AI 自动翻译。如有任何不准确之处,请参考英文原版。
项目背景
Dify 插件生态系统致力于使集成更简单、更易于访问。在本指南中,我们将以 Slack 为例,带你完成开发 Slack Bot 插件的过程。这允许你的团队直接在 Slack 中与 LLM 聊天,显著提高他们使用 AI 的效率。 Slack 是一个开放的实时通信平台,拥有强大的 API。其功能之一是基于 webhook 的事件系统,开发起来非常简单。我们将利用这个系统创建一个 Slack Bot 插件,如下图所示:
为避免混淆,以下概念作说明:工作原理(简要概述):
- Slack Bot Slack 平台上的聊天机器人,作为一个虚拟用户,你可以与其实时交互。
- Slack Bot 插件 Dify Marketplace 中的一个插件,用于连接 Dify 应用程序与 Slack。本指南重点介绍如何开发该插件。
- 向 Slack Bot 发送消息 当 Slack 中的用户向 Bot 发送消息时,Slack Bot 会立即向 Dify 平台发出 webhook 请求。
- 将消息转发给 Slack Bot 插件 Dify 平台触发 Slack Bot 插件,该插件将详细信息转发给 Dify 应用程序——类似于在电子邮件系统中输入收件人地址。通过 Slack 的 API 设置 Slack webhook 地址并在 Slack Bot 插件中输入,即可建立此连接。然后插件处理 Slack 请求并将其发送到 Dify 应用程序,LLM 分析用户的输入并生成响应。
- 将响应返回给 Slack 一旦 Slack Bot 插件收到 Dify 应用程序的回复,它就会通过相同的路径将 LLM 的答案发送回 Slack Bot。Slack 中的用户就可以在他们聊天的地方看到更智能、更互动的体验。
前提条件
- Dify 插件开发工具:更多信息,请参阅初始化开发工具。
- Python 环境(版本 ≥ 3.12):参考此 Python 安装教程 或向 LLM 询问完整的设置指南。
- 创建 Slack App 并获取 OAuth 令牌
- 启用 Webhooks:
- 在你的 Slack 工作区安装应用:
- 获取 OAuth 令牌以供后续插件开发使用:
1. 开发插件
现在我们将深入实际编码。在开始之前,请确保你已阅读快速入门:开发扩展插件或已经构建过 Dify 插件。1.1 初始化项目
运行以下命令来设置你的插件开发环境:extension 模板,并授予 Apps 和 Endpoints 权限。
有关在插件中反向调用 Dify 服务的更多详细信息,请参阅反向调用:App。
1.2 编辑配置表单
此插件需要知道哪个 Dify 应用应处理回复,以及用于验证机器人响应的 Slack App 令牌。因此,你需要在插件的表单中添加这两个字段。 修改 group 目录中的 YAML 文件——例如group/slack.yaml。表单的文件名由你创建插件时提供的信息决定,请相应调整。
示例代码:
slack.yaml
- type:设置为 app-selector,允许用户在使用此插件时将消息转发到特定的 Dify 应用。
- scope:设置为 chat,意味着该插件只能与智能体、chatbot 或 chatflow 等应用类型交互。
endpoints/slack.yaml 文件中,将请求方法更改为 POST 以正确处理传入的 Slack 消息。
示例代码:
endpoints/slack.yaml
2. 编辑功能代码
修改endpoints/slack.py 文件并添加以下代码:
2. 调试插件
前往 Dify 平台并获取插件的远程调试地址和密钥。
回到你的插件项目,复制 .env.example 文件并将其重命名为 .env。
python -m main 启动插件。你现在应该可以在 Dify 插件管理页面的工作区中看到你的插件已安装。其他团队成员也可以访问它。
配置插件端点
从 Dify 的插件管理页面,找到新安装的测试插件并创建一个新端点。提供名称、Bot 令牌,并选择你想要连接的应用。
保存后,将生成一个 POST 请求 URL:
接下来,完成 Slack App 设置:
-
启用事件订阅
粘贴你上面生成的 POST 请求 URL。
-
授予所需权限
3. 验证插件
在你的代码中,self.session.app.chat.invoke 用于调用 Dify 应用程序,传入 app_id 和 query 等参数。然后将响应返回给 Slack Bot。再次运行 python -m main 重启插件进行调试,并检查 Slack 是否正确显示 Dify App 的回复:
4. 打包插件(可选)
确认插件工作正常后,你可以通过以下命令打包并命名它。运行后,你会在当前目录中找到一个slack_bot.difypkg 文件——这就是你的最终插件包。有关详细的打包步骤,请参阅打包为本地文件并分享。
5. 发布插件(可选)
你现在可以将其上传到 Dify Marketplace 仓库 进行公开发布。在发布之前,请确保你的插件符合发布到 Dify Marketplace 指南。一旦获得批准,你的代码将合并到主分支,插件将在 Dify Marketplace 上线。相关资源
- 插件开发基础 - Dify 插件开发的全面概述
- 插件开发快速入门指南 - 从零开始开发插件
- 开发扩展插件 - 了解扩展插件开发
- 反向调用 Dify 服务 - 了解如何调用 Dify 平台功能
- 反向调用:App - 了解如何调用平台内的应用
- 发布插件 - 了解发布流程
- 发布到 Dify Marketplace - Marketplace 发布指南
- 端点详细定义 - 端点详细定义
延伸阅读
要获取完整的 Dify 插件项目示例,请访问 GitHub 仓库。你还可以找到包含完整源代码和实现细节的其他插件。 如果你想了解更多关于插件开发的内容,请查看以下资源: 快速入门: 插件接口文档:- 通过 Manifest 文件定义插件信息 - Manifest 结构
- 端点 - 端点详细定义
- 反向调用 - 反向调用 Dify 功能
- 通用规范 - 工具规范
- 模型 Schema - 模型
Edit this page | Report an issue