sqlx_sqlite/
transaction.rs1use futures_core::future::BoxFuture;
2use std::borrow::Cow;
3
4use sqlx_core::error::Error;
5use sqlx_core::transaction::TransactionManager;
6
7use crate::{Sqlite, SqliteConnection};
8
9pub struct SqliteTransactionManager;
11
12impl TransactionManager for SqliteTransactionManager {
13 type Database = Sqlite;
14
15 fn begin<'conn>(
16 conn: &'conn mut SqliteConnection,
17 statement: Option<Cow<'static, str>>,
18 ) -> BoxFuture<'conn, Result<(), Error>> {
19 Box::pin(async {
20 let is_custom_statement = statement.is_some();
21 conn.worker.begin(statement).await?;
22 if is_custom_statement {
23 let mut handle = conn.lock_handle().await?;
25 if !handle.in_transaction() {
26 return Err(Error::BeginFailed);
27 }
28 }
29 Ok(())
30 })
31 }
32
33 fn commit(conn: &mut SqliteConnection) -> BoxFuture<'_, Result<(), Error>> {
34 Box::pin(conn.worker.commit())
35 }
36
37 fn rollback(conn: &mut SqliteConnection) -> BoxFuture<'_, Result<(), Error>> {
38 Box::pin(conn.worker.rollback())
39 }
40
41 fn start_rollback(conn: &mut SqliteConnection) {
42 conn.worker.start_rollback().ok();
43 }
44
45 fn get_transaction_depth(conn: &SqliteConnection) -> usize {
46 conn.worker.shared.get_transaction_depth()
47 }
48}