fix(doctor): add role beads check with shared definitions (#378)

Role beads (hq-*-role) are templates that define role characteristics.
They are created during gt install but creation may fail silently.
Without role beads, agents fall back to defaults.

Changes:
- Add beads.AllRoleBeadDefs() as single source of truth for role bead definitions
- Update gt install to use shared definitions
- Add doctor check that detects missing role beads (warning, not error)
- Doctor --fix creates missing role beads

Fixes #371

Co-authored-by: julianknutsen <julianknutsen@users.noreply.github>
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
Julian Knutsen
2026-01-12 09:52:38 +00:00
committed by GitHub
parent 77e1199196
commit f6fd76172e
5 changed files with 244 additions and 50 deletions

View File

@@ -92,3 +92,54 @@ func HasLabel(issue *Issue, label string) bool {
}
return false
}
// RoleBeadDef defines a role bead's metadata.
// Used by gt install and gt doctor to create missing role beads.
type RoleBeadDef struct {
ID string // e.g., "hq-witness-role"
Title string // e.g., "Witness Role"
Desc string // Description of the role
}
// AllRoleBeadDefs returns all role bead definitions.
// This is the single source of truth for role beads used by both
// gt install (initial creation) and gt doctor --fix (repair).
func AllRoleBeadDefs() []RoleBeadDef {
return []RoleBeadDef{
{
ID: MayorRoleBeadIDTown(),
Title: "Mayor Role",
Desc: "Role definition for Mayor agents. Global coordinator for cross-rig work.",
},
{
ID: DeaconRoleBeadIDTown(),
Title: "Deacon Role",
Desc: "Role definition for Deacon agents. Daemon beacon for heartbeats and monitoring.",
},
{
ID: DogRoleBeadIDTown(),
Title: "Dog Role",
Desc: "Role definition for Dog agents. Town-level workers for cross-rig tasks.",
},
{
ID: WitnessRoleBeadIDTown(),
Title: "Witness Role",
Desc: "Role definition for Witness agents. Per-rig worker monitor with progressive nudging.",
},
{
ID: RefineryRoleBeadIDTown(),
Title: "Refinery Role",
Desc: "Role definition for Refinery agents. Merge queue processor with verification gates.",
},
{
ID: PolecatRoleBeadIDTown(),
Title: "Polecat Role",
Desc: "Role definition for Polecat agents. Ephemeral workers for batch work dispatch.",
},
{
ID: CrewRoleBeadIDTown(),
Title: "Crew Role",
Desc: "Role definition for Crew agents. Persistent user-managed workspaces.",
},
}
}