message_db 0.0.5

Event-Sourced autonomous services for rust
Documentation
use crate::message::Message;
use sqlx::{Error, PgPool};

#[derive(Clone, Copy)]
pub struct Reader<'a> {
  pool: &'a PgPool,
}

impl<'a> Reader<'a> {
  pub fn new(pool: &'a PgPool) -> Self {
    Self { pool }
  }

  pub async fn get_category_messages(
    &self,
    category_name: &str,
    position: Option<i64>,
    batch_size: Option<i64>,
    correlation: Option<&str>,
    consumer_group_member: Option<i64>,
    consumer_group_size: Option<i64>,
    condition: Option<&str>,
  ) -> Result<Vec<Message>, Error> {
    sqlx::query_as(
      "select * from get_category_messages(
        $1::varchar,
        $2::bigint,
        $3::bigint,
        $4::varchar,
        $5::bigint,
        $6::bigint,
        $7::varchar
      )",
    )
    .bind(category_name)
    .bind(position)
    .bind(batch_size)
    .bind(correlation)
    .bind(consumer_group_member)
    .bind(consumer_group_size)
    .bind(condition)
    .fetch_all(self.pool)
    .await
  }

  pub async fn get_stream_messages(
    &self,
    stream_name: &str,
    position: Option<i64>,
    batch_size: Option<i64>,
    condition: Option<&str>,
  ) -> Result<Vec<Message>, Error> {
    sqlx::query_as(
      "select * from get_stream_messages(
        $1::varchar,
        $2::bigint,
        $3::bigint,
        $4::varchar
      )",
    )
    .bind(stream_name)
    .bind(position)
    .bind(batch_size)
    .bind(condition)
    .fetch_all(self.pool)
    .await
  }

  pub async fn get_last_stream_message(&self, stream_name: &str) -> Result<Message, Error> {
    sqlx::query_as("select * from get_last_stream_message($1::varchar)")
      .bind(stream_name)
      .fetch_one(self.pool)
      .await
  }
}