Struct RqliteClient

Source
pub struct RqliteClient { /* private fields */ }
Expand description

A client for interacting with a rqlite cluster.

Implementations§

Source§

impl RqliteClient

Source

pub async fn fetch<Q>(&self, q: Q) -> Result<Vec<Row>, RequestError>

Executes a query that returns results. Returns a vector of Rows if the query was successful, otherwise an error.

§Errors

This function will return an error if:

  • The query could not be converted to a RqliteQuery
  • The request to the rqlite server failed
  • The response could not be parsed
  • The database returned an error
Source

pub async fn exec<Q>(&self, q: Q) -> Result<QueryResult, RequestError>

Executes a query that does not return any results. Returns the QueryResult if the query was successful, otherwise an error. Is primarily used for INSERT, UPDATE, DELETE and CREATE queries.

§Errors

This function will return an error if:

  • The query could not be converted to a RqliteQuery
  • The request to the rqlite server failed
  • The response could not be parsed
  • The database returned an error
Source

pub async fn batch<Q>( &self, qs: Vec<Q>, ) -> Result<Vec<RqliteResult<BatchResult>>, RequestError>

Executes a batch of queries. It allows sending multiple queries in a single request. This can be more efficient and reduces round-trips to the database. Returns a vector of RqliteResults. Each result contains the result of the corresponding query in the batch. If a query fails, the corresponding result will contain an error.

For more information on batch queries, see the rqlite documentation.

§Errors

This function will return an error if:

  • The query could not be converted to a RqliteQuery
  • The request to the rqlite server failed
  • The response could not be parsed
  • The database returned an error
Source

pub async fn transaction<Q>( &self, qs: Vec<Q>, ) -> Result<Vec<RqliteResult<QueryResult>>, RequestError>

Executes a transaction. A transaction is a set of queries that are executed as a single unit. If any of the queries fail, the entire transaction is rolled back. Returns a vector of RqliteResults.

For more information on transactions, see the rqlite documentation.

§Errors

This function will return an error if:

  • The query could not be converted to a RqliteQuery
  • The request to the rqlite server failed
  • The response could not be parsed
  • The database returned an error
  • The transaction could not be executed
Source

pub async fn queue<Q>(&self, qs: Vec<Q>) -> Result<(), RequestError>

Asynchronously executes multiple queries. This results in much higher write performance.

For more information on queued queries, see the rqlite documentation.

§Errors

This function will return an error if:

  • The query could not be converted to a RqliteQuery
  • The request to the rqlite server failed
  • The response could not be parsed
  • The database returned an error
Source

pub async fn ready(&self) -> bool

Checks if the rqlite cluster is ready. Returns true if the cluster is ready, otherwise false.

Source

pub async fn nodes(&self) -> Result<Vec<Node>, RequestError>

Retrieves the nodes in the rqlite cluster. Returns a vector of Nodes.

§Errors

This function will return an error if:

  • The request to the rqlite server failed
  • The response could not be parsed
Source

pub async fn leader(&self) -> Result<Option<Node>, RequestError>

Retrieves current the leader of the rqlite cluster. Returns a Node if a leader is found, otherwise None.

§Errors

This function will return an error if:

  • The request to the rqlite server failed
  • The response could not be parsed
Source

pub async fn remove_node(&self, id: &str) -> Result<(), RequestError>

Removes a node from the rqlite cluster.

§Errors

This function will return an error if:

  • The request body cannot be serialized
  • The request to the rqlite server failed
  • The response indicates a failure
  • The response body cannot be read

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where 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> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where 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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

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

Source§

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 T
where U: TryFrom<T>,

Source§

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.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ErasedDestructor for T
where T: 'static,