cala-ledger 0.15.9

An embeddable double sided accounting ledger built on PG/SQLx
Documentation
use es_entity::*;
use sqlx::PgPool;

use crate::{
    outbox::OutboxPublisher,
    primitives::{JournalId, TransactionId, TxTemplateId},
};

use super::entity::*;

#[derive(EsRepo, Clone)]
#[es_repo(
    entity = "Transaction",
    columns(
        external_id(ty = "Option<String>", update(persist = false)),
        correlation_id(ty = "String", update(persist = false)),
        journal_id(ty = "JournalId", update(persist = false)),
        tx_template_id(ty = "TxTemplateId", update(persist = false), list_for(by(created_at))),
        effective(ty = "chrono::NaiveDate", update(persist = false)),
    ),
    tbl_prefix = "cala",
    post_persist_hook = "publish",
    persist_event_context = false
)]
pub(super) struct TransactionRepo {
    pool: PgPool,
    publisher: OutboxPublisher,
}

impl TransactionRepo {
    pub fn new(pool: &PgPool, publisher: &OutboxPublisher) -> Self {
        Self {
            pool: pool.clone(),
            publisher: publisher.clone(),
        }
    }

    async fn publish(
        &self,
        op: &mut impl es_entity::AtomicOperation,
        entity: &Transaction,
        new_events: es_entity::LastPersisted<'_, TransactionEvent>,
    ) -> Result<(), sqlx::Error> {
        self.publisher
            .publish_entity_events(op, entity, new_events)
            .await?;
        Ok(())
    }
}