aboutsummaryrefslogtreecommitdiffstats
path: root/crates/pseudonyms/src/server.rs
blob: 88c46b422cfc09c93742fe7d8d55d373c20261b1 (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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
mod interceptor;
use interceptor::MyInterceptor;
use tokio::signal;
use warden_core::pseudonyms::transaction_relationship::mutate_pseudonym_server::MutatePseudonymServer;

use tonic::transport::{Server, server::TcpIncoming};
use tracing::info;

use crate::state::AppHandle;

pub async fn serve(state: AppHandle, tx: tokio::sync::oneshot::Sender<u16>) -> anyhow::Result<()> {
    let listener = tokio::net::TcpListener::bind(state.addr).await?;

    let socket_addr = listener
        .local_addr()
        .expect("should get socket_addr from listener");

    tx.send(socket_addr.port())
        .expect("port channel to be open");

    info!(addr = ?socket_addr, "starting server");

    Server::builder()
        .trace_fn(|_| tracing::info_span!(env!("CARGO_PKG_NAME")))
        //        .add_service(QueryUsersServer::new(state.clone()))
        .add_service(MutatePseudonymServer::with_interceptor(
            state.clone(),
            MyInterceptor,
        ))
        .serve_with_incoming_shutdown(TcpIncoming::from(listener), shutdown_signal(state))
        .await?;

    Ok(())
}
async fn shutdown_signal(state: AppHandle) {
    let ctrl_c = async {
        signal::ctrl_c()
            .await
            .expect("failed to install Ctrl+C handler");
    };

    #[cfg(unix)]
    let terminate = async {
        signal::unix::signal(signal::unix::SignalKind::terminate())
            .expect("failed to install signal handler")
            .recv()
            .await;
    };

    #[cfg(not(unix))]
    let terminate = std::future::pending::<()>();

    tokio::select! {
        _ = ctrl_c => {
            if let Some(ref provider) = state.tracer_provider {
                let _ = provider.shutdown();
            }
        },
        _ = terminate => {
            if let Some(ref provider) = state.tracer_provider {
                let _ = provider.shutdown();
            }
        },
    }
}