Endpoint(エンドポイント)
Last updated
Last updated
この記事では、プラグイン内のエンドポイントの構造を説明するために、クイックスタート:レインボーキャットプロジェクトを例として取り上げます。完全なプラグインコードは、Githubで確認できます。
Endpoint
グループは、複数のEndpoint
をまとめたものです。Dify
プラグインで新しいEndpoint
を作成する際には、以下の設定項目を入力する必要があります。
「Endpoint Name」の他に、グループ構成情報を記述することで、新しいフォーム項目を追加できます。保存すると、同じ構成情報を使用する複数のインターフェースが表示されるようになります。
settings
(map[string] ProviderConfig): エンドポイントの設定定義
endpoints
(list[string], required): 特定のendpoint
インターフェース定義を指定します。
path
(string): werkzeugのインターフェース標準に従います。
method
(string): インターフェースのメソッド。HEAD
GET
POST
PUT
DELETE
OPTIONS
のみをサポートします。
extra
(object): 基本情報以外の設定情報
python
(object)
source
(string): このインターフェースを実装するソースコード
dify_plugin.Enterpoint
を継承したサブクラスを実装し、_invoke
メソッドを実装する必要があります。
入力パラメータ
r
(Request): werkzeugからのリクエストオブジェクト
values
(Mapping): パスから解析されたパスパラメータ
settings
(Mapping): このエンドポイントの設定情報
戻り値
werkzeugからのレスポンスオブジェクト。ストリーミングでの応答をサポートします。
直接的な文字列の戻り値はサポートしません。
コード例: