pub struct SqliteBackedCache {
    pub connection: Arc<Mutex<Connection>>,
    pub cache_storage_dir: PathBuf,
}

Fields§

§connection: Arc<Mutex<Connection>>§cache_storage_dir: PathBuf

Implementations§

source§

impl SqliteBackedCache

source

pub fn new(cache_storage_dir: PathBuf) -> Self

Trait Implementations§

source§

impl Cache for SqliteBackedCache

source§

fn storage_open<'life0, 'async_trait>( &'life0 self, cache_name: String ) -> Pin<Box<dyn Future<Output = Result<i64, AnyError>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Open a cache storage. Internally, this creates a row in the sqlite db if the cache doesn’t exist and returns the internal id of the cache.

source§

fn storage_has<'life0, 'async_trait>( &'life0 self, cache_name: String ) -> Pin<Box<dyn Future<Output = Result<bool, AnyError>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Check if a cache with the provided name exists. Note: this doesn’t check the disk, it only checks the sqlite db.

source§

fn storage_delete<'life0, 'async_trait>( &'life0 self, cache_name: String ) -> Pin<Box<dyn Future<Output = Result<bool, AnyError>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

Delete a cache storage. Internally, this deletes the row in the sqlite db.

source§

fn put<'life0, 'async_trait>( &'life0 self, request_response: CachePutRequest ) -> Pin<Box<dyn Future<Output = Result<Option<Rc<dyn Resource>>, AnyError>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

source§

fn match<'life0, 'async_trait>( &'life0 self, request: CacheMatchRequest ) -> Pin<Box<dyn Future<Output = Result<Option<(CacheMatchResponseMeta, Option<Rc<dyn Resource>>)>, AnyError>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

source§

fn delete<'life0, 'async_trait>( &'life0 self, request: CacheDeleteRequest ) -> Pin<Box<dyn Future<Output = Result<bool, AnyError>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait,

source§

impl Clone for SqliteBackedCache

source§

fn clone(&self) -> SqliteBackedCache

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Resource for SqliteBackedCache

source§

fn name(&self) -> Cow<'_, str>

Returns a string representation of the resource which is made available to JavaScript code through op_resources. The default implementation returns the Rust type name, but specific resource types may override this trait method.
source§

fn read( self: Rc<Self>, limit: usize ) -> Pin<Box<dyn Future<Output = Result<BufView, Error>> + 'static, Global>>

Read a single chunk of data from the resource. This operation returns a BufView that represents the data that was read. If a zero length buffer is returned, it indicates that the resource has reached EOF. Read more
source§

fn read_byob( self: Rc<Self>, buf: BufMutView ) -> Pin<Box<dyn Future<Output = Result<(usize, BufMutView), Error>> + 'static, Global>>

Read a single chunk of data from the resource into the provided BufMutView. Read more
source§

fn write( self: Rc<Self>, buf: BufView ) -> Pin<Box<dyn Future<Output = Result<WriteOutcome, Error>> + 'static, Global>>

Write a single chunk of data to the resource. The operation may not be able to write the entire chunk, in which case it should return the number of bytes written. Additionally it should return the BufView that was passed in. Read more
source§

fn write_all( self: Rc<Self>, view: BufView ) -> Pin<Box<dyn Future<Output = Result<(), Error>> + 'static, Global>>

Write an entire chunk of data to the resource. Unlike write(), this will ensure the entire chunk is written. If the operation is not able to write the entire chunk, an error is to be returned. Read more
source§

fn read_byob_sync(&self, data: &mut [u8]) -> Result<usize, Error>

The same as read_byob(), but synchronous.
source§

fn write_sync(&self, data: &[u8]) -> Result<usize, Error>

The same as write(), but synchronous.
source§

fn shutdown( self: Rc<Self> ) -> Pin<Box<dyn Future<Output = Result<(), Error>> + 'static, Global>>

The shutdown method can be used to asynchronously close the resource. It is not automatically called when the resource is dropped or closed. Read more
source§

fn close(self: Rc<Self>)

Resources may implement the close() trait method if they need to do resource specific clean-ups, such as cancelling pending futures, after a resource has been removed from the resource table.
source§

fn backing_fd(self: Rc<Self>) -> Option<i32>

Resources backed by a file descriptor can let ops know to allow for low-level optimizations.
source§

fn size_hint(&self) -> (u64, Option<u64>)

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.