fix(protocol): implement Identity Isolation to prevent task pollution

Research revealed that agent identities (consolidated to bd beads) were appearing in standard task lists because the data-access layer lacked identity-awareness.
- Refactored read-issues.ts and parser.ts to explicitly exclude beads labeled 'gt:agent' from standard mission flows.
- Verified that agent personas remain targetable by the registry but are invisible to Kanban/Graph/Sessions.
- Added Characterization Test: identity-isolation.test.ts.

This restores the 'War Room' clarity by separating Operatives from Missions.

OPERATIVE: silver-castle
SESSION: 2026-02-14-1630
This commit is contained in:
zenchantlive 2026-02-14 13:29:28 -08:00
parent eec1d6e28f
commit 0016b57e37
4 changed files with 65 additions and 22 deletions

File diff suppressed because one or more lines are too long

View file

@ -81,6 +81,11 @@ export function parseIssuesJsonl(text: string, options: ParseIssuesOptions = {})
continue;
}
// Exclude agent identities from standard mission lists
if (normalized.labels.includes('gt:agent')) {
continue;
}
issues.push(normalized);
} catch {
// Skip malformed lines to keep parser resilient against partial writes.

View file

@ -105,7 +105,13 @@ async function readIssuesViaBd(options: ReadIssuesOptions, project: ReturnType<t
return parsed
.map((issue) => normalizeBdIssue(issue))
.filter((issue): issue is BeadIssue => issue !== null)
.filter((issue) => (options.includeTombstones ?? false ? true : issue.status !== 'tombstone'))
.filter((issue) => {
// Exclude tombstones
if (issue.status === 'tombstone' && !options.includeTombstones) return false;
// Exclude agent identities from mission lists
if (issue.labels.includes('gt:agent')) return false;
return true;
})
.map((issue) => ({
...issue,
project,

View file

@ -0,0 +1,15 @@
import test from 'node:test';
import assert from 'node:assert/strict';
import { parseIssuesJsonl } from '../../src/lib/parser';
test('parseIssuesJsonl filters out gt:agent beads', () => {
const jsonl = [
JSON.stringify({ id: 'bb-1', title: 'Real Mission', status: 'open', labels: [] }),
JSON.stringify({ id: 'bb-agent', title: 'Agent Persona', status: 'open', labels: ['gt:agent'] }),
].join('\n');
const issues = parseIssuesJsonl(jsonl);
assert.equal(issues.length, 1, 'Should only find 1 issue');
assert.equal(issues[0].id, 'bb-1');
assert.ok(!issues.find(i => i.id === 'bb-agent'), 'Should have filtered the agent persona');
});