aboutsummaryrefslogtreecommitdiffstats
path: root/crates/rule-executor/src/processor/publish.rs
blob: 0d359779705ff8356ddc6ee6defa61d31ef213d9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
use warden_stack::tracing::telemetry::nats::injector;

use opentelemetry::global;
use opentelemetry_semantic_conventions::attribute;
use tracing::{Instrument, Span, debug, info_span, warn};
use tracing_opentelemetry::OpenTelemetrySpanExt;
use warden_core::message::Payload;

use crate::state::AppHandle;

pub(super) async fn to_typologies(
    subject: &str,
    state: AppHandle,
    payload: Payload,
) -> anyhow::Result<()> {
    // send transaction to next with nats
    let subject = format!("{}.{}", state.config.nats.destination_prefix, subject);
    debug!(subject = ?subject, "publishing");

    let payload = prost::Message::encode_to_vec(&payload);

    let mut headers = async_nats::HeaderMap::new();

    let cx = Span::current().context();

    global::get_text_map_propagator(|propagator| {
        propagator.inject_context(&cx, &mut injector::HeaderMap(&mut headers))
    });

    let span = info_span!("nats.publish");
    span.set_attribute(
        attribute::MESSAGING_DESTINATION_SUBSCRIPTION_NAME,
        subject.to_string(),
    );
    span.set_attribute("otel.kind", "producer");
    state
        .services
        .jetstream
        .publish_with_headers(subject.clone(), headers, payload.into())
        .instrument(span)
        .await
        .inspect_err(|e| warn!(subject = ?subject, "failed to publish: {e}"))?;

    Ok(())
}