-
Notifications
You must be signed in to change notification settings - Fork 99
/
Copy pathttrpc-cdh.rs
108 lines (90 loc) · 3.09 KB
/
ttrpc-cdh.rs
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
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
// Copyright (c) 2023 Alibaba Cloud
//
// SPDX-License-Identifier: Apache-2.0
//
use std::{env, path::Path, sync::Arc};
use anyhow::{anyhow, Context, Result};
use clap::Parser;
use confidential_data_hub::CdhConfig;
use log::info;
use protos::{
api_ttrpc::{
create_get_resource_service, create_image_pull_service, create_sealed_secret_service,
create_secure_mount_service,
},
keyprovider_ttrpc::create_key_provider_service,
};
use tokio::{
fs,
signal::unix::{signal, SignalKind},
};
use ttrpc::r#async::Server as TtrpcServer;
use ttrpc_server::Server;
mod message;
mod protos;
mod ttrpc_server;
const UNIX_SOCKET_PREFIX: &str = "unix://";
const VERSION: &str = include_str!(concat!(env!("OUT_DIR"), "/version"));
#[derive(Debug, Parser)]
#[command(author, version = Some(VERSION))]
struct Cli {
/// Path to the config file
///
/// `--config /etc/confidential-data-hub.conf`
#[arg(short)]
config: Option<String>,
}
#[tokio::main]
async fn main() -> Result<()> {
env_logger::init_from_env(env_logger::Env::new().default_filter_or("info"));
let cli = Cli::parse();
let config = CdhConfig::new(cli.config)?;
let unix_socket_path = config
.socket
.strip_prefix(UNIX_SOCKET_PREFIX)
.ok_or_else(|| anyhow!("socket address scheme is not expected"))?;
create_socket_parent_directory(unix_socket_path).await?;
clean_previous_sock_file(unix_socket_path).await?;
let server = Server::new(&config).await.context("create CDH instance")?;
let server = Arc::new(server);
let mut server = TtrpcServer::new()
.bind(&config.socket)
.context("cannot bind cdh ttrpc service")?
.register_service(create_sealed_secret_service(server.clone() as _))
.register_service(create_get_resource_service(server.clone() as _))
.register_service(create_key_provider_service(server.clone() as _))
.register_service(create_secure_mount_service(server.clone() as _))
.register_service(create_image_pull_service(server.clone() as _));
info!(
"[ttRPC] Confidential Data Hub starts to listen to request: {}",
config.socket
);
server.start().await?;
let mut interrupt = signal(SignalKind::interrupt())?;
let mut hangup = signal(SignalKind::hangup())?;
tokio::select! {
_ = hangup.recv() => {
info!("Client terminal disconnected.");
server.shutdown().await?;
}
_ = interrupt.recv() => {
info!("SIGINT received, gracefully shutdown.");
server.shutdown().await?;
}
};
Ok(())
}
async fn clean_previous_sock_file(unix_socket_file: &str) -> Result<()> {
if Path::new(unix_socket_file).exists() {
fs::remove_file(unix_socket_file).await?;
}
Ok(())
}
async fn create_socket_parent_directory(unix_socket_file: &str) -> Result<()> {
let file_path = Path::new(unix_socket_file);
let parent_directory = file_path
.parent()
.ok_or(anyhow!("The file path does not have a parent directory."))?;
fs::create_dir_all(parent_directory).await?;
Ok(())
}