组定义
一个Endpoint 组是多个 Endpoint 的集合,在 Dify 插件内新建 Endpoint 时可能需要填写如下配置。
除了 Endpoint Name 外,你可以通过编写组的配置信息来添加新的表单项,点击保存后,你可以看到其中包含的多个接口,它们将使用相同的配置信息。
结构
settings(map[string] ProviderConfig ):Endpoint 配置定义endpoints(list[string], required):指向具体的endpoint接口定义
接口定义
path(string):遵循 werkzeug 接口标准method(string):接口方法,仅支持HEADGETPOSTPUTDELETEOPTIONSextra(object):除基础信息外的配置信息python(object)source(string):实现该接口的源代码
接口实现
需要实现一个继承自dify_plugin.Endpoint 子类,并实现 _invoke 方法。
- 输入参数
r(Request):werkzeug中的Request对象values(Mapping):从 path 中解析到的路径参数settings(Mapping):该Endpoint的配置信息
- 返回
werkzeug中的Response对象,支持流式返回- 不支持直接返回字符串
注意事项
- Endpoint 只在插件被调用时才会实例化,并不是长期运行的服务
- 请在开发 Endpoint 时注意安全性,避免执行危险操作
- Endpoint 可以用于处理 Webhook 回调或提供接口给其他系统连接
相关资源
- 插件开发基本概念 - 了解插件开发的整体架构
- 彩虹猫实例 - 扩展插件开发示例
- 通用规范定义 - 了解 ProviderConfig 等通用结构
- Slack 机器人插件开发示例 - 另一个插件开发示例
- 插件开发入门指南 - 从零开始开发插件
- 反向调用 Dify 服务 - 了解如何使用反向调用功能
编辑此页面 | 提交问题