summaryrefslogtreecommitdiff
path: root/makima/migrations/20260215000000_create_orders.sql
blob: d13480183c81d1b5191e980ce5ca8e272cd8472e (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
-- Orders system: card-based issue tracker (similar to Linear/Jira/GitHub Issues).
-- Orders represent planned work items (features, bugs, spikes) that can later be
-- attached to directives (as steps) or contracts for execution.

CREATE TABLE orders (
                        id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
                        owner_id UUID NOT NULL REFERENCES owners(id) ON DELETE CASCADE,
                        title VARCHAR(500) NOT NULL,
                        description TEXT,
    -- Priority: critical > high > medium > low > none
                        priority VARCHAR(32) NOT NULL DEFAULT 'medium'
                            CHECK (priority IN ('critical', 'high', 'medium', 'low', 'none')),
    -- Status lifecycle: open -> in_progress -> done | archived
                        status VARCHAR(32) NOT NULL DEFAULT 'open'
                            CHECK (status IN ('open', 'in_progress', 'done', 'archived')),
    -- Type of work item
                        order_type VARCHAR(32) NOT NULL DEFAULT 'feature'
                            CHECK (order_type IN ('feature', 'bug', 'spike', 'chore', 'improvement')),
    -- Flexible labels stored as JSON array of strings
                        labels JSONB NOT NULL DEFAULT '[]',
    -- Optional links to directives, directive steps, and contracts
                        directive_id UUID REFERENCES directives(id) ON DELETE SET NULL,
                        directive_step_id UUID REFERENCES directive_steps(id) ON DELETE SET NULL,
                        contract_id UUID REFERENCES contracts(id) ON DELETE SET NULL,
    -- Repository context
                        repository_url VARCHAR(512),
                        created_at TIMESTAMPTZ NOT NULL DEFAULT NOW(),
                        updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
);

-- Index for listing orders by owner
CREATE INDEX IF NOT EXISTS idx_orders_owner_id ON orders(owner_id);
-- Composite index for filtering by owner + status (common query pattern)
CREATE INDEX IF NOT EXISTS idx_orders_owner_status ON orders(owner_id, status);
-- Index for looking up orders linked to a directive
CREATE INDEX IF NOT EXISTS idx_orders_directive_id ON orders(directive_id);
-- Index for looking up orders linked to a contract
CREATE INDEX IF NOT EXISTS idx_orders_contract_id ON orders(contract_id);