caretta-sync/core/src/data/local/migration/v1.rs

38 lines
1.5 KiB
Rust
Raw Normal View History

2025-09-03 07:41:11 +09:00
use rusqlite::{Error, Connection};
2025-09-03 06:20:34 +09:00
2025-09-03 07:41:11 +09:00
pub fn migrate(con: &mut Connection) -> Result<(), Error>{
2025-09-03 06:20:34 +09:00
let tx = con.transaction()?;
2025-09-03 07:41:11 +09:00
tx.execute_batch(
"BEGIN;
CREATE TABLE peer (
id INTEGER PRIMARY KEY,
libp2p_peer_id TEXT UNIQUE NOT NULL,
created_at TEXT NOT NULL,
updated_at TEXT NOT NULL,
);
CREATE INDEX idx_peer_created_at ON peer(created_at);
CREATE INDEX idx_peer_updated_at ON peer(updated_at);
CREATE TABLE address (
id INTEGER PRIMARY KEY,
peer_id INTEGER NOT NULL,
multiaddr TEXT UNIQUE NOT NULL,
created_at TEXT NOT NULL,
updated_at TEXT NOT NULL,
protocol TEXT NOT NULL,
FOREIGN KEY(peer_id) REFERENCES peer(id)
);
CREATE INDEX idx_address_created_at ON address(created_at);
CREATE INDEX idx_address_updated_at ON address(updated_at);
CREATE TABLE authorized_peer (
id INTEGER PRIMARY KEY,
peer_id INTEGER NOT NULL UNIQUE,
synced_at TEXT,
created_at TEXT NOT NULL,
updated_at TEXT NOT NULL,
FOREIGN KEY(peer_id) REFERENCES peer(id)
)",
2025-09-03 06:20:34 +09:00
)?;
tx.pragma_update(None, "user_version", 1)?;
tx.commit()?;
2025-09-03 07:41:11 +09:00
Ok(())
2025-09-03 06:20:34 +09:00
}