mirror of
https://github.com/xtr-dev/rondevu-server.git
synced 2025-12-12 11:53:24 +00:00
- Update wrangler.toml with new D1 database ID - Add fresh_schema.sql for clean database initialization - Applied schema to fresh D1 database - Server redeployed with correct database binding This resolves the 'table services has no column named service_name' error by ensuring the database has the correct v0.4.1+ schema.
77 lines
2.4 KiB
SQL
77 lines
2.4 KiB
SQL
-- Fresh schema for Rondevu v0.4.1+
|
|
-- This is the complete schema without migration steps
|
|
|
|
-- Drop existing tables if they exist
|
|
DROP TABLE IF EXISTS ice_candidates;
|
|
DROP TABLE IF EXISTS services;
|
|
DROP TABLE IF EXISTS offers;
|
|
DROP TABLE IF EXISTS usernames;
|
|
|
|
-- Offers table
|
|
CREATE TABLE offers (
|
|
id TEXT PRIMARY KEY,
|
|
peer_id TEXT NOT NULL,
|
|
service_fqn TEXT NOT NULL,
|
|
sdp TEXT NOT NULL,
|
|
created_at INTEGER NOT NULL,
|
|
expires_at INTEGER NOT NULL,
|
|
secret TEXT,
|
|
answerer_peer_id TEXT,
|
|
answer_sdp TEXT,
|
|
answered_at INTEGER
|
|
);
|
|
|
|
CREATE INDEX idx_offers_peer ON offers(peer_id);
|
|
CREATE INDEX idx_offers_service_fqn ON offers(service_fqn);
|
|
CREATE INDEX idx_offers_expires ON offers(expires_at);
|
|
CREATE INDEX idx_offers_answerer ON offers(answerer_peer_id);
|
|
CREATE INDEX idx_offers_available ON offers(answerer_peer_id) WHERE answerer_peer_id IS NULL;
|
|
|
|
-- ICE candidates table
|
|
CREATE TABLE ice_candidates (
|
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
offer_id TEXT NOT NULL,
|
|
peer_id TEXT NOT NULL,
|
|
role TEXT NOT NULL CHECK(role IN ('offerer', 'answerer')),
|
|
candidate TEXT NOT NULL,
|
|
created_at INTEGER NOT NULL,
|
|
FOREIGN KEY (offer_id) REFERENCES offers(id) ON DELETE CASCADE
|
|
);
|
|
|
|
CREATE INDEX idx_ice_offer ON ice_candidates(offer_id);
|
|
CREATE INDEX idx_ice_peer ON ice_candidates(peer_id);
|
|
CREATE INDEX idx_ice_role ON ice_candidates(role);
|
|
CREATE INDEX idx_ice_created ON ice_candidates(created_at);
|
|
|
|
-- Usernames table
|
|
CREATE TABLE usernames (
|
|
username TEXT PRIMARY KEY,
|
|
public_key TEXT NOT NULL UNIQUE,
|
|
claimed_at INTEGER NOT NULL,
|
|
expires_at INTEGER NOT NULL,
|
|
last_used INTEGER NOT NULL,
|
|
metadata TEXT,
|
|
CHECK(length(username) >= 3 AND length(username) <= 32)
|
|
);
|
|
|
|
CREATE INDEX idx_usernames_expires ON usernames(expires_at);
|
|
CREATE INDEX idx_usernames_public_key ON usernames(public_key);
|
|
|
|
-- Services table with discovery fields
|
|
CREATE TABLE services (
|
|
id TEXT PRIMARY KEY,
|
|
service_fqn TEXT NOT NULL,
|
|
service_name TEXT NOT NULL,
|
|
version TEXT NOT NULL,
|
|
username TEXT NOT NULL,
|
|
created_at INTEGER NOT NULL,
|
|
expires_at INTEGER NOT NULL,
|
|
FOREIGN KEY (username) REFERENCES usernames(username) ON DELETE CASCADE,
|
|
UNIQUE(service_fqn)
|
|
);
|
|
|
|
CREATE INDEX idx_services_fqn ON services(service_fqn);
|
|
CREATE INDEX idx_services_discovery ON services(service_name, version);
|
|
CREATE INDEX idx_services_username ON services(username);
|
|
CREATE INDEX idx_services_expires ON services(expires_at);
|