|
|
|
@ -3,7 +3,7 @@ use std::{future::Future, io, net::SocketAddr, sync::atomic, time::Duration};
|
|
|
|
|
use axum::{
|
|
|
|
|
extract::{DefaultBodyLimit, FromRequestParts, MatchedPath},
|
|
|
|
|
response::IntoResponse,
|
|
|
|
|
routing::{get, on, MethodFilter},
|
|
|
|
|
routing::{any, get, on, MethodFilter},
|
|
|
|
|
Router,
|
|
|
|
|
};
|
|
|
|
|
use axum_server::{bind, bind_rustls, tls_rustls::RustlsConfig, Handle as ServerHandle};
|
|
|
|
@ -188,7 +188,7 @@ async fn run_server() -> io::Result<()> {
|
|
|
|
|
.expect("failed to convert max request size"),
|
|
|
|
|
));
|
|
|
|
|
|
|
|
|
|
let app = routes().layer(middlewares).into_make_service();
|
|
|
|
|
let app = routes(config).layer(middlewares).into_make_service();
|
|
|
|
|
let handle = ServerHandle::new();
|
|
|
|
|
|
|
|
|
|
tokio::spawn(shutdown_signal(handle.clone()));
|
|
|
|
@ -249,8 +249,8 @@ async fn unrecognized_method<B: Send>(
|
|
|
|
|
Ok(inner)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn routes() -> Router {
|
|
|
|
|
Router::new()
|
|
|
|
|
fn routes(config: &Config) -> Router {
|
|
|
|
|
let router = Router::new()
|
|
|
|
|
.ruma_route(client_server::get_supported_versions_route)
|
|
|
|
|
.ruma_route(client_server::get_register_available_route)
|
|
|
|
|
.ruma_route(client_server::register_route)
|
|
|
|
@ -390,33 +390,6 @@ fn routes() -> Router {
|
|
|
|
|
.ruma_route(client_server::get_relating_events_with_rel_type_route)
|
|
|
|
|
.ruma_route(client_server::get_relating_events_route)
|
|
|
|
|
.ruma_route(client_server::get_hierarchy_route)
|
|
|
|
|
.ruma_route(server_server::get_server_version_route)
|
|
|
|
|
.route(
|
|
|
|
|
"/_matrix/key/v2/server",
|
|
|
|
|
get(server_server::get_server_keys_route),
|
|
|
|
|
)
|
|
|
|
|
.route(
|
|
|
|
|
"/_matrix/key/v2/server/:key_id",
|
|
|
|
|
get(server_server::get_server_keys_deprecated_route),
|
|
|
|
|
)
|
|
|
|
|
.ruma_route(server_server::get_public_rooms_route)
|
|
|
|
|
.ruma_route(server_server::get_public_rooms_filtered_route)
|
|
|
|
|
.ruma_route(server_server::send_transaction_message_route)
|
|
|
|
|
.ruma_route(server_server::get_event_route)
|
|
|
|
|
.ruma_route(server_server::get_backfill_route)
|
|
|
|
|
.ruma_route(server_server::get_missing_events_route)
|
|
|
|
|
.ruma_route(server_server::get_event_authorization_route)
|
|
|
|
|
.ruma_route(server_server::get_room_state_route)
|
|
|
|
|
.ruma_route(server_server::get_room_state_ids_route)
|
|
|
|
|
.ruma_route(server_server::create_join_event_template_route)
|
|
|
|
|
.ruma_route(server_server::create_join_event_v1_route)
|
|
|
|
|
.ruma_route(server_server::create_join_event_v2_route)
|
|
|
|
|
.ruma_route(server_server::create_invite_route)
|
|
|
|
|
.ruma_route(server_server::get_devices_route)
|
|
|
|
|
.ruma_route(server_server::get_room_information_route)
|
|
|
|
|
.ruma_route(server_server::get_profile_information_route)
|
|
|
|
|
.ruma_route(server_server::get_keys_route)
|
|
|
|
|
.ruma_route(server_server::claim_keys_route)
|
|
|
|
|
.route(
|
|
|
|
|
"/_matrix/client/r0/rooms/:room_id/initialSync",
|
|
|
|
|
get(initial_sync),
|
|
|
|
@ -426,7 +399,42 @@ fn routes() -> Router {
|
|
|
|
|
get(initial_sync),
|
|
|
|
|
)
|
|
|
|
|
.route("/", get(it_works))
|
|
|
|
|
.fallback(not_found)
|
|
|
|
|
.fallback(not_found);
|
|
|
|
|
|
|
|
|
|
if config.allow_federation {
|
|
|
|
|
router
|
|
|
|
|
.ruma_route(server_server::get_server_version_route)
|
|
|
|
|
.route(
|
|
|
|
|
"/_matrix/key/v2/server",
|
|
|
|
|
get(server_server::get_server_keys_route),
|
|
|
|
|
)
|
|
|
|
|
.route(
|
|
|
|
|
"/_matrix/key/v2/server/:key_id",
|
|
|
|
|
get(server_server::get_server_keys_deprecated_route),
|
|
|
|
|
)
|
|
|
|
|
.ruma_route(server_server::get_public_rooms_route)
|
|
|
|
|
.ruma_route(server_server::get_public_rooms_filtered_route)
|
|
|
|
|
.ruma_route(server_server::send_transaction_message_route)
|
|
|
|
|
.ruma_route(server_server::get_event_route)
|
|
|
|
|
.ruma_route(server_server::get_backfill_route)
|
|
|
|
|
.ruma_route(server_server::get_missing_events_route)
|
|
|
|
|
.ruma_route(server_server::get_event_authorization_route)
|
|
|
|
|
.ruma_route(server_server::get_room_state_route)
|
|
|
|
|
.ruma_route(server_server::get_room_state_ids_route)
|
|
|
|
|
.ruma_route(server_server::create_join_event_template_route)
|
|
|
|
|
.ruma_route(server_server::create_join_event_v1_route)
|
|
|
|
|
.ruma_route(server_server::create_join_event_v2_route)
|
|
|
|
|
.ruma_route(server_server::create_invite_route)
|
|
|
|
|
.ruma_route(server_server::get_devices_route)
|
|
|
|
|
.ruma_route(server_server::get_room_information_route)
|
|
|
|
|
.ruma_route(server_server::get_profile_information_route)
|
|
|
|
|
.ruma_route(server_server::get_keys_route)
|
|
|
|
|
.ruma_route(server_server::claim_keys_route)
|
|
|
|
|
} else {
|
|
|
|
|
router
|
|
|
|
|
.route("/_matrix/federation/*path", any(federation_disabled))
|
|
|
|
|
.route("/_matrix/key/*path", any(federation_disabled))
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn shutdown_signal(handle: ServerHandle) {
|
|
|
|
@ -463,6 +471,10 @@ async fn shutdown_signal(handle: ServerHandle) {
|
|
|
|
|
let _ = sd_notify::notify(true, &[sd_notify::NotifyState::Stopping]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn federation_disabled(_: Uri) -> impl IntoResponse {
|
|
|
|
|
Error::bad_config("Federation is disabled.")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn not_found(uri: Uri) -> impl IntoResponse {
|
|
|
|
|
warn!("Not found: {uri}");
|
|
|
|
|
Error::BadRequest(ErrorKind::Unrecognized, "Unrecognized request")
|
|
|
|
|