use futures_core::future::BoxFuture;
use std::borrow::Cow;
use sqlx_core::error::Error;
use sqlx_core::transaction::TransactionManager;
use crate::{Sqlite, SqliteConnection};
pub struct SqliteTransactionManager;
impl TransactionManager for SqliteTransactionManager {
type Database = Sqlite;
fn begin<'conn>(
conn: &'conn mut SqliteConnection,
statement: Option<Cow<'static, str>>,
) -> BoxFuture<'conn, Result<(), Error>> {
Box::pin(async {
let is_custom_statement = statement.is_some();
conn.worker.begin(statement).await?;
if is_custom_statement {
let mut handle = conn.lock_handle().await?;
if !handle.in_transaction() {
return Err(Error::BeginFailed);
}
}
Ok(())
})
}
fn commit(conn: &mut SqliteConnection) -> BoxFuture<'_, Result<(), Error>> {
Box::pin(conn.worker.commit())
}
fn rollback(conn: &mut SqliteConnection) -> BoxFuture<'_, Result<(), Error>> {
Box::pin(conn.worker.rollback())
}
fn start_rollback(conn: &mut SqliteConnection) {
conn.worker.start_rollback().ok();
}
fn get_transaction_depth(conn: &SqliteConnection) -> usize {
conn.worker.shared.get_transaction_depth()
}
}