pub struct LibsqlStorage<T, C> { /* private fields */ }Expand description
LibsqlStorage is a storage backend for apalis using libsql as the database.
Implementations§
Source§impl<T> LibsqlStorage<T, ()>
impl<T> LibsqlStorage<T, ()>
Sourcepub fn new(db: &'static Database) -> LibsqlStorage<T, JsonCodec<CompactType>>
pub fn new(db: &'static Database) -> LibsqlStorage<T, JsonCodec<CompactType>>
Create a new LibsqlStorage with default JSON codec
Sourcepub fn new_with_config(
db: &'static Database,
config: Config,
) -> LibsqlStorage<T, JsonCodec<CompactType>>
pub fn new_with_config( db: &'static Database, config: Config, ) -> LibsqlStorage<T, JsonCodec<CompactType>>
Create a new LibsqlStorage with custom config
Source§impl<T, C> LibsqlStorage<T, C>
impl<T, C> LibsqlStorage<T, C>
Sourcepub async fn setup(&self) -> Result<(), LibsqlError>
pub async fn setup(&self) -> Result<(), LibsqlError>
Setup the database schema by running migrations
Sourcepub fn with_codec<D>(self) -> LibsqlStorage<T, D>
pub fn with_codec<D>(self) -> LibsqlStorage<T, D>
Change the codec used for serialization/deserialization
Source§impl<Args, Decode> LibsqlStorage<Args, Decode>
impl<Args, Decode> LibsqlStorage<Args, Decode>
Sourcepub fn poll_default(
self,
worker: &WorkerContext,
) -> impl Stream<Item = Result<Option<LibsqlTask<CompactType>>, LibsqlError>> + Send + 'static
pub fn poll_default( self, worker: &WorkerContext, ) -> impl Stream<Item = Result<Option<LibsqlTask<CompactType>>, LibsqlError>> + Send + 'static
Poll for tasks using the default polling strategy
Sourcepub async fn ack<Res>(
&mut self,
task_id: &Ulid,
result: Result<Res, BoxDynError>,
) -> Result<(), LibsqlError>
pub async fn ack<Res>( &mut self, task_id: &Ulid, result: Result<Res, BoxDynError>, ) -> Result<(), LibsqlError>
Acknowledge a task completion
Trait Implementations§
Source§impl<Args, Decode> Backend for LibsqlStorage<Args, Decode>
impl<Args, Decode> Backend for LibsqlStorage<Args, Decode>
Source§type Context = SqlContext
type Context = SqlContext
Context associated with each task.
Source§type Error = LibsqlError
type Error = LibsqlError
The error type returned by backend operations
Source§type Stream = Pin<Box<dyn Stream<Item = Result<Option<Task<Args, SqlContext, Ulid>>, LibsqlError>> + Send>>
type Stream = Pin<Box<dyn Stream<Item = Result<Option<Task<Args, SqlContext, Ulid>>, LibsqlError>> + Send>>
A stream of tasks provided by the backend.
Source§type Beat = Pin<Box<dyn Stream<Item = Result<(), LibsqlError>> + Send>>
type Beat = Pin<Box<dyn Stream<Item = Result<(), LibsqlError>> + Send>>
A stream representing heartbeat signals.
Source§type Layer = Stack<LockTaskLayer, AcknowledgeLayer<LibsqlAck>>
type Layer = Stack<LockTaskLayer, AcknowledgeLayer<LibsqlAck>>
The type representing backend middleware layer.
Source§fn heartbeat(&self, worker: &WorkerContext) -> Self::Beat
fn heartbeat(&self, worker: &WorkerContext) -> Self::Beat
Returns a heartbeat stream for the given worker.
Source§fn middleware(&self) -> Self::Layer
fn middleware(&self) -> Self::Layer
Returns the backend’s middleware layer.
Source§fn poll(self, worker: &WorkerContext) -> Self::Stream
fn poll(self, worker: &WorkerContext) -> Self::Stream
Polls the backend for tasks for the given worker.
Source§impl<Args, Decode> BackendExt for LibsqlStorage<Args, Decode>
impl<Args, Decode> BackendExt for LibsqlStorage<Args, Decode>
Source§type CompactStream = Pin<Box<dyn Stream<Item = Result<Option<Task<Vec<u8>, SqlContext, Ulid>>, LibsqlError>> + Send>>
type CompactStream = Pin<Box<dyn Stream<Item = Result<Option<Task<Vec<u8>, SqlContext, Ulid>>, LibsqlError>> + Send>>
A stream of encoded tasks provided by the backend.
Source§fn poll_compact(self, worker: &WorkerContext) -> Self::CompactStream
fn poll_compact(self, worker: &WorkerContext) -> Self::CompactStream
Polls the backend for encoded tasks for the given worker.
Source§impl<T, C> Clone for LibsqlStorage<T, C>
impl<T, C> Clone for LibsqlStorage<T, C>
Source§impl<T, C> Debug for LibsqlStorage<T, C>
impl<T, C> Debug for LibsqlStorage<T, C>
Source§impl<Args, Codec> Sink<Task<Vec<u8>, SqlContext, Ulid>> for LibsqlStorage<Args, Codec>
Implementation of Sink for LibsqlStorage to push tasks
impl<Args, Codec> Sink<Task<Vec<u8>, SqlContext, Ulid>> for LibsqlStorage<Args, Codec>
Implementation of Sink for LibsqlStorage to push tasks
Source§type Error = LibsqlError
type Error = LibsqlError
The type of value produced by the sink when an error occurs.
Source§fn poll_ready(
self: Pin<&mut Self>,
cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>
fn poll_ready( self: Pin<&mut Self>, cx: &mut Context<'_>, ) -> Poll<Result<(), Self::Error>>
Attempts to prepare the
Sink to receive a value. Read moreSource§fn start_send(
self: Pin<&mut Self>,
item: LibsqlTask<CompactType>,
) -> Result<(), Self::Error>
fn start_send( self: Pin<&mut Self>, item: LibsqlTask<CompactType>, ) -> Result<(), Self::Error>
Begin the process of sending a value to the sink.
Each call to this function must be preceded by a successful call to
poll_ready which returned Poll::Ready(Ok(())). Read moreimpl<'pin, T, C> Unpin for LibsqlStorage<T, C>where
PinnedFieldsOf<__LibsqlStorage<'pin, T, C>>: Unpin,
Auto Trait Implementations§
impl<T, C> Freeze for LibsqlStorage<T, C>
impl<T, C> !RefUnwindSafe for LibsqlStorage<T, C>
impl<T, C> Send for LibsqlStorage<T, C>
impl<T, C> Sync for LibsqlStorage<T, C>
impl<T, C> !UnwindSafe for LibsqlStorage<T, C>
Blanket Implementations§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
🔬This is a nightly-only experimental API. (
clone_to_uninit)Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::RequestSource§impl<T, Item> SinkExt<Item> for T
impl<T, Item> SinkExt<Item> for T
Source§fn with<U, Fut, F, E>(self, f: F) -> With<Self, Item, U, Fut, F>
fn with<U, Fut, F, E>(self, f: F) -> With<Self, Item, U, Fut, F>
Composes a function in front of the sink. Read more
Source§fn with_flat_map<U, St, F>(self, f: F) -> WithFlatMap<Self, Item, U, St, F>
fn with_flat_map<U, St, F>(self, f: F) -> WithFlatMap<Self, Item, U, St, F>
Composes a function in front of the sink. Read more
Source§fn sink_map_err<E, F>(self, f: F) -> SinkMapErr<Self, F>
fn sink_map_err<E, F>(self, f: F) -> SinkMapErr<Self, F>
Transforms the error returned by the sink.
Source§fn sink_err_into<E>(self) -> SinkErrInto<Self, Item, E>
fn sink_err_into<E>(self) -> SinkErrInto<Self, Item, E>
Map this sink’s error to a different error type using the
Into trait. Read moreSource§fn buffer(self, capacity: usize) -> Buffer<Self, Item>where
Self: Sized,
fn buffer(self, capacity: usize) -> Buffer<Self, Item>where
Self: Sized,
Adds a fixed-size buffer to the current sink. Read more
Source§fn flush(&mut self) -> Flush<'_, Self, Item>where
Self: Unpin,
fn flush(&mut self) -> Flush<'_, Self, Item>where
Self: Unpin,
Flush the sink, processing all pending items. Read more
Source§fn send(&mut self, item: Item) -> Send<'_, Self, Item>where
Self: Unpin,
fn send(&mut self, item: Item) -> Send<'_, Self, Item>where
Self: Unpin,
A future that completes after the given item has been fully processed
into the sink, including flushing. Read more
Source§fn feed(&mut self, item: Item) -> Feed<'_, Self, Item>where
Self: Unpin,
fn feed(&mut self, item: Item) -> Feed<'_, Self, Item>where
Self: Unpin,
A future that completes after the given item has been received
by the sink. Read more
Source§fn send_all<'a, St>(&'a mut self, stream: &'a mut St) -> SendAll<'a, Self, St>
fn send_all<'a, St>(&'a mut self, stream: &'a mut St) -> SendAll<'a, Self, St>
A future that completes after the given stream has been fully processed
into the sink, including flushing. Read more
Source§fn right_sink<Si1>(self) -> Either<Si1, Self>
fn right_sink<Si1>(self) -> Either<Si1, Self>
Source§fn poll_ready_unpin(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>where
Self: Unpin,
fn poll_ready_unpin(
&mut self,
cx: &mut Context<'_>,
) -> Poll<Result<(), Self::Error>>where
Self: Unpin,
A convenience method for calling
Sink::poll_ready on Unpin
sink types.Source§fn start_send_unpin(&mut self, item: Item) -> Result<(), Self::Error>where
Self: Unpin,
fn start_send_unpin(&mut self, item: Item) -> Result<(), Self::Error>where
Self: Unpin,
A convenience method for calling
Sink::start_send on Unpin
sink types.