ticket: record intake and companion closure
This commit is contained in:
parent
978d97a90a
commit
a0b688e29a
|
|
@ -1,8 +1,8 @@
|
|||
---
|
||||
title: "Companion status context and tool policy"
|
||||
state: "planning"
|
||||
state: 'closed'
|
||||
created_at: "2026-06-07T00:16:51Z"
|
||||
updated_at: "2026-06-07T02:45:32Z"
|
||||
updated_at: '2026-06-10T10:03:36Z'
|
||||
---
|
||||
|
||||
## Background
|
||||
|
|
|
|||
1
.yoi/tickets/00001KTFQ109R/resolution.md
Normal file
1
.yoi/tickets/00001KTFQ109R/resolution.md
Normal file
|
|
@ -0,0 +1 @@
|
|||
Companion の lifecycle / panel integration は 00001KTFQ109T で実装済み。Companion を含む project role profile の tool surface / feature policy は 00001KTNQK1V8 で実装済み。残る prompt 文言整理は LLM-facing prompt の resources/prompts 集約チケット側で扱うため、この古い計画チケットは完了扱いで閉じる。
|
||||
|
|
@ -41,4 +41,22 @@ Operational trigger for revisiting:
|
|||
- Users repeatedly want Companion to perform clear shell-based diagnostics; or
|
||||
- Prompt-level "read-only" instructions prove insufficient and Companion attempts or performs unsafe Bash actions.
|
||||
|
||||
---
|
||||
|
||||
<!-- event: state_changed author: hare at: 2026-06-10T10:03:36Z from: planning to: closed reason: closed field: state -->
|
||||
|
||||
## State changed
|
||||
|
||||
Ticket を closed にしました。
|
||||
|
||||
|
||||
---
|
||||
|
||||
<!-- event: close author: hare at: 2026-06-10T10:03:36Z status: closed -->
|
||||
|
||||
## 完了
|
||||
|
||||
Companion の lifecycle / panel integration は 00001KTFQ109T で実装済み。Companion を含む project role profile の tool surface / feature policy は 00001KTNQK1V8 で実装済み。残る prompt 文言整理は LLM-facing prompt の resources/prompts 集約チケット側で扱うため、この古い計画チケットは完了扱いで閉じる。
|
||||
|
||||
|
||||
---
|
||||
|
|
|
|||
0
.yoi/tickets/00001KTRKZ14C/artifacts/.gitkeep
Normal file
0
.yoi/tickets/00001KTRKZ14C/artifacts/.gitkeep
Normal file
130
.yoi/tickets/00001KTRKZ14C/item.md
Normal file
130
.yoi/tickets/00001KTRKZ14C/item.md
Normal file
|
|
@ -0,0 +1,130 @@
|
|||
---
|
||||
title: 'Project workflowsをpublic builtinとdogfood運用に分離する'
|
||||
state: 'ready'
|
||||
created_at: '2026-06-10T11:16:30Z'
|
||||
updated_at: '2026-06-10T11:18:55Z'
|
||||
assignee: null
|
||||
---
|
||||
|
||||
## 背景
|
||||
|
||||
現在の workflow は workspace-local な `.yoi/workflow/*.md` として管理されている。対象は以下。
|
||||
|
||||
- `ticket-intake-workflow.md`
|
||||
- `ticket-orchestrator-routing.md`
|
||||
- `ticket-preflight-workflow.md`
|
||||
- `multi-agent-workflow.md`
|
||||
- `worktree-workflow.md`
|
||||
|
||||
これらには Yoi の public builtin workflow として有用な Ticket / Pod orchestration 原則が含まれている一方、この repository の dogfooding 運用に強く結合した Git / worktree / branch / commit / merge / cargo / nix / `.yoi` sparse checkout などの具体手順も混ざっている。
|
||||
|
||||
そのまま builtin 化すると、公開用の標準 workflow が Yoi 開発 repository 固有の運用をユーザー project に押し付けることになる。builtin 化の前に、public default として提供する汎用 workflow と、この repository での dogfooding workflow を明確に分離する必要がある。
|
||||
|
||||
## 現状分析
|
||||
|
||||
- Workflow loader は主に `<workspace>/.yoi/workflow/<slug>.md` を読む。
|
||||
- `WorkflowSource` には現在 `WorkspaceWorkflow` と `Skill { dir }` があり、`Builtin` source はない。
|
||||
- Pod 起動時に workspace workflows を読み、その後 manifest の `[skills] directories` 由来の `SKILL.md` を registry に merge している。
|
||||
- resident workflow advertisement は workflow metadata に基づくため、builtin 化した workflow は model context への露出範囲も設計する必要がある。
|
||||
- 現在の `.yoi/ticket.config.toml` は project-local workflow slug を role に紐づけている。
|
||||
- Intake: `ticket-intake-workflow`
|
||||
- Orchestrator: `ticket-orchestrator-routing`
|
||||
- Coder/Reviewer: `multi-agent-workflow`
|
||||
|
||||
## 問題意識
|
||||
|
||||
- `ticket-intake-workflow.md` は builtin 化しやすいが、古い `Action required` / `Attention required` 語彙や Yoi dogfooding 寄りの表現を整理する必要がある。
|
||||
- `ticket-orchestrator-routing.md` は builtin 化候補だが、Git/worktree/branch など実装隔離 mechanism への具体言及を薄め、workspace state / active workspaces / isolation mechanism といった抽象表現へ寄せる必要がある。
|
||||
- `ticket-preflight-workflow.md` は内容としては planning / requirements sync に近く、public-facing slug と既存互換名の扱いを決める必要がある。
|
||||
- `multi-agent-workflow.md` は Yoi dogfooding 色が強く、`yoi を yoi で開発する`、worktree + branch + commit + merge + cargo/nix/yoi doctor などが濃い。そのまま public builtin にしない。
|
||||
- `worktree-workflow.md` は Git worktree 専用であり、optional な Git workflow としてはあり得るが、default resident workflow にするべきではない。
|
||||
- LLM-facing workflow 文言は prompt の一種なので、builtin workflow の resource placement は `resources/prompts` 集約方針と整合させる必要がある。
|
||||
|
||||
## 要件
|
||||
|
||||
- 現行 project workflows を audit し、public builtin に抽出する内容と dogfood/project-local に残す内容を分離する。
|
||||
- public builtin workflow に入れるべき抽象原則を整理する。
|
||||
- Ticket は durable orchestration record。
|
||||
- Task は session-local progress tracking。
|
||||
- Objective は中期 goal / decision context。
|
||||
- Intake は scheduler ではない。
|
||||
- Ticket 作成前に user agreement を取る。
|
||||
- broad effort を umbrella/progress-container Ticket にしない。
|
||||
- binding decisions / invariants と implementation latitude を分ける。
|
||||
- risk flags は automatic stop gate ではない。
|
||||
- `queued -> inprogress` は side effect 前の explicit acceptance。
|
||||
- notification は proof ではない。
|
||||
- coder/reviewer は sibling として扱う。
|
||||
- reviewer は intent / invariant / acceptance criteria に照らして判断する。
|
||||
- merge-ready dossier / handoff report の考え方。
|
||||
- secrets/private context を records に残さない。
|
||||
- prompt context / authority boundary に触れる変更は escalation。
|
||||
- public builtin workflow から、この repository 固有の dogfooding 手順を外す。
|
||||
- `yoi を yoi で開発する` 前提。
|
||||
- `.worktree/<task-name>` 固定。
|
||||
- `git worktree add` / sparse checkout 除外リスト。
|
||||
- branch naming / commit / merge / cleanup の細部。
|
||||
- `TODO.md` / `docs/report` / `.yoi/memory` 固有運用。
|
||||
- `cargo fmt --check` / `cargo check --workspace` / `cargo test` / `nix build` / `yoi ticket doctor` の固定 validation。
|
||||
- dogfood workflow はこの repository 用の project-local workflow として残す。
|
||||
- public builtin と同じ slug で override するか、`yoi-dogfood-*` のような明示 slug に分けるかを判断し、理由を記録する。
|
||||
- builtin workflow source model を設計する。
|
||||
- `WorkflowSource::Builtin` または同等の provenance を追加する方針を決める。
|
||||
- builtin workflow の synthetic path / source label / diagnostics 表示を決める。
|
||||
- workflow source priority / override semantics を決める。
|
||||
- workspace `.yoi/workflow/<slug>.md` が builtin を override できること。
|
||||
- skill workflows と builtin workflows の優先順位を明示すること。
|
||||
- resident advertisement の分類を決める。
|
||||
- core builtin resident workflow と optional builtin workflow を分ける。
|
||||
- Git/worktree workflow を default resident にするかどうかを明示する。
|
||||
- builtin workflow resource placement を決める。
|
||||
- LLM-facing text 集約方針に従い、`resources/prompts/workflows/` など prompt resource 配下に置く案を検討する。
|
||||
- workflow crate の record/source model と矛盾させない。
|
||||
- `.yoi/ticket.config.toml` の workflow selector を、分離後の slug / source model に合わせて更新する。
|
||||
- stale な `Action required` / `Attention required` workflow 文言を削除・置換する。
|
||||
|
||||
## 推奨する分解案
|
||||
|
||||
### Public builtin core workflows
|
||||
|
||||
- `ticket-intake-workflow`
|
||||
- `ticket-orchestrator-routing`
|
||||
- `ticket-planning-sync` または既存互換の `ticket-preflight-workflow`
|
||||
|
||||
### Public builtin optional workflows
|
||||
|
||||
- `multi-agent-review-workflow`
|
||||
- `git-worktree-isolation-workflow`
|
||||
|
||||
optional workflows は builtin resource として提供しても、default resident advertisement には含めない、または profile/feature で明示有効化する。
|
||||
|
||||
### Project dogfood workflows
|
||||
|
||||
- `yoi-dogfood-multi-agent-workflow`
|
||||
- `yoi-dogfood-worktree-workflow`
|
||||
|
||||
この repository の concrete Git/worktree/cargo/nix/Ticket doctor 運用は dogfood workflow 側に残す。
|
||||
|
||||
## 受け入れ条件
|
||||
|
||||
- 現行 `.yoi/workflow/*.md` の内容が、public builtin 候補と dogfood/project-local 残置対象に分類されている。
|
||||
- public builtin にそのまま入れてはいけない Git/worktree/Yoi-repo-specific 文言が audit され、移動先または削除理由が記録されている。
|
||||
- `WorkflowSource::Builtin` など builtin workflow source/provenance の設計が記録されている。
|
||||
- source priority が明文化されている。
|
||||
- workspace override が builtin より優先されること。
|
||||
- skill workflow と builtin workflow の優先順位。
|
||||
- resident advertisement の core/optional 方針が決まっている。
|
||||
- builtin workflow resource を `resources/prompts` 配下に置くか、別 resource tree に置くかの判断と理由が記録されている。
|
||||
- public builtin workflow の slug と dogfood workflow の slug 方針が決まっている。
|
||||
- `.yoi/ticket.config.toml` をどう移行するかが記録されている。
|
||||
- `Action required` / `Attention required` のような廃止済み Ticket frontmatter 語彙が workflow から取り除かれる計画になっている。
|
||||
- 後続実装 Ticket に分割できる粒度まで設計が落ちている。
|
||||
- `target/debug/yoi ticket doctor` が通る。
|
||||
|
||||
## 非目標
|
||||
|
||||
- この Ticket 単体で builtin workflow loader を実装すること。
|
||||
- この Ticket 単体ですべての workflow content を書き換えて移行完了すること。
|
||||
- Git/worktree workflow を public default resident workflow として無条件に有効化すること。
|
||||
- Yoi dogfooding 固有の運用を捨てること。
|
||||
- workflow 文言を Rust code に直書きすること。
|
||||
45
.yoi/tickets/00001KTRKZ14C/thread.md
Normal file
45
.yoi/tickets/00001KTRKZ14C/thread.md
Normal file
|
|
@ -0,0 +1,45 @@
|
|||
<!-- event: create author: "yoi ticket" at: 2026-06-10T11:16:30Z -->
|
||||
|
||||
## 作成
|
||||
|
||||
LocalTicketBackend によって作成されました。
|
||||
|
||||
---
|
||||
|
||||
<!-- event: plan author: ticket-intake at: 2026-06-10T11:18:41Z -->
|
||||
|
||||
## Plan
|
||||
|
||||
## Intake refinement
|
||||
|
||||
既存 Ticket を読み、重複作成はしない方針で確認した。この Ticket は loader 実装そのものではなく、現行 project workflow を public builtin 候補と dogfood/project-local 運用へ分離するための設計・監査 work item として扱う。
|
||||
|
||||
Readiness classification: `spike_needed` / planning-ready。Orchestrator は実装開始ではなく、まず workflow content audit と source/provenance/priority/resource placement の設計判断を行う planning/spike として route できる。後続で loader 実装や workflow content 移行が必要になった場合は、この Ticket の結論から concrete implementation Ticket に分割する。
|
||||
|
||||
Risk flags:
|
||||
|
||||
- `prompt-resource`: workflow 文言は LLM-facing prompt resource と同等に扱う必要がある。
|
||||
- `workflow-source`: builtin / workspace / skill の provenance と priority を誤ると override semantics が曖昧になる。
|
||||
- `public-api`: public builtin workflow の slug と resident advertisement はユーザー向け contract になり得る。
|
||||
- `dogfood-boundary`: Yoi repository 固有の Git/worktree/cargo/nix 運用を public default に混ぜない。
|
||||
- `migration-compat`: `.yoi/ticket.config.toml` の既存 workflow selectors と legacy `ticket-preflight-workflow` 名の扱いを決める必要がある。
|
||||
|
||||
Open questions: blocking な追加質問はない。設計中に複数案が残る場合は、workspace override が builtin より優先されること、LLM-facing text を Rust code に直書きしないこと、optional Git/worktree workflow を default resident にしないことを invariant として扱い、未決定点は後続 Ticket 化または decision record 化する。
|
||||
|
||||
---
|
||||
|
||||
<!-- event: intake_summary author: ticket-intake at: 2026-06-10T11:18:55Z -->
|
||||
|
||||
## Intake summary
|
||||
|
||||
既存 Ticket 00001KTRKZ14C を重複作成せず精査した。対象は現行 `.yoi/workflow/*.md` を public builtin 候補と Yoi repository dogfood/project-local 運用へ分離する設計・監査 work item。Orchestrator は実装開始ではなく planning/spike として route し、workflow content audit、`WorkflowSource::Builtin` 等の provenance、builtin/workspace/skill priority、resident advertisement、resource placement、`.yoi/ticket.config.toml` migration、廃止語彙削除方針を決める。blocking open question はないが、risk flags は prompt-resource / workflow-source / public-api / dogfood-boundary / migration-compat。
|
||||
|
||||
---
|
||||
|
||||
<!-- event: state_changed author: ticket-intake at: 2026-06-10T11:18:55Z from: planning to: ready reason: intake_ready field: state -->
|
||||
|
||||
## State changed
|
||||
|
||||
Intake により、Orchestrator が planning/spike routing できる情報が揃った。実装 side effect はまだ開始しない。
|
||||
|
||||
---
|
||||
Loading…
Reference in New Issue
Block a user