use sqlx::{sqlite::Sqlite, SqliteConnection, Transaction}; use crate::{ clock::DateTime, event::{Instant, Sequence}, }; pub trait Provider { fn sequence(&mut self) -> Sequences; } impl<'c> Provider for Transaction<'c, Sqlite> { fn sequence(&mut self) -> Sequences { Sequences(self) } } pub struct Sequences<'t>(&'t mut SqliteConnection); impl<'c> Sequences<'c> { pub async fn next(&mut self, at: &DateTime) -> Result { let next = sqlx::query_scalar!( r#" update event_sequence set last_value = last_value + 1 returning last_value as "next_value: Sequence" "#, ) .fetch_one(&mut *self.0) .await?; Ok(Instant::new(*at, next)) } pub async fn current(&mut self) -> Result { let next = sqlx::query_scalar!( r#" select last_value as "last_value: Sequence" from event_sequence "#, ) .fetch_one(&mut *self.0) .await?; Ok(next) } }