summaryrefslogtreecommitdiff
path: root/makima/migrations/20260205000000_chain_directives.sql
blob: d3d29c799d69b608602ad9160c47227f4da1feb6 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
-- Chain Directives: Structured specification documents that drive chain creation and evaluation
-- Contract Evaluations: LLM evaluation results for completed contracts

-- =============================================================================
-- New Tables
-- =============================================================================

-- Chain directives: formal specification documents for directive-driven chains
CREATE TABLE IF NOT EXISTS chain_directives (
    id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
    chain_id UUID NOT NULL REFERENCES chains(id) ON DELETE CASCADE,
    version INTEGER NOT NULL DEFAULT 1,

    -- Directive content (structured JSON)
    -- Requirements: [{ id, title, description, priority, category, parentId? }]
    requirements JSONB NOT NULL DEFAULT '[]',
    -- Acceptance criteria: [{ id, requirementIds[], description, testable, verificationMethod }]
    acceptance_criteria JSONB NOT NULL DEFAULT '[]',
    -- Constraints: [{ id, type, description, impact }]
    constraints JSONB NOT NULL DEFAULT '[]',
    -- External dependencies: [{ id, name, type, status, requiredBy[] }]
    external_dependencies JSONB NOT NULL DEFAULT '[]',

    -- Metadata
    source_type VARCHAR(32) NOT NULL DEFAULT 'llm_generated',  -- 'manual', 'llm_generated', 'imported'

    created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
    updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),

    CONSTRAINT chain_directives_chain_unique UNIQUE (chain_id)
);

CREATE INDEX IF NOT EXISTS idx_chain_directives_chain_id ON chain_directives(chain_id);

-- Contract evaluations: LLM evaluation results after contract completion
CREATE TABLE IF NOT EXISTS contract_evaluations (
    id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
    contract_id UUID NOT NULL REFERENCES contracts(id) ON DELETE CASCADE,
    chain_id UUID REFERENCES chains(id) ON DELETE SET NULL,
    chain_contract_id UUID REFERENCES chain_contracts(id) ON DELETE SET NULL,

    -- Evaluation metadata
    evaluation_number INTEGER NOT NULL DEFAULT 1,
    evaluator_model VARCHAR(100),

    -- Results
    passed BOOLEAN NOT NULL,
    overall_score DECIMAL(3,2),  -- 0.00 to 1.00

    -- Structured feedback
    -- criteria_results: [{ criterionId, criterionText, passed, score, feedback, evidence[] }]
    criteria_results JSONB NOT NULL DEFAULT '[]',
    summary_feedback TEXT NOT NULL,
    rework_instructions TEXT,

    -- Context snapshot for reproducibility
    directive_snapshot JSONB,
    deliverables_snapshot JSONB,

    started_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
    completed_at TIMESTAMPTZ,
    created_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
);

CREATE INDEX IF NOT EXISTS idx_contract_evaluations_contract ON contract_evaluations(contract_id);
CREATE INDEX IF NOT EXISTS idx_contract_evaluations_chain ON contract_evaluations(chain_id);
CREATE INDEX IF NOT EXISTS idx_contract_evaluations_chain_contract ON contract_evaluations(chain_contract_id);

-- =============================================================================
-- Table Modifications
-- =============================================================================

-- Extend chains table with directive support
ALTER TABLE chains
    ADD COLUMN IF NOT EXISTS directive_contract_id UUID REFERENCES contracts(id) ON DELETE SET NULL,
    ADD COLUMN IF NOT EXISTS directive_document TEXT,
    ADD COLUMN IF NOT EXISTS evaluation_enabled BOOLEAN NOT NULL DEFAULT true,
    ADD COLUMN IF NOT EXISTS default_pass_threshold DECIMAL(3,2) DEFAULT 0.80,
    ADD COLUMN IF NOT EXISTS default_max_retries INTEGER DEFAULT 3;

CREATE INDEX IF NOT EXISTS idx_chains_directive_contract ON chains(directive_contract_id) WHERE directive_contract_id IS NOT NULL;

-- Extend contracts table with chain directive support
ALTER TABLE contracts
    ADD COLUMN IF NOT EXISTS spawned_chain_id UUID REFERENCES chains(id) ON DELETE SET NULL,
    ADD COLUMN IF NOT EXISTS is_chain_directive BOOLEAN NOT NULL DEFAULT FALSE;

CREATE INDEX IF NOT EXISTS idx_contracts_spawned_chain ON contracts(spawned_chain_id) WHERE spawned_chain_id IS NOT NULL;
CREATE INDEX IF NOT EXISTS idx_contracts_is_directive ON contracts(is_chain_directive) WHERE is_chain_directive = true;

-- Extend chain_contracts table with evaluation tracking
ALTER TABLE chain_contracts
    ADD COLUMN IF NOT EXISTS evaluation_status VARCHAR(50) NOT NULL DEFAULT 'pending',
    ADD COLUMN IF NOT EXISTS evaluation_retry_count INTEGER NOT NULL DEFAULT 0,
    ADD COLUMN IF NOT EXISTS max_evaluation_retries INTEGER NOT NULL DEFAULT 3,
    ADD COLUMN IF NOT EXISTS last_evaluation_id UUID REFERENCES contract_evaluations(id) ON DELETE SET NULL,
    ADD COLUMN IF NOT EXISTS rework_feedback TEXT,
    ADD COLUMN IF NOT EXISTS rework_started_at TIMESTAMPTZ,
    ADD COLUMN IF NOT EXISTS original_completion_at TIMESTAMPTZ;

-- Extend chain_contract_definitions table with requirement traceability
ALTER TABLE chain_contract_definitions
    ADD COLUMN IF NOT EXISTS requirement_ids TEXT[] DEFAULT '{}',
    ADD COLUMN IF NOT EXISTS acceptance_criteria JSONB DEFAULT '[]',
    ADD COLUMN IF NOT EXISTS evaluation_enabled BOOLEAN NOT NULL DEFAULT true,
    ADD COLUMN IF NOT EXISTS pass_threshold DECIMAL(3,2) DEFAULT 0.80;

-- =============================================================================
-- Comments
-- =============================================================================

COMMENT ON TABLE chain_directives IS 'Formal directive documents that drive chain creation and contract evaluation';
COMMENT ON COLUMN chain_directives.requirements IS 'Enumerated requirements with IDs for traceability';
COMMENT ON COLUMN chain_directives.acceptance_criteria IS 'Testable criteria mapped to requirements';
COMMENT ON COLUMN chain_directives.constraints IS 'Technical, business, time, or resource constraints';
COMMENT ON COLUMN chain_directives.external_dependencies IS 'External APIs, services, or data dependencies';

COMMENT ON TABLE contract_evaluations IS 'LLM evaluation results after contract completion within a chain';
COMMENT ON COLUMN contract_evaluations.criteria_results IS 'Per-criterion evaluation results with scores and feedback';
COMMENT ON COLUMN contract_evaluations.directive_snapshot IS 'Snapshot of directive at evaluation time for audit';

COMMENT ON COLUMN chains.directive_contract_id IS 'Reference to the directive contract that created/orchestrates this chain';
COMMENT ON COLUMN chains.evaluation_enabled IS 'Whether LLM evaluation is enabled after contract completion';

COMMENT ON COLUMN contracts.spawned_chain_id IS 'Reference to chain spawned by this directive contract';
COMMENT ON COLUMN contracts.is_chain_directive IS 'Whether this contract is a chain directive orchestrator';

COMMENT ON COLUMN chain_contracts.evaluation_status IS 'Evaluation state: pending, evaluating, passed, failed, rework, escalated';
COMMENT ON COLUMN chain_contracts.evaluation_retry_count IS 'Number of evaluation retry attempts';