More work on federation
This commit is contained in:
		
							parent
							
								
									b0d9ccdb2d
								
							
						
					
					
						commit
						1af6dd984a
					
				
					 5 changed files with 91 additions and 9 deletions
				
			
		
							
								
								
									
										3
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										3
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							|  | @ -142,6 +142,7 @@ dependencies = [ | ||||||
| name = "conduit" | name = "conduit" | ||||||
| version = "0.1.0" | version = "0.1.0" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  |  "base64 0.12.0", | ||||||
|  "directories", |  "directories", | ||||||
|  "http", |  "http", | ||||||
|  "js_int", |  "js_int", | ||||||
|  | @ -1265,6 +1266,7 @@ dependencies = [ | ||||||
|  "ruma-api", |  "ruma-api", | ||||||
|  "ruma-events", |  "ruma-events", | ||||||
|  "ruma-identifiers", |  "ruma-identifiers", | ||||||
|  |  "ruma-serde", | ||||||
|  "serde", |  "serde", | ||||||
|  "serde_json", |  "serde_json", | ||||||
| ] | ] | ||||||
|  | @ -1292,7 +1294,6 @@ dependencies = [ | ||||||
| [[package]] | [[package]] | ||||||
| name = "ruma-signatures" | name = "ruma-signatures" | ||||||
| version = "0.6.0-dev.1" | version = "0.6.0-dev.1" | ||||||
| source = "git+https://github.com/ruma/ruma-signatures.git#c3f8399c268695464730afd6077c7ce50155b8d5" |  | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "base64 0.12.0", |  "base64 0.12.0", | ||||||
|  "ring", |  "ring", | ||||||
|  |  | ||||||
|  | @ -17,7 +17,7 @@ ruma-client-api = { git = "https://github.com/ruma/ruma-client-api.git" } | ||||||
| ruma-identifiers = "0.15.1" | ruma-identifiers = "0.15.1" | ||||||
| ruma-api = "0.16.0-rc.1" | ruma-api = "0.16.0-rc.1" | ||||||
| ruma-events = "0.19.0" | ruma-events = "0.19.0" | ||||||
| ruma-signatures = { git = "https://github.com/ruma/ruma-signatures.git" } | ruma-signatures = { path = "../ruma-signatures" } | ||||||
| ruma-federation-api = { path = "../ruma-federation-api" } | ruma-federation-api = { path = "../ruma-federation-api" } | ||||||
| pretty_env_logger = "0.4.0" | pretty_env_logger = "0.4.0" | ||||||
| log = "0.4.8" | log = "0.4.8" | ||||||
|  | @ -30,3 +30,4 @@ tokio = { version = "0.2.18", features = ["macros"] } | ||||||
| rand = "0.7.3" | rand = "0.7.3" | ||||||
| rust-argon2 = "0.8.2" | rust-argon2 = "0.8.2" | ||||||
| reqwest = "0.10.4" | reqwest = "0.10.4" | ||||||
|  | base64 = "0.12.0" | ||||||
|  |  | ||||||
|  | @ -756,7 +756,7 @@ pub async fn get_public_rooms_filtered_route( | ||||||
|     chunk.extend_from_slice( |     chunk.extend_from_slice( | ||||||
|         &server_server::send_request( |         &server_server::send_request( | ||||||
|             &data, |             &data, | ||||||
|             "https://matrix.org".to_owned(), |             "https://matrix.koesters.xyz".to_owned(), | ||||||
|             ruma_federation_api::v1::get_public_rooms::Request { |             ruma_federation_api::v1::get_public_rooms::Request { | ||||||
|                 limit: None, |                 limit: None, | ||||||
|                 since: None, |                 since: None, | ||||||
|  |  | ||||||
|  | @ -60,6 +60,10 @@ fn setup_rocket(data: Data) -> rocket::Rocket { | ||||||
|                 client_server::turn_server_route, |                 client_server::turn_server_route, | ||||||
|                 client_server::publicised_groups_route, |                 client_server::publicised_groups_route, | ||||||
|                 client_server::options_route, |                 client_server::options_route, | ||||||
|  |                 server_server::well_known_server, | ||||||
|  |                 server_server::get_server_version, | ||||||
|  |                 server_server::get_server_keys, | ||||||
|  |                 server_server::get_server_keys_deprecated, | ||||||
|             ], |             ], | ||||||
|         ) |         ) | ||||||
|         .manage(data) |         .manage(data) | ||||||
|  | @ -72,7 +76,7 @@ fn main() { | ||||||
|     } |     } | ||||||
|     pretty_env_logger::init(); |     pretty_env_logger::init(); | ||||||
| 
 | 
 | ||||||
|     let data = Data::load_or_create("matrixtesting.koesters.xyz"); |     let data = Data::load_or_create("matrixtesting.koesters.xyz:14004"); | ||||||
|     //data.debug();
 |     //data.debug();
 | ||||||
| 
 | 
 | ||||||
|     setup_rocket(data).launch().unwrap(); |     setup_rocket(data).launch().unwrap(); | ||||||
|  |  | ||||||
|  | @ -1,10 +1,20 @@ | ||||||
| use log::error; | use crate::{utils, Data, MatrixResult, Ruma}; | ||||||
| use http::header::{HeaderValue, AUTHORIZATION}; | use http::header::{HeaderValue, AUTHORIZATION}; | ||||||
|  | use log::error; | ||||||
|  | use rocket::{get, options, post, put, response::content::Json, State}; | ||||||
| use ruma_api::{ | use ruma_api::{ | ||||||
|     error::{FromHttpRequestError, FromHttpResponseError}, |     error::{FromHttpRequestError, FromHttpResponseError}, | ||||||
|     Endpoint, Outgoing, |     Endpoint, Outgoing, | ||||||
| }; | }; | ||||||
| use std::convert::{TryFrom, TryInto}; | use ruma_client_api::error::{Error, ErrorKind}; | ||||||
|  | use ruma_federation_api::{v1::get_server_version, v2::get_server_keys}; | ||||||
|  | use serde_json::json; | ||||||
|  | use std::{ | ||||||
|  |     collections::{BTreeMap, HashMap}, | ||||||
|  |     convert::{TryFrom, TryInto}, | ||||||
|  |     path::PathBuf, | ||||||
|  |     time::{Duration, SystemTime}, | ||||||
|  | }; | ||||||
| 
 | 
 | ||||||
| pub async fn send_request<T: Endpoint>( | pub async fn send_request<T: Endpoint>( | ||||||
|     data: &crate::Data, |     data: &crate::Data, | ||||||
|  | @ -39,7 +49,7 @@ where | ||||||
|     request_map.insert("origin".to_owned(), data.hostname().into()); |     request_map.insert("origin".to_owned(), data.hostname().into()); | ||||||
|     request_map.insert("destination".to_owned(), destination.to_string().into()); |     request_map.insert("destination".to_owned(), destination.to_string().into()); | ||||||
| 
 | 
 | ||||||
|     ruma_signatures::sign_json(data.hostname(), data.keypair(), dbg!(&mut request_json)).unwrap(); |     ruma_signatures::sign_json(data.hostname(), data.keypair(), &mut request_json).unwrap(); | ||||||
|     let signatures = request_json["signatures"] |     let signatures = request_json["signatures"] | ||||||
|         .as_object() |         .as_object() | ||||||
|         .unwrap() |         .unwrap() | ||||||
|  | @ -52,7 +62,16 @@ where | ||||||
|         .map(|(k, v)| (k, v.as_str().unwrap())); |         .map(|(k, v)| (k, v.as_str().unwrap())); | ||||||
| 
 | 
 | ||||||
|     for s in signatures { |     for s in signatures { | ||||||
|         http_request.headers_mut().insert(AUTHORIZATION, HeaderValue::from_str(dbg!(&format!("X-Matrix origin={},key=\"{}\",sig=\"{}\"", data.hostname(), s.0, s.1))).unwrap()); |         http_request.headers_mut().insert( | ||||||
|  |             AUTHORIZATION, | ||||||
|  |             HeaderValue::from_str(&format!( | ||||||
|  |                 "X-Matrix origin={},key=\"{}\",sig=\"{}\"", | ||||||
|  |                 data.hostname(), | ||||||
|  |                 s.0, | ||||||
|  |                 s.1 | ||||||
|  |             )) | ||||||
|  |             .unwrap(), | ||||||
|  |         ); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     let reqwest_response = data |     let reqwest_response = data | ||||||
|  | @ -79,7 +98,13 @@ where | ||||||
|                 .unwrap() |                 .unwrap() | ||||||
|                 .into_iter() |                 .into_iter() | ||||||
|                 .collect(); |                 .collect(); | ||||||
|             Some(<T::Response as Outgoing>::Incoming::try_from(dbg!(http_response.body(body).unwrap())).ok().unwrap()) |             Some( | ||||||
|  |                 <T::Response as Outgoing>::Incoming::try_from( | ||||||
|  |                     dbg!(http_response.body(body)).unwrap(), | ||||||
|  |                 ) | ||||||
|  |                 .ok() | ||||||
|  |                 .unwrap(), | ||||||
|  |             ) | ||||||
|         } |         } | ||||||
|         Err(e) => { |         Err(e) => { | ||||||
|             println!("ERROR: {}", e); |             println!("ERROR: {}", e); | ||||||
|  | @ -87,3 +112,54 @@ where | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | #[get("/.well-known/matrix/server")] | ||||||
|  | pub fn well_known_server(data: State<Data>) -> Json<String> { | ||||||
|  |     rocket::response::content::Json( | ||||||
|  |         json!({ "m.server": "matrixtesting.koesters.xyz:14004"}).to_string(), | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[get("/_matrix/federation/v1/version")] | ||||||
|  | pub fn get_server_version(data: State<Data>) -> MatrixResult<get_server_version::Response, Error> { | ||||||
|  |     MatrixResult(Ok(get_server_version::Response { | ||||||
|  |         server: get_server_version::Server { | ||||||
|  |             name: Some("Conduit".to_owned()), | ||||||
|  |             version: Some(env!("CARGO_PKG_VERSION").to_owned()), | ||||||
|  |         }, | ||||||
|  |     })) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[get("/_matrix/key/v2/server", data = "<body>")] | ||||||
|  | pub fn get_server_keys(data: State<Data>, body: Ruma<get_server_keys::Request>) -> Json<String> { | ||||||
|  |     let mut verify_keys = BTreeMap::new(); | ||||||
|  |     verify_keys.insert( | ||||||
|  |         format!("ed25519:{}", data.keypair().version()), | ||||||
|  |         get_server_keys::VerifyKey { | ||||||
|  |             key: base64::encode_config(data.keypair().public_key(), base64::STANDARD_NO_PAD), | ||||||
|  |         }, | ||||||
|  |     ); | ||||||
|  |     let mut response = serde_json::from_slice( | ||||||
|  |         http::Response::try_from(get_server_keys::Response { | ||||||
|  |             server_name: data.hostname().to_owned(), | ||||||
|  |             verify_keys, | ||||||
|  |             old_verify_keys: BTreeMap::new(), | ||||||
|  |             signatures: BTreeMap::new(), | ||||||
|  |             valid_until_ts: SystemTime::now() + Duration::from_secs(60 * 60 * 24), | ||||||
|  |         }) | ||||||
|  |         .unwrap() | ||||||
|  |         .body(), | ||||||
|  |     ) | ||||||
|  |     .unwrap(); | ||||||
|  |     ruma_signatures::sign_json(data.hostname(), data.keypair(), &mut response).unwrap(); | ||||||
|  |     Json(dbg!(response.to_string())) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[get("/_matrix/key/v2/server/<_key_id>", data = "<body>")] | ||||||
|  | pub fn get_server_keys_deprecated( | ||||||
|  |     data: State<Data>, | ||||||
|  |     body: Ruma<get_server_keys::Request>, | ||||||
|  |     _key_id: String, | ||||||
|  | ) -> Json<String> { | ||||||
|  |     get_server_keys(data, body) | ||||||
|  | } | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue