Files
packager/rust/src/sqlite.rs

50 lines
1.3 KiB
Rust
Raw Normal View History

2023-08-29 21:34:01 +02:00
use std::time;
2023-08-29 21:34:01 +02:00
use tracing::Instrument;
2023-08-29 21:34:00 +02:00
use sqlx::sqlite::{SqliteConnectOptions, SqlitePoolOptions};
2023-08-29 21:34:01 +02:00
use sqlx::ConnectOptions;
2023-08-29 21:34:00 +02:00
pub use sqlx::{Pool, Sqlite};
use std::str::FromStr as _;
use crate::StartError;
#[tracing::instrument]
2023-08-29 21:34:00 +02:00
pub async fn init_database_pool(url: &str) -> Result<Pool<Sqlite>, StartError> {
2023-08-29 21:34:01 +02:00
async {
SqlitePoolOptions::new()
.max_connections(5)
.connect_with(
SqliteConnectOptions::from_str(url)?
.log_statements(log::LevelFilter::Debug)
.log_slow_statements(log::LevelFilter::Warn, time::Duration::from_millis(100))
.pragma("foreign_keys", "1"),
)
.await
}
.instrument(tracing::info_span!("packager::sql::pool"))
.await
.map_err(Into::into)
2023-08-29 21:34:00 +02:00
}
#[tracing::instrument]
2023-08-29 21:34:00 +02:00
pub async fn migrate(url: &str) -> Result<(), StartError> {
2023-08-29 21:34:01 +02:00
async {
let pool = SqlitePoolOptions::new()
.max_connections(5)
.connect_with(
SqliteConnectOptions::from_str(url)?
.pragma("foreign_keys", "0")
.log_statements(log::LevelFilter::Debug),
)
.await?;
sqlx::migrate!().run(&pool).await
}
.instrument(tracing::info_span!("packager::sql::migrate"))
.await?;
2023-08-29 21:34:01 +02:00
2023-08-29 21:34:00 +02:00
Ok(())
}