このドキュメントは AI によって自動翻訳されています。不正確な部分がある場合は、英語版 を参照してください。各アプリ操作は 1 つのコマンドに対応し、いずれも グローバルフラグ を受け付けます。
difyctl get appはアプリを一覧表示しますdescribe appは単一アプリの詳細と入力を表示しますrun appは単一アプリを呼び出しますresume appは 人間の入力で一時停止した ワークフローを継続しますexport studio-app/import studio-appはアプリを DSL ファイルとしてエクスポート / インポートします
アプリを一覧表示
引数
[app-id]:任意。表示する単一アプリの ID。省略すると、ワークスペース内のすべてのアプリを一覧表示します。
フラグ
| フラグ | 型 | デフォルト | 説明 |
|---|---|---|---|
--name <substring> | string | なし | 名前にこのテキストを含むアプリのみに絞り込みます。 |
--mode <mode> | string | なし | アプリタイプで絞り込みます。API mode で指定します: chat(チャットボット)、advanced-chat(チャットフロー)、agent-chat(Agent)、workflow(ワークフロー)、completion(テキストジェネレーター)。 |
--page <n> | integer | 1 | ページ番号。 |
--limit <n> | integer | 20 | ページサイズ、1 から 200。フラグが優先され、次に DIFY_LIMIT が使われます。 |
-o <format> | string | なし | 出力形式: json、yaml、name、wide。フラグを省略するとデフォルトのテーブルになります。 |
例
ワークスペース内のアプリを一覧表示します:出力
| 形式 | stdout の内容 |
|---|---|
| デフォルト | 整列されたテーブル。MODE 列は各アプリの API mode 名です(アプリタイプとの対応は --mode を参照)。 |
-o wide | テーブルに WORKSPACE 列を加えたもの。 |
-o json、-o yaml | アプリの data 配列に加え、ページング項目の page(現在のページ)、limit(ページサイズ)、total(一致したアプリ数)、has_more(さらにページがあるか)。 |
-o name | アプリ ID を 1 行に 1 つ。 |
終了コード
| 終了コード | 意味 |
|---|---|
0 | 成功 |
1 | ネットワークまたはサーバーエラー |
2 | 使用方法のエラー(例: --limit が 1 から 200 の範囲外) |
4 | 認証失敗 |
7 | レート制限(HTTP 429) |
アプリを確認
describe app は、よく知らないアプリを実行する前に確認したいこと、つまりアプリのタイプ、API が有効かどうか、どんな入力が必要かを教えてくれます。
引数
<app-id>:必須。確認するアプリの ID。
フラグ
| フラグ | 型 | デフォルト | 説明 |
|---|---|---|---|
--refresh | boolean | false | ローカルのアプリ情報キャッシュをバイパスし、最新の詳細を取得します。アプリの再公開後に使用します。 |
-o <format> | string | text | 出力形式: json、yaml、text。 |
例
実行前にアプリを確認します:--inputs をプログラムで組み立てるために入力スキーマを抽出します:
出力
| 形式 | stdout の内容 |
|---|---|
デフォルト(text) | 整列されたフィールドブロックに続いて、アプリのパラメータ(ユーザー入力フォームを含む)。 |
-o json、-o yaml | 3 つのトップレベルキー: info、parameters、input_schema(詳細は後述)。 |
Description: 行が、アプリが agentic な場合は Agent: true 行が表示されます。
-o json では、3 つのキーはそれぞれ次のとおりです:
info:上記のNameからService APIまでのメタデータ項目parameters:上記のパラメータブロックinput_schema:アプリ入力の正規化されたリスト。jq '.input_schema'の例が読み取る項目
終了コード
| 終了コード | 意味 |
|---|---|
0 | 成功 |
1 | ネットワークまたはサーバーエラー(アプリが見つからない場合を含む) |
2 | 使用方法のエラー(<app-id> が UUID でない場合を含む) |
4 | 認証失敗 |
7 | レート制限(HTTP 429) |
アプリを実行
run app は、すべてのアプリタイプを 1 つのコマンドで扱います。CLI がアプリのタイプを判別し、適切なエンドポイントに振り分けます。アプリタイプによって変わるのは、入力の渡し方とレスポンスの形だけです:
- チャットボット、チャットフロー、Agent:位置引数のメッセージを受け取り、応答を stdout に出力し、会話のヒントを stderr に出力します。
- テキストジェネレーター:位置引数のメッセージを受け取り、補完結果を stdout に出力します。会話状態もヒントもありません。
- ワークフロー:
--inputsで JSON オブジェクトを受け取り、その出力を stdout に出力します。出力が単一の文字列のときはそのまま、それ以外はコンパクトな JSON として出力します。
引数
<app-id>:必須。実行するアプリの ID。get appから取得します。[message]:ユーザーメッセージ。チャットボット、チャットフロー、Agent、テキストジェネレーターのアプリで使います。ワークフローアプリは位置引数のメッセージを受け付けないため、その入力は--inputsで渡します。
フラグ
| フラグ | 型 | デフォルト | 説明 |
|---|---|---|---|
--inputs <json> | string | なし | 入力変数を 1 つの JSON オブジェクトとして指定します。例: --inputs '{"topic":"Q3"}'。ワークフローアプリでは必須です。--inputs-file とは併用できません。 |
--inputs-file <path> | string | なし | 代わりに JSON ファイルから入力オブジェクトを読み込みます。 |
--file <key=value> | string、繰り返し可 | なし | 名前付きファイル入力。key=@path はローカルファイルをアップロードします。key=https://… はアップロードせずにリモート URL を渡します。key は入力変数名です。 |
--conversation <id> | string | なし | 既存の会話を継続します。ID は前回の実行の stderr ヒントまたは JSON レスポンスから得られます。 |
--workflow-id <id> | string | なし | 実行を特定の公開済みワークフローバージョンに固定します。ワークフローとチャットフローのアプリのみ。 |
--stream | boolean | false | 最後に一度に出力するのではなく、生成されるそばから出力をライブで表示します。 |
--think | boolean | false | モデルが思考過程を公開する場合に、それを stderr に出力します。このフラグがない場合、<think> ブロックは無言で取り除かれます。 |
--retry-on-limit | boolean | false | 429 レート制限時に、終了コード 7 で失敗する代わりに待機して実行を再試行します。実行は冪等ではないため、デフォルトはオフです。 |
-o <format> | string | text | 出力形式: json、yaml、text。 |
例
チャットボット、チャットフロー、Agent、テキストジェネレーターのアプリにメッセージを送信します:出力
| 形式 | stdout の内容 |
|---|---|
デフォルト(text) | 応答(チャットボット、チャットフロー、Agent、テキストジェネレーター)またはワークフローの出力を、プレーンテキストで。 |
-o json、-o yaml | サーバーの完全なペイロード。会話型アプリでは answer と conversation_id を含みます。モデルが推論を返す場合は、ノードごとの推論が metadata.reasoning の下に含まれます。 |
--stream を付けると、サーバーが生成するそばから出力が逐次表示されます。アプリの再公開直後に実行が HTTP 422 で失敗した場合、CLI はアプリメタデータのキャッシュをクリアし、コマンドの再実行を促します。
エラーは stderr に出力されます。-o json では、安定した code 項目を持つ構造化された JSON オブジェクトとして返されます。エラーの形は 出力形式と終了コード を参照してください。
終了コード
| 終了コード | 意味 |
|---|---|
0 | 成功。人間の入力で一時停止した ワークフローを含む |
1 | ネットワークまたはサーバーエラー(アプリが見つからない場合を含む) |
2 | 使用方法のエラー: --inputs の JSON が無効、またはワークフローアプリに位置引数のメッセージを渡した場合 |
4 | 認証失敗 |
7 | レート制限(HTTP 429) |
ワークフローが一時停止する場合
ワークフローアプリには人間の入力ステップを含められます。実行がそこに到達すると、終了せずに一時停止します。コマンドは 終了コード 0 で終了し(一時停止は失敗ではありません)、一時停止を stdout に出力し、すぐに実行できる再開コマンドを stderr に出力します:-o json を付けると、stdout には一時停止が JSON オブジェクトとして出力されます:
-o json で実行し、stdout に "status": "paused" があるか確認します。再開に必要なのは次の 3 つです: form_token、workflow_run_id、そして(フォームが複数の操作を提示する場合は)操作の id。フォームは expiration_time(Unix エポック秒)の時点で期限切れになります。
ワークフローがメールやその他の外部チャネル経由でフォームを配信する場合、form_token は null になり、その実行は CLI から再開できません。
一時停止したワークフローを再開
resume app は、一時停止したワークフローが待機しているフォームを送信し、その実行にアタッチして、run app とまったく同じように出力を表示します。
引数
<app-id>:必須。一時停止ペイロードのapp_id。<form-token>:必須。一時停止ペイロードのform_token。Token は 1 回限りのため、消費済みの token で再開するとエラーが返ります。
フラグ
| フラグ | 型 | デフォルト | 説明 |
|---|---|---|---|
--workflow-run-id <id> | string | 必須 | 一時停止ペイロードの workflow_run_id。 |
--action <id> | string | 自動選択 | どのフォーム操作を実行するか。一時停止ペイロードの actions 内の id で指定します。フォームの操作がちょうど 1 つの場合は任意、複数ある場合は必須です。 |
--inputs <json> | string | なし | フォーム入力の値を 1 つの JSON オブジェクトとして、各入力の output_variable_name をキーにして指定します。--inputs-file とは併用できません。 |
--inputs-file <path> | string | なし | 代わりに JSON ファイルからフォームの値を読み込みます。 |
--with-history | boolean | false | ライブストリームにアタッチする前に、実行済みノードの出力を再生します。 |
--stream | boolean | false | 最後に一度に出力するのではなく、生成されるそばから出力をライブで表示します。 |
--think | boolean | false | モデルが思考過程を公開する場合に、それを stderr に出力します。このフラグがない場合、<think> ブロックは無言で取り除かれます。 |
-o <format> | string | text | 出力形式: json、yaml、text。 |
例
単一操作のフォームを承認し、その入力値を指定します:出力
| 形式 | stdout の内容 |
|---|---|
デフォルト(text) | 実行の進行に合わせて出力されるワークフローの出力。stderr が送信と完了を確認します。 |
-o json、-o yaml | 実行結果を 1 つのドキュメントとして。run app と同じです(再び一時停止した場合は一時停止ペイロード)。 |
終了コード
| 終了コード | 意味 |
|---|---|
0 | 成功。後続のノードで実行が再び一時停止する場合を含む |
1 | エラー。消費済みのフォーム token、または操作が複数あるフォームで --action を省略した場合を含む |
2 | 使用方法のエラー |
4 | 認証失敗 |
7 | レート制限(HTTP 429) |
アプリをエクスポート
export studio-app は、バージョン管理、バックアップ、または別の場所への インポート のために、アプリの完全な定義を DSL YAML ドキュメントとして書き出します。
ワークフローとチャットフローのアプリでは、エクスポートは run app が実行する公開済みバージョンではなく、現在のドラフトを返します。代わりに --workflow-id を使うと、特定の公開済みバージョンをエクスポートできます。チャットボット、Agent、テキストジェネレーターのアプリは公開済みバージョンをエクスポートします。
引数
<app-id>:必須。エクスポートするアプリの ID。get appから取得します。
フラグ
| フラグ | 型 | デフォルト | 説明 |
|---|---|---|---|
-o, --output <path> | string | なし | DSL を stdout ではなくこのファイルに書き込みます。このコマンドでは、-o は出力形式のセレクタではなく出力ファイルのパスです。 |
--include-secret | boolean | false | エクスポートする DSL に暗号化された機密値を含めます。 |
--workflow-id <id> | string | なし | デフォルトのドラフトではなく、特定の公開済みワークフローバージョンを ID で指定してエクスポートします。ワークフローとチャットフローのアプリのみ。 |
例
アプリの DSL を stdout に出力します:出力
DSL YAML ドキュメントが stdout に出力されます:kind: app ヘッダー、version 項目、そしてアプリの完全な定義です。--output を付けると、同じ内容がファイルに書き込まれ、stderr が確認します:
終了コード
| 終了コード | 意味 |
|---|---|
0 | 成功 |
1 | ネットワークまたはサーバーエラー(アプリが見つからない場合を含む) |
2 | 使用方法のエラー(<app-id> の欠落を含む) |
4 | 認証失敗 |
7 | レート制限(HTTP 429) |
アプリをインポート
import studio-app は、DSL YAML ドキュメントからアプリを作成するか、--app-id で既存のアプリを上書きします。ワークフローとチャットフローのアプリでは、定義をアプリのドラフトに書き込みます。run app は公開済みバージョンを使うため、変更を反映させるにはインポート後に Dify でアプリを公開してください。
フラグ
| フラグ | 型 | デフォルト | 説明 |
|---|---|---|---|
-f, --from-file <path> | string | なし | ローカルファイルから DSL をインポートします。--from-file と --from-url のどちらか一方が必須です。 |
--from-url <url> | string | なし | HTTP(S) URL から DSL をインポートします。 |
--name <name> | string | DSL から | アプリ名を上書きします。 |
--description <text> | string | DSL から | アプリの説明を上書きします。 |
--app-id <id> | string | なし | 新規作成ではなく、既存のアプリを上書きします。ワークフローとチャットフローのアプリのみ。 |
--icon-type <type> | string | DSL から | アイコンタイプを上書きします。 |
--icon <icon> | string | DSL から | アイコンを上書きします。 |
--icon-background <color> | string | DSL から | アイコンの背景色を上書きします。 |
例
ローカルの DSL ファイルからアプリをインポートします:出力
すべてのステータス行は stderr に出力され、stdout は空のままです。成功すると、stderr が新しいアプリの ID を報告します:Missing plugin dependencies の下にそれらを列挙します。アプリを使う前にインストールしてください。
終了コード
| 終了コード | 意味 |
|---|---|
0 | 成功。警告付きのインポートを含む |
1 | エラー。--from-file/--from-url の欠落や競合、またはインポートの失敗を含む |
2 | 使用方法のエラー。存在しない --from-file パスを含む |
4 | 認証失敗 |
7 | レート制限(HTTP 429) |