外部データツール
外部データツールは、エンドユーザーがデータを送信した後、外部ツールを使用して追加のデータを取得し、それをプロンプトに組み込むことで、LLMの追加のコンテキスト情報として利用します。Difyはデフォルトで外部API呼び出しツールを提供しており、詳細はapi-based-extensionを参照してください。
ローカルにDifyをデプロイする開発者向けには、よりカスタマイズされたニーズに対応するため、または追加のAPIサーバーを開発したくない場合、Difyサービスの基盤にカスタムの外部データツールをプラグインとして直接挿入することができます。カスタムツールを拡張した後、ツールタイプのドロップダウンリストにカスタムツールオプションが追加され、チームメンバーはカスタムツールを使用して外部データを取得できるようになります。
クイックスタート
ここでは、天気検索
外部データツール拡張を例として、以下の手順を説明します:
- ディレクトリの初期化
- フロントエンドフォーム規格の追加
- 実装クラスの追加
- 拡張のデバッグ
1. ディレクトリの初期化
新しいカスタムタイプWeather Search
を追加するには、api/core/external_data_tool
ディレクトリに関連するディレクトリとファイルを新規作成します。
2. フロントエンドコンポーネント規格の追加
schema.json
、ここではフロントエンドコンポーネントの規格を定義します。
3. 実装クラスの追加
weather_search.py
のコードテンプレートです。ここに具体的な業務ロジックを実装します。
注意点:クラス変数nameはカスタムタイプ名称であり、ディレクトリとファイル名と一致し、かつ唯一である必要があります。
4. 拡張のデバッグ
これで、DifyアプリケーションオーケストレーションインターフェースでカスタムWeather Search
外部データツール拡張タイプを選択してデバッグできます。
実装クラステンプレート
実装クラスの詳細な説明
def validate_config
schema.json
フォーム検証メソッド、ユーザーが「公開」をクリックして設定を保存するときに呼び出されます。
config
フォームパラメータ{variable}
フォームカスタム変数
def query
ユーザーがカスタムデータクエリを実装し、返される結果は指定された変数に置き換えられます。
inputs
:エンドユーザーが入力した変数値query
:エンドユーザーが現在の会話で入力した内容、対話型アプリケーションの固定パラメータ。