template_workflow.ja.mdx 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742
  1. import { CodeGroup } from '../code.tsx'
  2. import { Row, Col, Properties, Property, Heading, SubProperty, Paragraph } from '../md.tsx'
  3. # ワークフローアプリAPI
  4. ワークフローアプリケーションは、セッションをサポートせず、翻訳、記事作成、要約AIなどに最適です。
  5. <div>
  6. ### ベースURL
  7. <CodeGroup title="コード" targetCode={props.appDetail.api_base_url}>
  8. ```javascript
  9. ```
  10. </CodeGroup>
  11. ### 認証
  12. サービスAPIは`API-Key`認証を使用します。
  13. <i>**APIキーの漏洩を防ぐため、APIキーはクライアント側で共有または保存せず、サーバー側で保存することを強くお勧めします。**</i>
  14. すべてのAPIリクエストにおいて、以下のように`Authorization`HTTPヘッダーにAPIキーを含めてください:
  15. <CodeGroup title="コード">
  16. ```javascript
  17. Authorization: Bearer {API_KEY}
  18. ```
  19. </CodeGroup>
  20. </div>
  21. ---
  22. <Heading
  23. url='/workflows/run'
  24. method='POST'
  25. title='ワークフローを実行'
  26. name='#Execute-Workflow'
  27. />
  28. <Row>
  29. <Col>
  30. ワークフローを実行します。公開されたワークフローがないと実行できません。
  31. ### リクエストボディ
  32. - `inputs` (object) 必須
  33. アプリで定義されたさまざまな変数値の入力を許可します。
  34. `inputs`パラメータには複数のキー/値ペアが含まれ、各キーは特定の変数に対応し、各値はその変数の特定の値です。
  35. ワークフローアプリケーションは少なくとも1つのキー/値ペアの入力を必要とします。
  36. 変数がファイルタイプの場合、以下の`files`で説明されているキーを持つオブジェクトを指定してください。
  37. - `response_mode` (string) 必須
  38. 応答の返却モードを指定します。サポートされているモード:
  39. - `streaming` ストリーミングモード(推奨)、SSE([Server-Sent Events](https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events/Using_server-sent_events))を通じてタイプライターのような出力を実装します。
  40. - `blocking` ブロッキングモード、実行完了後に結果を返します。(プロセスが長い場合、リクエストが中断される可能性があります)
  41. <i>Cloudflareの制限により、100秒後に応答がない場合、リクエストは中断されます。</i>
  42. - `user` (string) 必須
  43. ユーザー識別子、エンドユーザーのアイデンティティを定義するために使用されます。
  44. アプリケーション内で開発者によって一意に定義される必要があります。
  45. - `files` (array[object]) オプション
  46. ファイルリストは、テキスト理解と質問への回答を組み合わせたファイルの入力に適しています。モデルがファイルの解析と理解機能をサポートしている場合にのみ使用できます。
  47. - `type` (string) サポートされているタイプ:
  48. - `document` ('TXT', 'MD', 'MARKDOWN', 'PDF', 'HTML', 'XLSX', 'XLS', 'DOCX', 'CSV', 'EML', 'MSG', 'PPTX', 'PPT', 'XML', 'EPUB')
  49. - `image` ('JPG', 'JPEG', 'PNG', 'GIF', 'WEBP', 'SVG')
  50. - `audio` ('MP3', 'M4A', 'WAV', 'WEBM', 'AMR')
  51. - `video` ('MP4', 'MOV', 'MPEG', 'MPGA')
  52. - `transfer_method` (string) 転送方法、画像URLの場合は`remote_url` / ファイルアップロードの場合は`local_file`
  53. - `url` (string) 画像URL(転送方法が`remote_url`の場合)
  54. - `upload_file_id` (string) アップロードされたファイルID、事前にファイルアップロードAPIを通じて取得する必要があります(転送方法が`local_file`の場合)
  55. ### 応答
  56. `response_mode`が`blocking`の場合、CompletionResponseオブジェクトを返します。
  57. `response_mode`が`streaming`の場合、ChunkCompletionResponseストリームを返します。
  58. ### CompletionResponse
  59. アプリの結果を返します。`Content-Type`は`application/json`です。
  60. - `workflow_run_id` (string) ワークフロー実行の一意のID
  61. - `task_id` (string) タスクID、リクエスト追跡と以下のStop Generate APIに使用
  62. - `data` (object) 結果の詳細
  63. - `id` (string) ワークフロー実行のID
  64. - `workflow_id` (string) 関連するワークフローのID
  65. - `status` (string) 実行のステータス、`running` / `succeeded` / `failed` / `stopped`
  66. - `outputs` (json) オプションの出力内容
  67. - `error` (string) オプションのエラー理由
  68. - `elapsed_time` (float) オプションの使用時間(秒)
  69. - `total_tokens` (int) オプションの使用トークン数
  70. - `total_steps` (int) デフォルト0
  71. - `created_at` (timestamp) 開始時間
  72. - `finished_at` (timestamp) 終了時間
  73. ### ChunkCompletionResponse
  74. アプリによって出力されたストリームチャンクを返します。`Content-Type`は`text/event-stream`です。
  75. 各ストリーミングチャンクは`data:`で始まり、2つの改行文字`\n\n`で区切られます。以下のように表示されます:
  76. <CodeGroup>
  77. ```streaming {{ title: '応答' }}
  78. data: {"event": "message", "task_id": "900bbd43-dc0b-4383-a372-aa6e6c414227", "id": "663c5084-a254-4040-8ad3-51f2a3c1a77c", "answer": "Hi", "created_at": 1705398420}\n\n
  79. ```
  80. </CodeGroup>
  81. ストリーミングチャンクの構造は`event`に応じて異なります:
  82. - `event: workflow_started` ワークフローが実行を開始
  83. - `task_id` (string) タスクID、リクエスト追跡と以下のStop Generate APIに使用
  84. - `workflow_run_id` (string) ワークフロー実行の一意のID
  85. - `event` (string) `workflow_started`に固定
  86. - `data` (object) 詳細
  87. - `id` (string) ワークフロー実行の一意のID
  88. - `workflow_id` (string) 関連するワークフローのID
  89. - `sequence_number` (int) 自己増加シリアル番号、アプリ内で自己増加し、1から始まります
  90. - `created_at` (timestamp) 作成タイムスタンプ、例:1705395332
  91. - `event: node_started` ノード実行開始
  92. - `task_id` (string) タスクID、リクエスト追跡と以下のStop Generate APIに使用
  93. - `workflow_run_id` (string) ワークフロー実行の一意のID
  94. - `event` (string) `node_started`に固定
  95. - `data` (object) 詳細
  96. - `id` (string) ワークフロー実行の一意のID
  97. - `node_id` (string) ノードのID
  98. - `node_type` (string) ノードのタイプ
  99. - `title` (string) ノードの名前
  100. - `index` (int) 実行シーケンス番号、トレースノードシーケンスを表示するために使用
  101. - `predecessor_node_id` (string) オプションのプレフィックスノードID、キャンバス表示実行パスに使用
  102. - `inputs` (object) ノードで使用されるすべての前のノード変数の内容
  103. - `created_at` (timestamp) 開始のタイムスタンプ、例:1705395332
  104. - `event: node_finished` ノード実行終了、同じイベントで異なる状態で成功または失敗
  105. - `task_id` (string) タスクID、リクエスト追跡と以下のStop Generate APIに使用
  106. - `workflow_run_id` (string) ワークフロー実行の一意のID
  107. - `event` (string) `node_finished`に固定
  108. - `data` (object) 詳細
  109. - `id` (string) ワークフロー実行の一意のID
  110. - `node_id` (string) ノードのID
  111. - `node_type` (string) ノードのタイプ
  112. - `title` (string) ノードの名前
  113. - `index` (int) 実行シーケンス番号、トレースノードシーケンスを表示するために使用
  114. - `predecessor_node_id` (string) オプションのプレフィックスノードID、キャンバス表示実行パスに使用
  115. - `inputs` (object) ノードで使用されるすべての前のノード変数の内容
  116. - `process_data` (json) オプションのノードプロセスデータ
  117. - `outputs` (json) オプションの出力内容
  118. - `status` (string) 実行のステータス、`running` / `succeeded` / `failed` / `stopped`
  119. - `error` (string) オプションのエラー理由
  120. - `elapsed_time` (float) オプションの使用時間(秒)
  121. - `execution_metadata` (json) メタデータ
  122. - `total_tokens` (int) オプションの使用トークン数
  123. - `total_price` (decimal) オプションの総コスト
  124. - `currency` (string) オプション 例:`USD` / `RMB`
  125. - `created_at` (timestamp) 開始のタイムスタンプ、例:1705395332
  126. - `event: workflow_finished` ワークフロー実行終了、同じイベントで異なる状態で成功または失敗
  127. - `task_id` (string) タスクID、リクエスト追跡と以下のStop Generate APIに使用
  128. - `workflow_run_id` (string) ワークフロー実行の一意のID
  129. - `event` (string) `workflow_finished`に固定
  130. - `data` (object) 詳細
  131. - `id` (string) ワークフロー実行のID
  132. - `workflow_id` (string) 関連するワークフローのID
  133. - `status` (string) 実行のステータス、`running` / `succeeded` / `failed` / `stopped`
  134. - `outputs` (json) オプションの出力内容
  135. - `error` (string) オプションのエラー理由
  136. - `elapsed_time` (float) オプションの使用時間(秒)
  137. - `total_tokens` (int) オプションの使用トークン数
  138. - `total_steps` (int) デフォルト0
  139. - `created_at` (timestamp) 開始時間
  140. - `finished_at` (timestamp) 終了時間
  141. - `event: tts_message` TTSオーディオストリームイベント、つまり音声合成出力。内容はMp3形式のオーディオブロックで、base64文字列としてエンコードされています。再生時には、base64をデコードしてプレーヤーに入力するだけです。(このメッセージは自動再生が有効な場合にのみ利用可能)
  142. - `task_id` (string) タスクID、リクエスト追跡と以下の停止応答インターフェースに使用
  143. - `message_id` (string) 一意のメッセージID
  144. - `audio` (string) 音声合成後のオーディオ、base64テキストコンテンツとしてエンコードされており、再生時にはbase64をデコードしてプレーヤーに入力するだけです
  145. - `created_at` (int) 作成タイムスタンプ、例:1705395332
  146. - `event: tts_message_end` TTSオーディオストリーム終了イベント。このイベントを受信すると、オーディオストリームの終了を示します。
  147. - `task_id` (string) タスクID、リクエスト追跡と以下の停止応答インターフェースに使用
  148. - `message_id` (string) 一意のメッセージID
  149. - `audio` (string) 終了イベントにはオーディオがないため、これは空の文字列です
  150. - `created_at` (int) 作成タイムスタンプ、例:1705395332
  151. - `event: ping` 接続を維持するために10秒ごとに送信されるPingイベント。
  152. ### エラー
  153. - 400, `invalid_param`, 異常なパラメータ入力
  154. - 400, `app_unavailable`, アプリの設定が利用できません
  155. - 400, `provider_not_initialize`, 利用可能なモデル資格情報の設定がありません
  156. - 400, `provider_quota_exceeded`, モデル呼び出しのクォータが不足しています
  157. - 400, `model_currently_not_support`, 現在のモデルは利用できません
  158. - 400, `workflow_request_error`, ワークフロー実行に失敗しました
  159. - 500, 内部サーバーエラー
  160. </Col>
  161. <Col sticky>
  162. <CodeGroup title="リクエスト" tag="POST" label="/workflows/run" targetCode={`curl -X POST '${props.appDetail.api_base_url}/workflows/run' \\\n--header 'Authorization: Bearer {api_key}' \\\n--header 'Content-Type: application/json' \\\n--data-raw '{\n "inputs": ${JSON.stringify(props.inputs)},\n "response_mode": "streaming",\n "user": "abc-123"\n}'\n`}>
  163. ```bash {{ title: 'cURL' }}
  164. curl -X POST '${props.appDetail.api_base_url}/workflows/run' \
  165. --header 'Authorization: Bearer {api_key}' \
  166. --header 'Content-Type: application/json' \
  167. --data-raw '{
  168. "inputs": {},
  169. "response_mode": "streaming",
  170. "user": "abc-123"
  171. }'
  172. ```
  173. </CodeGroup>
  174. <CodeGroup title="ファイル変数の例">
  175. ```json {{ title: 'ファイル変数の例' }}
  176. {
  177. "inputs": {
  178. "{variable_name}": {
  179. "transfer_method": "local_file",
  180. "upload_file_id": "{upload_file_id}",
  181. "type": "{document_type}"
  182. }
  183. }
  184. }
  185. ```
  186. </CodeGroup>
  187. ### ブロッキングモード
  188. <CodeGroup title="応答">
  189. ```json {{ title: '応答' }}
  190. {
  191. "workflow_run_id": "djflajgkldjgd",
  192. "task_id": "9da23599-e713-473b-982c-4328d4f5c78a",
  193. "data": {
  194. "id": "fdlsjfjejkghjda",
  195. "workflow_id": "fldjaslkfjlsda",
  196. "status": "succeeded",
  197. "outputs": {
  198. "text": "Nice to meet you."
  199. },
  200. "error": null,
  201. "elapsed_time": 0.875,
  202. "total_tokens": 3562,
  203. "total_steps": 8,
  204. "created_at": 1705407629,
  205. "finished_at": 1727807631
  206. }
  207. }
  208. ```
  209. </CodeGroup>
  210. ### ストリーミングモード
  211. <CodeGroup title="応答">
  212. ```streaming {{ title: '応答' }}
  213. data: {"event": "workflow_started", "task_id": "5ad4cb98-f0c7-4085-b384-88c403be6290", "workflow_run_id": "5ad498-f0c7-4085-b384-88cbe6290", "data": {"id": "5ad498-f0c7-4085-b384-88cbe6290", "workflow_id": "dfjasklfjdslag", "sequence_number": 1, "created_at": 1679586595}}
  214. data: {"event": "node_started", "task_id": "5ad4cb98-f0c7-4085-b384-88c403be6290", "workflow_run_id": "5ad498-f0c7-4085-b384-88cbe6290", "data": {"id": "5ad498-f0c7-4085-b384-88cbe6290", "node_id": "dfjasklfjdslag", "node_type": "start", "title": "Start", "index": 0, "predecessor_node_id": "fdljewklfklgejlglsd", "inputs": {}, "created_at": 1679586595}}
  215. data: {"event": "node_finished", "task_id": "5ad4cb98-f0c7-4085-b384-88c403be6290", "workflow_run_id": "5ad498-f0c7-4085-b384-88cbe6290", "data": {"id": "5ad498-f0c7-4085-b384-88cbe6290", "node_id": "dfjasklfjdslag", "node_type": "start", "title": "Start", "index": 0, "predecessor_node_id": "fdljewklfklgejlglsd", "inputs": {}, "outputs": {}, "status": "succeeded", "elapsed_time": 0.324, "execution_metadata": {"total_tokens": 63127864, "total_price": 2.378, "currency": "USD"}, "created_at": 1679586595}}
  216. data: {"event": "workflow_finished", "task_id": "5ad4cb98-f0c7-4085-b384-88c403be6290", "workflow_run_id": "5ad498-f0c7-4085-b384-88cbe6290", "data": {"id": "5ad498-f0c7-4085-b384-88cbe6290", "workflow_id": "dfjasklfjdslag", "outputs": {}, "status": "succeeded", "elapsed_time": 0.324, "total_tokens": 63127864, "total_steps": "1", "created_at": 1679586595, "finished_at": 1679976595}}
  217. data: {"event": "tts_message", "conversation_id": "23dd85f3-1a41-4ea0-b7a9-062734ccfaf9", "message_id": "a8bdc41c-13b2-4c18-bfd9-054b9803038c", "created_at": 1721205487, "task_id": "3bf8a0bb-e73b-4690-9e66-4e429bad8ee7", "audio": "qqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqqq"}
  218. data: {"event": "tts_message_end", "conversation_id": "23dd85f3-1a41-4ea0-b7a9-062734ccfaf9", "message_id": "a8bdc41c-13b2-4c18-bfd9-054b9803038c", "created_at": 1721205487, "task_id": "3bf8a0bb-e73b-4690-9e66-4e429bad8ee7", "audio": ""}
  219. ```
  220. </CodeGroup>
  221. <CodeGroup title="ファイルアップロードのサンプルコード">
  222. ```json {{ title: 'ファイルアップロードのサンプルコード' }}
  223. import requests
  224. import json
  225. def upload_file(file_path, user):
  226. upload_url = "https://api.dify.ai/v1/files/upload"
  227. headers = {
  228. "Authorization": "Bearer app-xxxxxxxx",
  229. }
  230. try:
  231. print("ファイルをアップロードしています...")
  232. with open(file_path, 'rb') as file:
  233. files = {
  234. 'file': (file_path, file, 'text/plain') # ファイルが適切な MIME タイプでアップロードされていることを確認してください
  235. }
  236. data = {
  237. "user": user,
  238. "type": "TXT" # ファイルタイプをTXTに設定します
  239. }
  240. response = requests.post(upload_url, headers=headers, files=files, data=data)
  241. if response.status_code == 201: # 201 は作成が成功したことを意味します
  242. print("ファイルが正常にアップロードされました")
  243. return response.json().get("id") # アップロードされたファイルIDを取得する
  244. else:
  245. print(f"ファイルのアップロードに失敗しました。ステータス コード: {response.status_code}")
  246. return None
  247. except Exception as e:
  248. print(f"エラーが発生しました: {str(e)}")
  249. return None
  250. def run_workflow(file_id, user, response_mode="blocking"):
  251. workflow_url = "https://api.dify.ai/v1/workflows/run"
  252. headers = {
  253. "Authorization": "Bearer app-xxxxxxxxx",
  254. "Content-Type": "application/json"
  255. }
  256. data = {
  257. "inputs": {
  258. "orig_mail": {
  259. "transfer_method": "local_file",
  260. "upload_file_id": file_id,
  261. "type": "document"
  262. }
  263. },
  264. "response_mode": response_mode,
  265. "user": user
  266. }
  267. try:
  268. print("ワークフローを実行...")
  269. response = requests.post(workflow_url, headers=headers, json=data)
  270. if response.status_code == 200:
  271. print("ワークフローが正常に実行されました")
  272. return response.json()
  273. else:
  274. print(f"ワークフローの実行がステータス コードで失敗しました: {response.status_code}")
  275. return {"status": "error", "message": f"Failed to execute workflow, status code: {response.status_code}"}
  276. except Exception as e:
  277. print(f"エラーが発生しました: {str(e)}")
  278. return {"status": "error", "message": str(e)}
  279. # 使用例
  280. file_path = "{your_file_path}"
  281. user = "difyuser"
  282. # ファイルをアップロードする
  283. file_id = upload_file(file_path, user)
  284. if file_id:
  285. # ファイルは正常にアップロードされました。ワークフローの実行を続行します
  286. result = run_workflow(file_id, user)
  287. print(result)
  288. else:
  289. print("ファイルのアップロードに失敗し、ワークフローを実行できません")
  290. ```
  291. </CodeGroup>
  292. </Col>
  293. </Row>
  294. ---
  295. <Heading
  296. url='/workflows/run/:workflow_id'
  297. method='GET'
  298. title='ワークフロー実行詳細を取得'
  299. name='#get-workflow-run-detail'
  300. />
  301. <Row>
  302. <Col>
  303. ワークフロー実行IDに基づいて、ワークフロータスクの現在の実行結果を取得します。
  304. ### パス
  305. - `workflow_id` (string) ワークフローID、ストリーミングチャンクの返り値から取得可能
  306. ### 応答
  307. - `id` (string) ワークフロー実行のID
  308. - `workflow_id` (string) 関連するワークフローのID
  309. - `status` (string) 実行のステータス、`running` / `succeeded` / `failed` / `stopped`
  310. - `inputs` (json) 入力内容
  311. - `outputs` (json) 出力内容
  312. - `error` (string) エラー理由
  313. - `total_steps` (int) タスクの総ステップ数
  314. - `total_tokens` (int) 使用されるトークンの総数
  315. - `created_at` (timestamp) 開始時間
  316. - `finished_at` (timestamp) 終了時間
  317. - `elapsed_time` (float) 使用される総秒数
  318. </Col>
  319. <Col sticky>
  320. ### リクエスト例
  321. <CodeGroup title="リクエスト" tag="GET" label="/workflows/run/:workflow_id" targetCode={`curl -X GET '${props.appDetail.api_base_url}/workflows/run/:workflow_id' \\\n-H 'Authorization: Bearer {api_key}' \\\n-H 'Content-Type: application/json'`}>
  322. ```bash {{ title: 'cURL' }}
  323. curl -X GET '${props.appDetail.api_base_url}/workflows/run/:workflow_id' \
  324. -H 'Authorization: Bearer {api_key}' \
  325. -H 'Content-Type: application/json'
  326. ```
  327. </CodeGroup>
  328. ### 応答例
  329. <CodeGroup title="応答">
  330. ```json {{ title: '応答' }}
  331. {
  332. "id": "b1ad3277-089e-42c6-9dff-6820d94fbc76",
  333. "workflow_id": "19eff89f-ec03-4f75-b0fc-897e7effea02",
  334. "status": "succeeded",
  335. "inputs": "{\"sys.files\": [], \"sys.user_id\": \"abc-123\"}",
  336. "outputs": null,
  337. "error": null,
  338. "total_steps": 3,
  339. "total_tokens": 0,
  340. "created_at": "Thu, 18 Jul 2024 03:17:40 -0000",
  341. "finished_at": "Thu, 18 Jul 2024 03:18:10 -0000",
  342. "elapsed_time": 30.098514399956912
  343. }
  344. ```
  345. </CodeGroup>
  346. </Col>
  347. </Row>
  348. ---
  349. <Heading
  350. url='/workflows/tasks/:task_id/stop'
  351. method='POST'
  352. title='生成を停止'
  353. name='#stop-generatebacks'
  354. />
  355. <Row>
  356. <Col>
  357. ストリーミングモードでのみサポートされています。
  358. ### パス
  359. - `task_id` (string) タスクID、ストリーミングチャンクの返り値から取得可能
  360. ### リクエストボディ
  361. - `user` (string) 必須
  362. ユーザー識別子、エンドユーザーのアイデンティティを定義するために使用され、送信メッセージインターフェースで渡されたユーザーと一致している必要があります。
  363. ### 応答
  364. - `result` (string) 常に"success"を返します
  365. </Col>
  366. <Col sticky>
  367. ### リクエスト例
  368. <CodeGroup title="リクエスト" tag="POST" label="/workflows/tasks/:task_id/stop" targetCode={`curl -X POST '${props.appDetail.api_base_url}/workflows/tasks/:task_id/stop' \\\n-H 'Authorization: Bearer {api_key}' \\\n-H 'Content-Type: application/json' \\\n--data-raw '{"user": "abc-123"}'`}>
  369. ```bash {{ title: 'cURL' }}
  370. curl -X POST '${props.appDetail.api_base_url}/workflows/tasks/:task_id/stop' \
  371. -H 'Authorization: Bearer {api_key}' \
  372. -H 'Content-Type: application/json' \
  373. --data-raw '{
  374. "user": "abc-123"
  375. }'
  376. ```
  377. </CodeGroup>
  378. ### 応答例
  379. <CodeGroup title="応答">
  380. ```json {{ title: '応答' }}
  381. {
  382. "result": "success"
  383. }
  384. ```
  385. </CodeGroup>
  386. </Col>
  387. </Row>
  388. ---
  389. <Heading
  390. url='/files/upload'
  391. method='POST'
  392. title='ファイルアップロード'
  393. name='#file-upload'
  394. />
  395. <Row>
  396. <Col>
  397. メッセージ送信時に使用するためのファイルをアップロードし、画像とテキストのマルチモーダル理解を可能にします。
  398. ワークフローでサポートされている任意の形式をサポートします。
  399. アップロードされたファイルは、現在のエンドユーザーのみが使用できます。
  400. ### リクエストボディ
  401. このインターフェースは`multipart/form-data`リクエストを必要とします。
  402. - `file` (File) 必須
  403. アップロードするファイル。
  404. - `user` (string) 必須
  405. ユーザー識別子、開発者のルールで定義され、アプリケーション内で一意でなければなりません。
  406. ### 応答
  407. アップロードが成功すると、サーバーはファイルのIDと関連情報を返します。
  408. - `id` (uuid) ID
  409. - `name` (string) ファイル名
  410. - `size` (int) ファイルサイズ(バイト)
  411. - `extension` (string) ファイル拡張子
  412. - `mime_type` (string) ファイルのMIMEタイプ
  413. - `created_by` (uuid) エンドユーザーID
  414. - `created_at` (timestamp) 作成タイムスタンプ、例:1705395332
  415. ### エラー
  416. - 400, `no_file_uploaded`, ファイルが提供されていません
  417. - 400, `too_many_files`, 現在は1つのファイルのみ受け付けています
  418. - 400, `unsupported_preview`, ファイルはプレビューをサポートしていません
  419. - 400, `unsupported_estimate`, ファイルは推定をサポートしていません
  420. - 413, `file_too_large`, ファイルが大きすぎます
  421. - 415, `unsupported_file_type`, サポートされていない拡張子、現在はドキュメントファイルのみ受け付けています
  422. - 503, `s3_connection_failed`, S3サービスに接続できません
  423. - 503, `s3_permission_denied`, S3にファイルをアップロードする権限がありません
  424. - 503, `s3_file_too_large`, ファイルがS3のサイズ制限を超えています
  425. - 500, 内部サーバーエラー
  426. </Col>
  427. <Col sticky>
  428. ### リクエスト例
  429. <CodeGroup title="リクエスト" tag="POST" label="/files/upload" targetCode={`curl -X POST '${props.appDetail.api_base_url}/files/upload' \\\n--header 'Authorization: Bearer {api_key}' \\\n--form 'file=@localfile;type=image/[png|jpeg|jpg|webp|gif] \\\n--form 'user=abc-123'`}>
  430. ```bash {{ title: 'cURL' }}
  431. curl -X POST '${props.appDetail.api_base_url}/files/upload' \
  432. --header 'Authorization: Bearer {api_key}' \
  433. --form 'file=@"/path/to/file"'
  434. ```
  435. </CodeGroup>
  436. ### 応答例
  437. <CodeGroup title="応答">
  438. ```json {{ title: '応答' }}
  439. {
  440. "id": "72fa9618-8f89-4a37-9b33-7e1178a24a67",
  441. "name": "example.png",
  442. "size": 1024,
  443. "extension": "png",
  444. "mime_type": "image/png",
  445. "created_by": "6ad1ab0a-73ff-4ac1-b9e4-cdb312f71f13",
  446. "created_at": 1577836800,
  447. }
  448. ```
  449. </CodeGroup>
  450. </Col>
  451. </Row>
  452. ---
  453. <Heading
  454. url='/workflows/logs'
  455. method='GET'
  456. title='ワークフローログを取得'
  457. name='#Get-Workflow-Logs'
  458. />
  459. <Row>
  460. <Col>
  461. ワークフローログを返します。最初のページは最新の`{limit}`メッセージを返します。つまり、逆順です。
  462. ### クエリ
  463. <Properties>
  464. <Property name='keyword' type='string' key='keyword'>
  465. 検索するキーワード
  466. </Property>
  467. <Property name='status' type='string' key='status'>
  468. succeeded/failed/stopped
  469. </Property>
  470. <Property name='page' type='int' key='page'>
  471. 現在のページ、デフォルトは1。
  472. </Property>
  473. <Property name='limit' type='int' key='limit'>
  474. 1回のリクエストで返すチャット履歴メッセージの数、デフォルトは20。
  475. </Property>
  476. </Properties>
  477. ### 応答
  478. - `page` (int) 現在のページ
  479. - `limit` (int) 返されたアイテムの数、入力がシステム制限を超える場合、システム制限量を返します
  480. - `total` (int) 合計アイテム数
  481. - `has_more` (bool) 次のページがあるかどうか
  482. - `data` (array[object]) ログリスト
  483. - `id` (string) ID
  484. - `workflow_run` (object) ワークフロー実行
  485. - `id` (string) ID
  486. - `version` (string) バージョン
  487. - `status` (string) 実行のステータス、`running` / `succeeded` / `failed` / `stopped`
  488. - `error` (string) オプションのエラー理由
  489. - `elapsed_time` (float) 使用される総秒数
  490. - `total_tokens` (int) 使用されるトークン数
  491. - `total_steps` (int) デフォルト0
  492. - `created_at` (timestamp) 開始時間
  493. - `finished_at` (timestamp) 終了時間
  494. - `created_from` (string) 作成元
  495. - `created_by_role` (string) 作成者の役割
  496. - `created_by_account` (string) オプションの作成者アカウント
  497. - `created_by_end_user` (object) エンドユーザーによって作成
  498. - `id` (string) ID
  499. - `type` (string) タイプ
  500. - `is_anonymous` (bool) 匿名かどうか
  501. - `session_id` (string) セッションID
  502. - `created_at` (timestamp) 作成時間
  503. </Col>
  504. <Col sticky>
  505. <CodeGroup title="リクエスト" tag="GET" label="/workflows/logs" targetCode={`curl -X GET '${props.appDetail.api_base_url}/workflows/logs'\\\n --header 'Authorization: Bearer {api_key}'`}>
  506. ```bash {{ title: 'cURL' }}
  507. curl -X GET '${props.appDetail.api_base_url}/workflows/logs?limit=1'
  508. --header 'Authorization: Bearer {api_key}'
  509. ```
  510. </CodeGroup>
  511. ### 応答例
  512. <CodeGroup title="応答">
  513. ```json {{ title: '応答' }}
  514. {
  515. "page": 1,
  516. "limit": 1,
  517. "total": 7,
  518. "has_more": true,
  519. "data": [
  520. {
  521. "id": "e41b93f1-7ca2-40fd-b3a8-999aeb499cc0",
  522. "workflow_run": {
  523. "id": "c0640fc8-03ef-4481-a96c-8a13b732a36e",
  524. "version": "2024-08-01 12:17:09.771832",
  525. "status": "succeeded",
  526. "error": null,
  527. "elapsed_time": 1.3588523610014818,
  528. "total_tokens": 0,
  529. "total_steps": 3,
  530. "created_at": 1726139643,
  531. "finished_at": 1726139644
  532. },
  533. "created_from": "service-api",
  534. "created_by_role": "end_user",
  535. "created_by_account": null,
  536. "created_by_end_user": {
  537. "id": "7f7d9117-dd9d-441d-8970-87e5e7e687a3",
  538. "type": "service_api",
  539. "is_anonymous": false,
  540. "session_id": "abc-123"
  541. },
  542. "created_at": 1726139644
  543. }
  544. ]
  545. }
  546. ```
  547. </CodeGroup>
  548. </Col>
  549. </Row>
  550. ---
  551. <Heading
  552. url='/info'
  553. method='GET'
  554. title='アプリケーションの基本情報を取得'
  555. name='#info'
  556. />
  557. <Row>
  558. <Col>
  559. このアプリケーションの基本情報を取得するために使用されます
  560. ### Query
  561. <Properties>
  562. <Property name='user' type='string' key='user'>
  563. ユーザー識別子、開発者のルールによって定義され、アプリケーション内で一意でなければなりません。
  564. </Property>
  565. </Properties>
  566. ### Response
  567. - `name` (string) アプリケーションの名前
  568. - `description` (string) アプリケーションの説明
  569. - `tags` (array[string]) アプリケーションのタグ
  570. </Col>
  571. <Col>
  572. <CodeGroup title="Request" tag="GET" label="/info" targetCode={`curl -X GET '${props.appDetail.api_base_url}/info?user=abc-123' \\\n-H 'Authorization: Bearer {api_key}'`}>
  573. ```bash {{ title: 'cURL' }}
  574. curl -X GET '${props.appDetail.api_base_url}/info?user=abc-123' \
  575. -H 'Authorization: Bearer {api_key}'
  576. ```
  577. </CodeGroup>
  578. <CodeGroup title="Response">
  579. ```json {{ title: 'Response' }}
  580. {
  581. "name": "My App",
  582. "description": "This is my app.",
  583. "tags": [
  584. "tag1",
  585. "tag2"
  586. ]
  587. }
  588. ```
  589. </CodeGroup>
  590. </Col>
  591. </Row>
  592. ---
  593. <Heading
  594. url='/parameters'
  595. method='GET'
  596. title='アプリケーションのパラメータ情報を取得'
  597. name='#parameters'
  598. />
  599. <Row>
  600. <Col>
  601. ページに入る際に、機能、入力パラメータ名、タイプ、デフォルト値などの情報を取得するために使用されます。
  602. ### クエリ
  603. <Properties>
  604. <Property name='user' type='string' key='user'>
  605. ユーザー識別子、開発者のルールで定義され、アプリケーション内で一意でなければなりません。
  606. </Property>
  607. </Properties>
  608. ### 応答
  609. - `user_input_form` (array[object]) ユーザー入力フォームの設定
  610. - `text-input` (object) テキスト入力コントロール
  611. - `label` (string) 変数表示ラベル名
  612. - `variable` (string) 変数ID
  613. - `required` (bool) 必須かどうか
  614. - `default` (string) デフォルト値
  615. - `paragraph` (object) 段落テキスト入力コントロール
  616. - `label` (string) 変数表示ラベル名
  617. - `variable` (string) 変数ID
  618. - `required` (bool) 必須かどうか
  619. - `default` (string) デフォルト値
  620. - `select` (object) ドロップダウンコントロール
  621. - `label` (string) 変数表示ラベル名
  622. - `variable` (string) 変数ID
  623. - `required` (bool) 必須かどうか
  624. - `default` (string) デフォルト値
  625. - `options` (array[string]) オプション値
  626. - `file_upload` (object) ファイルアップロード設定
  627. - `image` (object) 画像設定
  628. 現在サポートされている画像タイプのみ:`png`, `jpg`, `jpeg`, `webp`, `gif`
  629. - `enabled` (bool) 有効かどうか
  630. - `number_limits` (int) 画像数の制限、デフォルトは3
  631. - `transfer_methods` (array[string]) 転送方法のリスト、remote_url, local_file、いずれかを選択する必要があります
  632. - `system_parameters` (object) システムパラメータ
  633. - `file_size_limit` (int) ドキュメントアップロードサイズ制限(MB)
  634. - `image_file_size_limit` (int) 画像ファイルアップロードサイズ制限(MB)
  635. - `audio_file_size_limit` (int) オーディオファイルアップロードサイズ制限(MB)
  636. - `video_file_size_limit` (int) ビデオファイルアップロードサイズ制限(MB)
  637. </Col>
  638. <Col sticky>
  639. <CodeGroup title="リクエスト" tag="GET" label="/parameters" targetCode={` curl -X GET '${props.appDetail.api_base_url}/parameters?user=abc-123'`}>
  640. ```bash {{ title: 'cURL' }}
  641. curl -X GET '${props.appDetail.api_base_url}/parameters?user=abc-123' \
  642. --header 'Authorization: Bearer {api_key}'
  643. ```
  644. </CodeGroup>
  645. <CodeGroup title="応答">
  646. ```json {{ title: '応答' }}
  647. {
  648. "user_input_form": [
  649. {
  650. "paragraph": {
  651. "label": "Query",
  652. "variable": "query",
  653. "required": true,
  654. "default": ""
  655. }
  656. }
  657. ],
  658. "file_upload": {
  659. "image": {
  660. "enabled": false,
  661. "number_limits": 3,
  662. "detail": "high",
  663. "transfer_methods": [
  664. "remote_url",
  665. "local_file"
  666. ]
  667. }
  668. },
  669. "system_parameters": {
  670. "file_size_limit": 15,
  671. "image_file_size_limit": 10,
  672. "audio_file_size_limit": 50,
  673. "video_file_size_limit": 100
  674. }
  675. }
  676. ```
  677. </CodeGroup>
  678. </Col>
  679. </Row>