relay/src/main.rs

156 lines
4.6 KiB
Rust
Raw Normal View History

2020-04-23 18:28:00 +00:00
use actix_rt::Arbiter;
use actix_web::{
middleware::{Compress, Logger},
web, App, HttpServer,
};
2020-03-15 02:05:40 +00:00
mod apub;
mod args;
mod config;
2020-03-23 22:17:53 +00:00
mod data;
mod db;
2020-03-16 03:36:46 +00:00
mod error;
mod jobs;
2020-03-23 17:38:39 +00:00
mod middleware;
mod notify;
mod requests;
2020-03-23 17:38:39 +00:00
mod routes;
2020-03-15 02:05:40 +00:00
2020-03-20 18:40:18 +00:00
use self::{
args::Args,
config::Config,
data::{ActorCache, Media, State},
db::Db,
jobs::{create_server, create_workers},
2020-07-10 20:07:47 +00:00
middleware::{DebugPayload, RelayResolver},
2020-03-23 17:38:39 +00:00
routes::{actor, inbox, index, nodeinfo, nodeinfo_meta, statics},
2020-03-20 18:40:18 +00:00
};
2020-03-20 04:06:16 +00:00
2020-03-15 02:05:40 +00:00
#[actix_rt::main]
async fn main() -> Result<(), anyhow::Error> {
dotenv::dotenv().ok();
let config = Config::build()?;
2020-03-15 22:37:53 +00:00
if config.debug() {
2020-03-26 14:22:57 +00:00
std::env::set_var(
"RUST_LOG",
"debug,tokio_postgres=info,h2=info,trust_dns_resolver=info,trust_dns_proto=info,rustls=info,html5ever=info",
2020-03-26 14:22:57 +00:00
)
} else {
std::env::set_var("RUST_LOG", "info")
}
if config.pretty_log() {
pretty_env_logger::init();
} else {
env_logger::init();
}
2020-04-21 17:07:39 +00:00
let db = Db::build(&config)?;
2020-03-15 02:05:40 +00:00
let args = Args::new();
2020-03-23 00:07:36 +00:00
if args.jobs_only() && args.no_jobs() {
return Err(anyhow::Error::msg(
"Either the server or the jobs must be run",
));
}
if !args.blocks().is_empty() || !args.whitelists().is_empty() {
if args.undo() {
db.remove_blocks(args.blocks()).await?;
db.remove_whitelists(args.whitelists()).await?;
} else {
db.add_blocks(args.blocks()).await?;
db.add_whitelists(args.whitelists()).await?;
}
return Ok(());
}
let media = Media::new(db.clone());
let state = State::hydrate(config.clone(), &db).await?;
2020-03-23 22:17:53 +00:00
let actors = ActorCache::new(db.clone());
2020-07-11 01:00:31 +00:00
let job_server = create_server();
2020-03-15 02:05:40 +00:00
notify::Notifier::new(config.database_url().parse()?)
.register(notify::NewBlocks(state.clone()))
.register(notify::NewWhitelists(state.clone()))
.register(notify::NewListeners(state.clone(), job_server.clone()))
.register(notify::NewActors(actors.clone()))
.register(notify::NewNodes(state.node_cache()))
.register(notify::RmBlocks(state.clone()))
.register(notify::RmWhitelists(state.clone()))
.register(notify::RmListeners(state.clone()))
.register(notify::RmActors(actors.clone()))
.register(notify::RmNodes(state.node_cache()))
.start();
2020-03-23 00:07:36 +00:00
if args.jobs_only() {
for _ in 0..num_cpus::get() {
let state = state.clone();
2020-03-23 22:17:53 +00:00
let actors = actors.clone();
2020-03-23 00:07:36 +00:00
let job_server = job_server.clone();
let media = media.clone();
let config = config.clone();
2020-03-30 17:10:04 +00:00
let db = db.clone();
2020-03-23 00:07:36 +00:00
Arbiter::new().exec_fn(move || {
2020-03-30 17:10:04 +00:00
create_workers(db, state, actors, job_server, media, config);
2020-03-23 00:07:36 +00:00
});
}
actix_rt::signal::ctrl_c().await?;
return Ok(());
}
let no_jobs = args.no_jobs();
let bind_address = config.bind_address();
2020-03-15 02:05:40 +00:00
HttpServer::new(move || {
2020-03-23 00:07:36 +00:00
if !no_jobs {
create_workers(
2020-03-30 17:10:04 +00:00
db.clone(),
state.clone(),
actors.clone(),
job_server.clone(),
media.clone(),
config.clone(),
);
2020-03-23 00:07:36 +00:00
}
2020-03-15 02:05:40 +00:00
App::new()
.wrap(Compress::default())
2020-03-15 22:37:53 +00:00
.wrap(Logger::default())
2020-03-19 22:19:05 +00:00
.data(db.clone())
2020-03-15 02:05:40 +00:00
.data(state.clone())
2020-03-18 04:35:20 +00:00
.data(state.requests())
2020-03-23 22:17:53 +00:00
.data(actors.clone())
.data(config.clone())
.data(job_server.clone())
.data(media.clone())
2020-03-15 02:05:40 +00:00
.service(web::resource("/").route(web::get().to(index)))
.service(web::resource("/media/{path}").route(web::get().to(routes::media)))
.service(
web::resource("/inbox")
.wrap(config.digest_middleware())
2020-03-23 22:17:53 +00:00
.wrap(config.signature_middleware(state.requests(), actors.clone()))
2020-07-10 20:34:18 +00:00
.wrap(DebugPayload(config.debug()))
2020-03-23 17:38:39 +00:00
.route(web::post().to(inbox)),
)
2020-03-23 17:38:39 +00:00
.service(web::resource("/actor").route(web::get().to(actor)))
.service(web::resource("/nodeinfo/2.0.json").route(web::get().to(nodeinfo)))
2020-03-19 19:05:16 +00:00
.service(
web::scope("/.well-known")
2020-04-21 19:12:10 +00:00
.service(actix_webfinger::scoped::<RelayResolver>())
2020-03-23 17:38:39 +00:00
.service(web::resource("/nodeinfo").route(web::get().to(nodeinfo_meta))),
2020-03-19 19:05:16 +00:00
)
2020-03-23 17:38:39 +00:00
.service(web::resource("/static/{filename}").route(web::get().to(statics)))
2020-03-15 02:05:40 +00:00
})
.bind(bind_address)?
2020-03-15 02:05:40 +00:00
.run()
.await?;
Ok(())
}
2020-03-20 18:40:18 +00:00
include!(concat!(env!("OUT_DIR"), "/templates.rs"));