22 lines
583 B
Rust
22 lines
583 B
Rust
use anyhow::{bail, Result};
|
|
|
|
use rusqlite::Connection;
|
|
|
|
pub fn setup_connection_and_for_replication(path: String) -> Result<Connection> {
|
|
let db = Connection::open(path)?;
|
|
|
|
let mode: String = db.pragma_update_and_check(None, "journal_mode", "WAL", |row| row.get(0))?;
|
|
|
|
if mode != "wal" {
|
|
bail!("couldn't set journaling to WAL");
|
|
}
|
|
|
|
db.pragma_update(None, "busy_timeout", "5000")?;
|
|
db.pragma_update(None, "synchronous", "NORMAL")?;
|
|
db.pragma_update(None, "foreign_keys", "ON")?;
|
|
|
|
db.execute_batch(include_str!("../schema.sql"))?;
|
|
|
|
Ok(db)
|
|
}
|