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
#![warn(clippy::all)]
#![warn(missing_docs)]
use minerva_broker as broker;
use minerva_cache as cache;
use minerva_data as data;
use broker::LapinPool;
use data::db::DBPool;
use dotenv::dotenv;
use log::info;
use std::collections::HashMap;
use std::env;
mod controller;
mod error;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
println!("Minerva System: DISPATCH");
println!("Copyright (c) 2022 Lucas S. Vieira");
println!();
dotenv().ok();
let logconfig = env::var("LOG_CONFIG_FILE").unwrap_or_else(|_| "./logging.yml".to_owned());
match log4rs::init_file(logconfig, Default::default()) {
Ok(_) => info!("Log system initialized."),
Err(e) => eprintln!(
"Failure while initializing logs: {:?}\n\
You might be flying solo now.",
e
),
}
let dbserver = env::var("DATABASE_SERVICE_SERVER")?;
let mongoserver = env::var("MONGO_SERVICE_SERVER")?;
let redisserver = env::var("REDIS_SERVICE_SERVER")?;
let rmqserver = env::var("RABBITMQ_SERVICE_SERVER")?;
info!("Loading tenant configuration...");
let tenant_config = data::tenancy::get_tenants("tenancy.toml");
info!("Creating service connections...");
let mongo_client = data::mongo::make_client(&mongoserver).await;
let redis_client = cache::build_client(&redisserver)?;
let mut tenant_clients: HashMap<String, (DBPool, LapinPool)> = HashMap::new();
for tenant in tenant_config.clone() {
let dbpool =
data::db::make_connection_pool(&tenant.database, &dbserver, tenant.connections).await;
let lapinpool =
broker::make_connection_pool(&rmqserver, Some(&tenant.database), tenant.connections)
.await;
tenant_clients.insert(tenant.database.clone(), (dbpool, lapinpool));
}
let tenants = tenant_config
.iter()
.map(|cfg| cfg.database.clone())
.collect::<Vec<String>>();
info!("Starting listeners for each tenant...");
let mut handlers = vec![];
for t in tenants {
let tenant = t.clone();
let postgres = data::db::make_connection_pool(&tenant.clone(), &dbserver, 15).await;
let rabbitmq = broker::make_connection_pool(&rmqserver, Some(&tenant), 15).await;
let redis = redis_client.clone();
let mongo = mongo_client.clone();
handlers.push(tokio::spawn(async move {
info!("Running queue listener for {}.", tenant);
controller::queue_consume(tenant, rabbitmq, postgres, mongo, redis)
.await
.unwrap();
}))
}
for handler in handlers {
handler.await?;
}
Ok(())
}