feat(agent): complete proposal review api #32
No reviewers
Labels
No labels
3plus3-followup
agent/claude-code
agent/codex
agent/hermes
agent/iskra
agent/ollama
agent/patchwarden
analytics
api
cockpit
dependency/blocked
dependency/blocks-others
dependency/cross-repo
dependency/needs-confirmation
docs
domain:agents
domain:ci
domain:docs
domain:forgejo
domain:infra
domain:memory
domain:runtime
domain:signal
domain:ux
flow/architecture
flow/blocked
flow/deployed
flow/done
flow/implementation
flow/intake
flow/maintained
flow/observed
flow/ready
flow/refining
flow/retired
flow/review
gemini-flash
judge/codex-candidate
judge/hermes-candidate
judge/low-confidence
judge/needs-refinement
judge/operator-needed
judge/p0
judge/p1
judge/p2
judge/p3
judge/park
judge/patchwarden-candidate
judge/stale-priority
kind/adr
kind/bug
kind/chore
kind/feature
kind/infra
kind/ops
kind/refactor
kind/research
leviathan
mcp
merge/auto
merge/manual
merge/manual-dependency-conflict
merge/manual-failing-tests
merge/manual-merge-conflict
merge/manual-missing-review
merge/manual-operator-preference
merge/manual-red-zone
merge/manual-security-sensitive
merge/manual-unclear-scope
merge/manual-unknown
mode:operator-only
mode:patchwarden-iskra-approved
mode:safe-auto
observed/erroring
observed/needs-followup
observed/pending
observed/retire-candidate
observed/unused
observed/used
ops
priority:p0
priority:p1
priority:p2
priority:p3
review:claude-reviewed
review:codex-reviewed
review:dziadek-reviewed
review:needs-human
safety
safety:external-write
safety:no-prod-mutation
safety:prod-impact
safety:secret-touch
scout
security
size/large
size/medium
size/small
size/tiny
size/unknown
small-task
source/adr
source/agent-generated
source/manual
source/operator-chat
source/voice-note
status:blocked
status:codex-ready
status:merged:pending-evidence
status:needs-evidence
status:operator-needed
status:parked
tests
tier:0-platform-substrate
tier:1-iskra-value-layer
tier:2-tools-products-modules
type:bug
type:chore
type:docs
type:feat
type:policy
type:research
ui
No milestone
No project
No assignees
2 participants
Notifications
Due date
No due date set.
Dependencies
No dependencies set.
Reference
pdurlej/kan-ductor!32
Loading…
Add table
Add a link
Reference in a new issue
No description provided.
Delete branch "codex/agent-proposal-review-api"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
Canary status: missing — fire 3+3 review before merge
Summary
Completes the proposal-review API layer so Piotr can list/read/approve/reject Iskra proposals and agents can apply approved proposals idempotently.
Closes #8.
Scope
listProposalsandgetProposalAPI routes.approveProposalandrejectProposal.applyApprovedUpdatereplay safely by idempotency key without duplicating actions.docs/agent-mcp-contract.md.Non-goals
Spec sources read
docs/kan-ductor-working-pr-plan.mddocs/agent-mcp-contract.mdpackages/api/src/routers/agent.tspackages/db/src/repository/agent.repo.tsTests / smoke
pnpm --filter @kan/db buildpnpm --filter @kan/db typecheckpnpm --filter @kan/api typecheckpnpm --filter @kan/mcp typecheckpnpm --filter @kan/api test -- agent.test.ts integration-tests/agent.integration.test.tspnpm exec prettier --check packages/db/src/repository/agent.repo.ts packages/api/src/routers/agent.ts packages/api/src/routers/agent.test.ts packages/api/integration-tests/agent.integration.test.ts docs/agent-mcp-contract.mdgit diff --checkRollback
Revert commit
2f33c12from this branch. No schema migration is included in this PR.Owner gates
3+3 Review Result
Status: NOT READY
Review lanes completed: tech-ollama-1, tech-ollama-2, tech-codex, product-ollama-1, product-ollama-2, product-claude-opus.
Deterministic checks on current stack tip:
@kan/dbtypecheck/build@kan/sharedtypecheck/build@kan/mcptypecheck/build@kan/apitypecheck/build and focused agent tests: 28/28apps/web/src/views/card/components/ActivityList.tsx:374unusedisAdmin@kan/web typecheckstill has existing bootstrap/workspace typing errorsCanary gate: current automated canary is not green for the draft stack; treat this as a review/checkpoint result, not merge approval.
Review notes:
War-room fix 2026-05-10 — Prof Opus
Operator pinged: PR #32 stale-conflict status. Codex tokens out, ja war-room operator.
Diagnosis: PR base był
codex/agent-machine-identities(head branch of PR #28), który zmergował się do main jako #28. Forgejo nie auto-pivots base po parent merge — base SHA pozostała na pre-merge state, conflict-check dalej szła vs stary base.Fix:
git merge origin/mainw head branch (poszło czysto bez konfliktów — main + PR #32 changes nie overlap)8552fb5)codex/agent-machine-identities→mainStatus: mergeable=true. Ready do merge.
Implication dla pozostałego chainu (#33-#50): każdy PR może wymagać podobnego pivot po parent merge. Forgejo's "Update branch" button może auto-handle jeśli klikniesz, ALE base ref zostaje na old branch — żeby pivot na main, edit base manually w UI lub poproś mnie o batch-pivot.
— Prof Opus 🦍🎓 (war-room continuation, Codex out do 2026-05-12 00:38)