bc6360ccfc
http_request 零件擴展(registry/components/http_request):
- 加 body_json 物件欄位(內部 JSON.stringify),yaml 端不用手組 JSON 字串
- 新增 JSON 回應的 error 欄位偵測 → 若 body 含 `{"error":"..."}` 則零件回 success=false
解 cascade bug:mira_feed_watcher 用 http_request trigger wiki_synthesis,
原本 4xx response 也被當 success,ON_SUCCESS 鏈會誤觸發
根因架構債:host fn 沒回 HTTP status code(arcrun.md 列為 P1 follow-up)
landing 河道 feed (landing/app/mira/feed/page.tsx):
- 加回 triggerWikiSynthesis fire-and-forget 對 cypher.arcrun.dev/webhooks/named/
wiki_synthesis/trigger 公開觸發 endpoint(arcrun-native,非 mira-specific route)
- 不走 watcher 是因為 cypher-executor 自己 fetch 自己 workers.dev URL = CF 1042
self-fetch 擋
watcher 仍存在當 cron backup,但目前因 self-fetch 1042 不會真正觸發下游
wiki_synthesis(arcrun.md 列為 P1 follow-up)。
67 lines
2.0 KiB
YAML
67 lines
2.0 KiB
YAML
canonical_id: "http_request"
|
||
display_name: "HTTP 請求"
|
||
category: "api"
|
||
version: "v1"
|
||
wasi_target: "preview1"
|
||
stability: "floating"
|
||
runtime_compat:
|
||
- "cf-workers"
|
||
- "workerd"
|
||
- "wazero"
|
||
constraints:
|
||
max_size_kb: 2048
|
||
max_cold_start_ms: 50
|
||
no_network_syscall: false
|
||
no_filesystem_syscall: true
|
||
io_model: "stdin_stdout_json"
|
||
input_schema:
|
||
type: object
|
||
required: [url]
|
||
properties:
|
||
url:
|
||
type: string
|
||
description: 目標 URL(必填)
|
||
method:
|
||
type: string
|
||
description: HTTP 方法(GET / POST / PUT / DELETE 等),預設 GET
|
||
default: GET
|
||
headers:
|
||
type: object
|
||
description: 自訂 HTTP headers(key-value 物件)
|
||
additionalProperties:
|
||
type: string
|
||
body:
|
||
type: string
|
||
description: 模式 A — body 字串(自行 stringify 後傳)
|
||
body_json:
|
||
type: object
|
||
description: 模式 B — body 物件,零件內部 JSON.stringify(yaml 端不用手組字串)
|
||
output_schema:
|
||
type: object
|
||
properties:
|
||
success:
|
||
type: boolean
|
||
data:
|
||
type: object
|
||
properties:
|
||
body:
|
||
type: string
|
||
description: HTTP 回應 body(字串)
|
||
gherkin_tests:
|
||
- scenario: "缺少 url"
|
||
given: '{"method":"GET"}'
|
||
then_contains: '{"success":false'
|
||
- scenario: "基本 GET 請求"
|
||
given: '{"url":"https://example.com"}'
|
||
then_contains: '{"success":true'
|
||
tags: [integration, http, request, api]
|
||
description: "發送任意 HTTP 請求並回傳 status 與 body。透過 host function 呼叫,.wasm 本身不含網路 syscall。headers 由用戶手動填入。"
|
||
config_example: |
|
||
http_call: # 節點名稱(可自訂)
|
||
url: "" # 目標 URL(必填)
|
||
method: "GET" # HTTP 方法(選填,預設 GET)
|
||
headers: # 自訂 headers(選填,用戶手動填入)
|
||
Content-Type: "application/json"
|
||
Authorization: "Bearer <your_token>"
|
||
body: {} # 請求 body(選填)
|