use crate::database::Database; use crate::error::Error; use crate::pool::{MaybePoolConnection, Pool, PoolConnection}; use crate::transaction::Transaction; use futures_core::future::BoxFuture; use std::ops::{Deref, DerefMut}; pub trait Acquire<'c> { type Database: Database; type Connection: Deref::Connection> + DerefMut + Send; fn acquire(self) -> BoxFuture<'c, Result>; fn begin(self) -> BoxFuture<'c, Result, Error>>; } impl<'a, DB: Database> Acquire<'a> for &'_ Pool { type Database = DB; type Connection = PoolConnection; fn acquire(self) -> BoxFuture<'static, Result> { Box::pin(self.acquire()) } fn begin(self) -> BoxFuture<'static, Result, Error>> { let conn = self.acquire(); Box::pin(async move { Transaction::begin(MaybePoolConnection::PoolConnection(conn.await?)).await }) } } #[allow(unused_macros)] macro_rules! impl_acquire { ($DB:ident, $C:ident) => { impl<'c> crate::acquire::Acquire<'c> for &'c mut $C { type Database = $DB; type Connection = &'c mut <$DB as crate::database::Database>::Connection; #[inline] fn acquire( self, ) -> futures_core::future::BoxFuture<'c, Result> { Box::pin(futures_util::future::ok(self)) } #[inline] fn begin( self, ) -> futures_core::future::BoxFuture< 'c, Result, crate::error::Error>, > { crate::transaction::Transaction::begin(self) } } impl<'c> crate::acquire::Acquire<'c> for &'c mut crate::pool::PoolConnection<$DB> { type Database = $DB; type Connection = &'c mut <$DB as crate::database::Database>::Connection; #[inline] fn acquire( self, ) -> futures_core::future::BoxFuture<'c, Result> { Box::pin(futures_util::future::ok(&mut **self)) } #[inline] fn begin( self, ) -> futures_core::future::BoxFuture< 'c, Result, crate::error::Error>, > { crate::transaction::Transaction::begin(&mut **self) } } impl<'c, 't> crate::acquire::Acquire<'t> for &'t mut crate::transaction::Transaction<'c, $DB> { type Database = $DB; type Connection = &'t mut <$DB as crate::database::Database>::Connection; #[inline] fn acquire( self, ) -> futures_core::future::BoxFuture<'t, Result> { Box::pin(futures_util::future::ok(&mut **self)) } #[inline] fn begin( self, ) -> futures_core::future::BoxFuture< 't, Result, crate::error::Error>, > { crate::transaction::Transaction::begin(&mut **self) } } }; }