Files
system-dev-template/template/system-dev/workflows/tasks-project-sync.local.sh
T
Leo 10f25e53e3 feat: tasks.md ⇄ GitHub Project 單向投影 optional 模組(issue #16)+ bump 1.13.0
裝了 SDD 的專案可把 docs/3-specs/*/tasks.md 待辦單向投影成唯讀 GitHub Project。
md 唯一真相源、Project 永遠唯讀,無反向同步、不會兩個真相源打架。預設不逼:
沒裝 Arcrun/答不要的用戶完全 no-op,純 md 不受影響。

- 投影 workflow template/system-dev/workflows/tasks-project-sync.yaml(Arcrun
  workflow):foreach 增量 → switch 動作 → http_request 打 GitHub API:新 task→
  issue create / [ ]→[x]→close / 文字改→edit / 行刪→archive(not_planned),並用
  GraphQL addProjectV2ItemById 投影進 Projects v2。auth 走 {{creds.github_token}}。
- 本地觸發端 tasks-project-sync.local.sh:因 Arcrun workflow 跑遠端 CF Workers、
  沒本地 fs/git,「讀 tasks.md / git diff / 回寫 <!-- gh:id -->」由本地端做完再
  acr run 餵增量。本地一半 + 遠端一半,職責邊界清楚。薄殼不自刻 parser。
- 防複發核實:每個 component 經 acr parts 核實存在(registry 無 github 零件,全用
  http_request 打 REST/GraphQL)。acr validate --offline 通過(7 三元組、config 完整)。
- 啟用判準=對話 + 能力,不掃檔(Arcrun workflow 存遠端 KV、零本地檔也能用 →
  掃檔 false negative)。install/init 問一句 → 查環境有 Arcrun 就 acr push 啟用、
  沒有就一次性溫和廣告。帶檔 ≠ 啟用。install/update 隨 SDD 模組帶 workflow(add_if_missing)。
- 守 flag 紅線:push 後本機觸發單次,禁定期輪詢、禁 GitHub Actions fan-out。

⚠️ 端到端(acr push 真部署 + acr run 真投影)待 leo21c 驗,本版為 code-done 骨架。
SDD(內部,gitignore 不推):docs/3-specs/tasks-project-projection/。

Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-28 16:24:33 +08:00

71 lines
4.1 KiB
Bash
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
#!/usr/bin/env bash
# tasks-project-sync.local.sh — 本地觸發端(投影的「本地一半」)
#
# 來源:issue #16;設計:system-dev/docs/3-specs/tasks-project-projection/design.md
#
# ── 為什麼有這支(職責邊界)──────────────────────────────────────
# arcrun workflow 跑在遠端 CF Workers,沒有本地 fs / git / shell。
# 所以「讀 tasks.md / git diff / 回寫 <!-- gh:id -->」這三件本地事
# 不能放進 workflow(arcrun 也沒有對應零件,這是架構邊界、不是缺口)。
# 這支就是那「本地一半」:分類好增量 → 交給 acr run 打 GitHub。
#
# 這支(本地):讀 tasks.md → git diff → 分類四動作 → acr run 投影 → 回寫新 id
# │
# ▼
# tasks-project-sync.yaml(遠端):foreach → switch → github API
#
# ── 怎麼觸發(守 flag 紅線)─────────────────────────────────────
# push 後「本機觸發單次」,非 cron、非輪詢、非 GitHub Actions。
# 掛載點建議:本機 git post-push 類 hook,或叫 CC 在 push 後跑這支一次。
# ⚠️ 具體掛載點與「分類四動作」的精確 parse,待 leo21c 端到端驗證後定稿;
# 目前是 code-done 骨架,標出該做什麼、邊界在哪,不假裝已通。
#
# ── 用法 ───────────────────────────────────────────────────────
# tasks-project-sync.local.sh <owner> <repo> <project_id>
#
# 前置:acr 在 PATH、github_token 已 acr creds push、workflow 已 acr push。
set -euo pipefail
OWNER="${1:?需要 owner}"
REPO="${2:?需要 repo}"
PROJECT_ID="${3:?需要 GitHub Projects v2 node id}"
# 多組 SDD 全同步:glob 掃所有 tasks.md(新 folder 自動成組,免手動登記)。
GLOB="system-dev/docs/3-specs/*/tasks.md"
# ── 1. 分類增量(git diff 知道改了哪幾行 → 四動作)──────────────
# 這裡是「本地一半」的核心。實作策略(待端到端驗證後落地):
# - 拿 push 前後的 git diff,限定 $GLOB 範圍,只看動到的行。
# - 每行 task 解析:有無 `<!-- gh:N -->` id、checkbox 是否 [ ]→[x]、文字/負責人/日期變動。
# - 行不見(diff 的刪除行)且原本有 id → archive。
# - 子系統 = 該 tasks.md 的 folder 名(當 label 分組)。
# - 產出 tasks_json 陣列(格式見 yaml 註解)。
#
# ⚠️ 刻意不在這支用 TS/Python 刻複雜 parser(守薄殼)。複雜分類交給 CC 在 push 後
# 讀 diff 直接產 tasks_json;這支保持「薄殼 + 交棒 acr run」。若未來證明需要可重用的
# parser 零件,那屬於 arcrun 零件缺口 → 回報 issue #16 由 arcrun 端補,不在此自刻。
#
# 佔位:實際 tasks_json 由 CC 依上述策略產生後填入。
TASKS_JSON="${TASKS_JSON:-[]}"
if [ "$TASKS_JSON" = "[]" ]; then
echo "(無增量 → 本次 no-op,不呼叫 GitHub"
exit 0
fi
# ── 2. 交給遠端 workflow 投影 ───────────────────────────────────
acr run tasks_project_sync \
-i owner="$OWNER" \
-i repo="$REPO" \
-i project_id="$PROJECT_ID" \
-i tasks_json="$TASKS_JSON"
# ── 3. 回寫新 task 的 id(唯一對 md 的寫入,只在 create 時做一次)──
# create 動作的回傳 issue number → append `<!-- gh:N -->` 到該行末。
# ⚠️ 防迴圈:回寫造成 working tree 變動,這次回寫「不得」再觸發一輪投影
# (否則 push→觸發→回寫→又一個 diff→又觸發…)。實作時觸發端要排除
# 「只動到 <!-- gh:N --> 註解」的 diff,或回寫走 [skip-sync] 標記。
# 具體機制待端到端驗證定稿。
echo "(新 task 的 id 回寫:待端到端驗證後接上 acr run 的回傳 → append <!-- gh:N -->"