3e65e22775
壓測四橫向問題修正(docs 壓測報告):
① 薄殼原則成鐵律:能力長在 API,CLI/MCP/lib 只暴露
- seed 下沉成 API 行為:cypher-executor POST /init/seed(一次灌 API+auth recipe),
種子資料移到 server src/lib/api-recipe-seeds.ts,CLI 改薄殼一次呼叫
- 解除 deployFullyOk 連坐 + init 補 seed auth recipe + update 補 seed/全 KV
- registry SUBMISSIONS_KV 補進 REQUIRED_KV_NAMESPACES(修 20/21)
② MCP 統一帳號來源(單一 remote MCP + .env 切 MCP URL)
- MCP 從 sibling repo 搬進 arcrun/mcp/(remote Worker,route 改 mcp.arcrun.dev)
- config 加 mcp_url 三層解析 + getMcpUrl + DEFAULT_MCP_URL
- 新增 acr mcp-setup:依 config 寫專案 .mcp.json(接案切資料夾自動切 MCP)
- acr --version 改動態讀 package.json(根治漂移)
③ Deploy 一致性
- tests/release.feature + scripts/check-release.sh
- local-deploy.sh:CLI npm publish + auto patch bump + CHANGELOG
- local-deploy.sh bash 3.2 相容修正(mapfile / 空陣列 set -u)
- builtins/pnpm-lock.yaml
④ README self-hosted 同步現況(移除 R2 殘留、加 flag/env、多帳號)
CLI bump → 1.3.0
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
40 lines
2.2 KiB
TypeScript
40 lines
2.2 KiB
TypeScript
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
|
|
import { z } from "zod";
|
|
import { Env } from "../types.js";
|
|
import { kbdbFetch } from "../lib/kbdb-client.js";
|
|
|
|
export function registerListWorkflows(server: McpServer, env: Env, orgNamespace: string) {
|
|
server.tool(
|
|
"u6u_list_workflows",
|
|
"列出當前命名空間下所有已部署的工作流,可選擇按 tag 篩選。",
|
|
{ tag: z.string().optional().describe("按 tag 名稱篩選(選填)") },
|
|
async ({ tag }) => {
|
|
try {
|
|
if (!env.KBDB) {
|
|
return { content: [{ type: "text", text: "Error: KBDB service binding unavailable" }], isError: true };
|
|
}
|
|
let workflowIds: string[] | null = null;
|
|
if (tag) {
|
|
const tagResp = await kbdbFetch(env, `/records/search?template=resource_tag&user_id=${encodeURIComponent(orgNamespace)}&tag_name=${encodeURIComponent(tag)}&resource_type=workflow`);
|
|
if (!tagResp.ok) {
|
|
return { content: [{ type: "text", text: `Error querying tags: ${await tagResp.text()}` }], isError: true };
|
|
}
|
|
const tagData = await tagResp.json<{ records: Array<{ slots: { resource_id: string } }> }>();
|
|
workflowIds = tagData.records.map(r => r.slots.resource_id);
|
|
if (workflowIds.length === 0) return { content: [{ type: "text", text: JSON.stringify([], null, 2) }] };
|
|
}
|
|
const resp = await kbdbFetch(env, `/records/search?template=workflow_metadata&user_id=${encodeURIComponent(orgNamespace)}`);
|
|
if (!resp.ok) {
|
|
return { content: [{ type: "text", text: `Error querying workflows: ${await resp.text()}` }], isError: true };
|
|
}
|
|
const data = await resp.json<{ records: Array<{ slots: { workflow_id: string; name: string; deployed_at: string; org_namespace: string } }> }>();
|
|
let workflows = data.records.map(r => r.slots);
|
|
if (workflowIds !== null) workflows = workflows.filter(w => workflowIds!.includes(w.workflow_id));
|
|
return { content: [{ type: "text", text: JSON.stringify(workflows, null, 2) }] };
|
|
} catch (error) {
|
|
return { content: [{ type: "text", text: `Internal Error: ${error instanceof Error ? error.message : String(error)}` }], isError: true };
|
|
}
|
|
}
|
|
);
|
|
}
|