Migrations: - 016, 017, 019: Replace gen_random_uuid() with uuid_generate_v7() - All UUID tables now use custom uuid_generate_v7() function Backend: - Create internal/utils/uuid/uuid.go with V7() function (RFC 9562) - Update storage_handler.go to use internal uuid.V7() - Remove dependency on google/uuid for file naming All new UUIDs in the system are now UUID v7 (time-ordered)
25 lines
1,000 B
SQL
25 lines
1,000 B
SQL
DROP TABLE IF EXISTS ticket_messages;
|
|
DROP TABLE IF EXISTS tickets;
|
|
|
|
CREATE TABLE tickets (
|
|
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
user_id INTEGER NOT NULL REFERENCES users(id) ON DELETE CASCADE,
|
|
subject VARCHAR(255) NOT NULL,
|
|
status VARCHAR(50) NOT NULL DEFAULT 'open', -- open, in_progress, closed
|
|
priority VARCHAR(50) NOT NULL DEFAULT 'medium', -- low, medium, high
|
|
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
|
);
|
|
|
|
CREATE INDEX idx_tickets_user_id ON tickets(user_id);
|
|
CREATE INDEX idx_tickets_status ON tickets(status);
|
|
|
|
CREATE TABLE ticket_messages (
|
|
id UUID PRIMARY KEY DEFAULT uuid_generate_v7(),
|
|
ticket_id UUID NOT NULL REFERENCES tickets(id) ON DELETE CASCADE,
|
|
user_id INTEGER NOT NULL REFERENCES users(id) ON DELETE CASCADE, -- Sender
|
|
message TEXT NOT NULL,
|
|
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP
|
|
);
|
|
|
|
CREATE INDEX idx_ticket_messages_ticket_id ON ticket_messages(ticket_id);
|