conduit/src/main.rs

244 lines
9.5 KiB
Rust
Raw Normal View History

#![warn(rust_2018_idioms)]
#![allow(clippy::suspicious_else_formatting)]
pub mod appservice_server;
pub mod client_server;
2020-08-14 12:34:15 +03:00
pub mod server_server;
2020-06-12 14:18:25 +03:00
mod database;
mod error;
2020-04-04 12:53:37 +03:00
mod pdu;
2020-02-16 00:42:21 +03:00
mod ruma_wrapper;
2020-03-29 14:48:44 +03:00
mod utils;
2020-02-16 00:42:21 +03:00
2021-02-28 14:41:03 +03:00
use database::Config;
pub use database::Database;
2021-02-28 14:41:03 +03:00
pub use error::{Error, Result};
2020-04-04 12:53:37 +03:00
pub use pdu::PduEvent;
pub use rocket::State;
use ruma::api::client::error::ErrorKind;
2020-06-09 16:13:17 +03:00
pub use ruma_wrapper::{ConduitResult, Ruma, RumaResponse};
2021-01-27 05:53:03 +03:00
use rocket::{
catch, catchers,
figment::{
providers::{Env, Format, Toml},
Figment,
},
routes, Request,
};
2021-02-28 14:41:03 +03:00
use tracing::span;
use tracing_subscriber::{prelude::*, Registry};
2021-04-24 14:34:35 +03:00
fn setup_rocket(config: Figment, data: Database) -> rocket::Rocket<rocket::Build> {
2021-04-26 19:01:41 +03:00
rocket::custom(config)
2021-04-23 19:54:17 +03:00
.manage(data)
2020-02-19 00:07:57 +03:00
.mount(
"/",
routes![
2020-04-11 10:30:11 +03:00
client_server::get_supported_versions_route,
client_server::get_register_available_route,
2020-04-11 10:30:11 +03:00
client_server::register_route,
2020-07-31 15:40:28 +03:00
client_server::get_login_types_route,
2020-04-11 10:30:11 +03:00
client_server::login_route,
2020-07-27 18:38:00 +03:00
client_server::whoami_route,
client_server::logout_route,
2020-07-05 09:35:19 +03:00
client_server::logout_all_route,
client_server::change_password_route,
client_server::deactivate_route,
2020-04-19 15:14:47 +03:00
client_server::get_capabilities_route,
2020-04-11 10:30:11 +03:00
client_server::get_pushrules_all_route,
client_server::set_pushrule_route,
2021-01-24 18:05:52 +03:00
client_server::get_pushrule_route,
client_server::set_pushrule_enabled_route,
2021-01-24 18:05:52 +03:00
client_server::get_pushrule_enabled_route,
client_server::get_pushrule_actions_route,
client_server::set_pushrule_actions_route,
client_server::delete_pushrule_route,
client_server::get_room_event_route,
2020-04-11 10:30:11 +03:00
client_server::get_filter_route,
client_server::create_filter_route,
client_server::set_global_account_data_route,
2021-03-24 10:48:28 +03:00
client_server::set_room_account_data_route,
2020-04-11 10:30:11 +03:00
client_server::get_global_account_data_route,
2021-03-24 10:48:28 +03:00
client_server::get_room_account_data_route,
2020-04-11 10:30:11 +03:00
client_server::set_displayname_route,
client_server::get_displayname_route,
client_server::set_avatar_url_route,
client_server::get_avatar_url_route,
client_server::get_profile_route,
client_server::set_presence_route,
client_server::upload_keys_route,
2020-05-17 20:56:40 +03:00
client_server::get_keys_route,
client_server::claim_keys_route,
2020-06-16 13:11:38 +03:00
client_server::create_backup_route,
client_server::update_backup_route,
client_server::delete_backup_route,
2020-06-16 13:11:38 +03:00
client_server::get_latest_backup_route,
client_server::get_backup_route,
client_server::add_backup_key_sessions_route,
2020-06-16 13:11:38 +03:00
client_server::add_backup_keys_route,
client_server::delete_backup_key_session_route,
client_server::delete_backup_key_sessions_route,
client_server::delete_backup_keys_route,
client_server::get_backup_key_session_route,
client_server::get_backup_key_sessions_route,
2020-06-16 13:11:38 +03:00
client_server::get_backup_keys_route,
2020-04-11 10:30:11 +03:00
client_server::set_read_marker_route,
2021-03-02 16:32:30 +03:00
client_server::create_receipt_route,
2020-04-12 22:12:50 +03:00
client_server::create_typing_event_route,
2020-04-11 10:30:11 +03:00
client_server::create_room_route,
2020-05-26 00:24:13 +03:00
client_server::redact_event_route,
client_server::create_alias_route,
client_server::delete_alias_route,
2020-04-11 10:30:11 +03:00
client_server::get_alias_route,
client_server::join_room_by_id_route,
client_server::join_room_by_id_or_alias_route,
client_server::joined_members_route,
2020-04-19 15:14:47 +03:00
client_server::leave_room_route,
2020-04-28 20:56:34 +03:00
client_server::forget_room_route,
client_server::joined_rooms_route,
2020-06-04 16:02:27 +03:00
client_server::kick_user_route,
client_server::ban_user_route,
client_server::unban_user_route,
client_server::invite_user_route,
2020-05-26 00:24:13 +03:00
client_server::set_room_visibility_route,
client_server::get_room_visibility_route,
2020-05-19 17:28:03 +03:00
client_server::get_public_rooms_route,
2020-04-11 10:30:11 +03:00
client_server::get_public_rooms_filtered_route,
client_server::search_users_route,
2020-04-19 15:14:47 +03:00
client_server::get_member_events_route,
2020-04-11 10:30:11 +03:00
client_server::get_protocols_route,
2020-08-13 00:32:39 +03:00
client_server::send_message_event_route,
client_server::send_state_event_for_key_route,
client_server::send_state_event_for_empty_key_route,
2020-05-18 10:22:07 +03:00
client_server::get_state_events_route,
client_server::get_state_events_for_key_route,
client_server::get_state_events_for_empty_key_route,
client_server::sync_events_route,
2020-06-04 14:58:55 +03:00
client_server::get_context_route,
2020-04-28 20:56:34 +03:00
client_server::get_message_events_route,
2020-08-18 13:15:27 +03:00
client_server::search_events_route,
client_server::turn_server_route,
client_server::send_event_to_device_route,
client_server::get_media_config_route,
2020-05-18 18:53:34 +03:00
client_server::create_content_route,
client_server::get_content_route,
client_server::get_content_thumbnail_route,
client_server::get_devices_route,
client_server::get_device_route,
client_server::update_device_route,
client_server::delete_device_route,
client_server::delete_devices_route,
client_server::get_tags_route,
client_server::update_tag_route,
client_server::delete_tag_route,
2020-04-11 10:30:11 +03:00
client_server::options_route,
2020-06-16 13:11:38 +03:00
client_server::upload_signing_keys_route,
client_server::upload_signatures_route,
2020-07-29 18:37:26 +03:00
client_server::get_key_changes_route,
2020-07-30 19:14:47 +03:00
client_server::get_pushers_route,
2020-06-16 13:11:38 +03:00
client_server::set_pushers_route,
2021-01-27 05:53:03 +03:00
// client_server::third_party_route,
2020-08-06 14:21:53 +03:00
client_server::upgrade_room_route,
server_server::get_server_version_route,
server_server::get_server_keys_route,
server_server::get_server_keys_deprecated_route,
server_server::get_public_rooms_route,
server_server::get_public_rooms_filtered_route,
server_server::send_transaction_message_route,
2021-04-07 16:56:57 +03:00
server_server::get_event_route,
server_server::get_missing_events_route,
server_server::get_room_state_ids_route,
server_server::create_join_event_template_route,
server_server::create_join_event_route,
2021-04-11 22:01:27 +03:00
server_server::create_invite_route,
2021-04-21 11:51:34 +03:00
server_server::get_devices_route,
server_server::get_room_information_route,
2020-10-05 23:19:22 +03:00
server_server::get_profile_information_route,
2020-02-19 00:07:57 +03:00
],
)
2021-04-23 19:54:17 +03:00
.register(
"/",
catchers![
not_found_catcher,
forbidden_catcher,
unknown_token_catcher,
missing_token_catcher,
bad_json_catcher
],
2021-04-26 19:01:41 +03:00
)
}
2020-06-16 14:53:15 +03:00
#[rocket::main]
async fn main() {
2021-04-24 14:34:35 +03:00
// Force log level off, so we can use our own logger
std::env::set_var("CONDUIT_LOG_LEVEL", "off");
let raw_config =
Figment::from(rocket::Config::release_default())
.merge(
Toml::file(Env::var("CONDUIT_CONFIG").expect(
"The CONDUIT_CONFIG env var needs to be set. Example: /etc/conduit.toml",
))
.nested(),
)
.merge(Env::prefixed("CONDUIT_").global());
let config = raw_config
.extract::<Config>()
.expect("It looks like your config is invalid. Please take a look at the error");
let db = Database::load_or_create(config.clone())
.await
.expect("config is valid");
db.sending.start_handler(&db);
2021-02-28 14:41:03 +03:00
if config.allow_jaeger {
let (tracer, _uninstall) = opentelemetry_jaeger::new_pipeline()
.with_service_name("conduit")
.install()
.unwrap();
let telemetry = tracing_opentelemetry::layer().with_tracer(tracer);
Registry::default().with(telemetry).try_init().unwrap();
let root = span!(tracing::Level::INFO, "app_start", work_units = 2);
let _enter = root.enter();
} else {
2021-04-24 14:34:35 +03:00
std::env::set_var("CONDUIT_LOG", config.log);
pretty_env_logger::init_custom_env("CONDUIT_LOG");
2021-02-28 14:41:03 +03:00
}
2021-04-24 14:34:35 +03:00
let rocket = setup_rocket(raw_config, db);
rocket.launch().await.unwrap();
2020-02-16 00:42:21 +03:00
}
2020-12-19 18:00:11 +03:00
#[catch(404)]
2020-12-22 20:45:35 +03:00
fn not_found_catcher(_: &Request<'_>) -> String {
2020-12-19 18:00:11 +03:00
"404 Not Found".to_owned()
}
#[catch(580)]
fn forbidden_catcher() -> Result<()> {
Err(Error::BadRequest(ErrorKind::Forbidden, "Forbidden."))
}
#[catch(581)]
fn unknown_token_catcher() -> Result<()> {
Err(Error::BadRequest(
ErrorKind::UnknownToken { soft_logout: false },
"Unknown token.",
))
}
#[catch(582)]
fn missing_token_catcher() -> Result<()> {
Err(Error::BadRequest(ErrorKind::MissingToken, "Missing token."))
}
#[catch(583)]
fn bad_json_catcher() -> Result<()> {
Err(Error::BadRequest(ErrorKind::BadJson, "Bad json."))
}