standardize names, path vs raw_path distinction

This commit is contained in:
bitful-pannul 2023-10-20 19:26:19 +02:00
parent ec281673a4
commit c1529cef21
2 changed files with 46 additions and 11 deletions

View File

@ -43,19 +43,21 @@ pub async fn http_server(
// Add RPC path // Add RPC path
let mut bindings_map: Router<BoundPath> = Router::new(); let mut bindings_map: Router<BoundPath> = Router::new();
let rpc_bound_path = BoundPath { let rpc_bound_path = BoundPath {
app: ProcessId::from_str("rpc:rpc:uqbar").unwrap(), app: ProcessId::from_str("rpc:sys:uqbar").unwrap(),
authenticated: false, authenticated: false,
local_only: true, local_only: true,
original_path: "/rpc:sys:uqbar/message".to_string(),
}; };
bindings_map.add("/rpc/message", rpc_bound_path); bindings_map.add("/rpc:sys:uqbar/message", rpc_bound_path);
// Add encryptor binding // Add encryptor binding
let encryptor_bound_path = BoundPath { let encryptor_bound_path = BoundPath {
app: ProcessId::from_str("encryptor:sys:uqbar").unwrap(), app: ProcessId::from_str("encryptor:sys:uqbar").unwrap(),
authenticated: false, authenticated: false,
local_only: true, local_only: true,
original_path: "/encryptor:sys:uqbar".to_string(),
}; };
bindings_map.add("/encryptor", encryptor_bound_path); bindings_map.add("/encryptor:sys:uqbar", encryptor_bound_path);
let path_bindings: PathBindings = Arc::new(Mutex::new(bindings_map)); let path_bindings: PathBindings = Arc::new(Mutex::new(bindings_map));
@ -240,7 +242,7 @@ async fn http_handle_messages(
None => {} None => {}
Some((path, channel)) => { Some((path, channel)) => {
// if path is /rpc/message, return accordingly with base64 encoded payload // if path is /rpc/message, return accordingly with base64 encoded payload
if path == "/rpc/message".to_string() { if path == "/rpc:sys:uqbar/message".to_string() {
let payload = payload.map(|p| { let payload = payload.map(|p| {
let bytes = p.bytes; let bytes = p.bytes;
let base64_bytes = base64::encode(&bytes); let base64_bytes = base64::encode(&bytes);
@ -379,6 +381,7 @@ async fn http_handle_messages(
app: source.process, app: source.process,
authenticated: authenticated, authenticated: authenticated,
local_only: local_only, local_only: local_only,
original_path: path.clone(),
}; };
path_bindings.add(&path, bound_path); path_bindings.add(&path, bound_path);
@ -726,9 +729,11 @@ async fn handler(
if let Ok(route) = path_bindings.recognize(&raw_path) { if let Ok(route) = path_bindings.recognize(&raw_path) {
let bound_path = route.handler(); let bound_path = route.handler();
let app = bound_path.app.to_string(); let app = bound_path.app.to_string();
let url_params: HashMap<&str, &str> = route.params().into_iter().collect(); let url_params: HashMap<&str, &str> = route.params().into_iter().collect();
let path = remove_process_id(&raw_path); let raw_path = remove_process_id(&raw_path);
let path = remove_process_id(&bound_path.original_path);
if bound_path.authenticated { if bound_path.authenticated {
let auth_token = real_headers.get("cookie").cloned().unwrap_or_default(); let auth_token = real_headers.get("cookie").cloned().unwrap_or_default();
@ -745,11 +750,11 @@ async fn handler(
headers.insert("Content-Type".to_string(), "text/html".to_string()); headers.insert("Content-Type".to_string(), "text/html".to_string());
} }
// RPC functionality: if path is /rpc/message, // RPC functionality: if path is /rpc:sys:uqbar/message,
// we extract message from base64 encoded bytes in data // we extract message from base64 encoded bytes in data
// and send it to the correct app. // and send it to the correct app.
if app == "rpc:rpc:uqbar".to_string() { if app == "rpc:sys:uqbar".to_string() {
let rpc_message: RpcMessage = match serde_json::from_slice(&body) { let rpc_message: RpcMessage = match serde_json::from_slice(&body) {
// to_vec()? // to_vec()?
Ok(v) => v, Ok(v) => v,
@ -760,6 +765,15 @@ async fn handler(
} }
}; };
let target_process = match ProcessId::from_str(&rpc_message.process) {
Ok(p) => p,
Err(_) => {
return Ok(
warp::reply::with_status(vec![], StatusCode::BAD_REQUEST).into_response()
);
}
};
let payload = match base64::decode(&rpc_message.data.unwrap_or("".to_string())) { let payload = match base64::decode(&rpc_message.data.unwrap_or("".to_string())) {
Ok(bytes) => Some(Payload { Ok(bytes) => Some(Payload {
mime: rpc_message.mime, mime: rpc_message.mime,
@ -780,7 +794,7 @@ async fn handler(
}, },
target: Address { target: Address {
node: node, node: node,
process: ProcessId::from_str(&rpc_message.process).unwrap(), // DOUBLECHECK process: target_process,
}, },
rsvp: Some(Address { rsvp: Some(Address {
node: our.clone(), node: our.clone(),
@ -798,12 +812,25 @@ async fn handler(
} else if app == "encryptor:sys:uqbar".to_string() { } else if app == "encryptor:sys:uqbar".to_string() {
let body_json = match String::from_utf8(body.to_vec()) { let body_json = match String::from_utf8(body.to_vec()) {
Ok(s) => s, Ok(s) => s,
Err(_) => String::new(), Err(_) => {
return Ok(
warp::reply::with_status(vec![], StatusCode::BAD_REQUEST).into_response()
);
}
};
let body: serde_json::Value = match serde_json::from_str(&body_json) {
Ok(v) => v,
Err(_) => {
return Ok(
warp::reply::with_status(vec![], StatusCode::BAD_REQUEST).into_response()
);
}
}; };
let body: serde_json::Value = serde_json::from_str(&body_json).unwrap(); // doublecheck
let channel_id = body["channel_id"].as_str().unwrap_or(""); let channel_id = body["channel_id"].as_str().unwrap_or("");
let public_key_hex = body["public_key_hex"].as_str().unwrap_or(""); let public_key_hex = body["public_key_hex"].as_str().unwrap_or("");
km = Some(KernelMessage { km = Some(KernelMessage {
id, id,
source: Address { source: Address {
@ -876,13 +903,20 @@ async fn handler(
return Ok(warp::reply::with_status(vec![], StatusCode::NOT_FOUND).into_response()); return Ok(warp::reply::with_status(vec![], StatusCode::NOT_FOUND).into_response());
} }
let message = match km {
Some(m) => m,
None => {
return Ok(warp::reply::with_status(vec![], StatusCode::INTERNAL_SERVER_ERROR)
.into_response())
}
};
let (response_sender, response_receiver) = oneshot::channel(); let (response_sender, response_receiver) = oneshot::channel();
http_response_senders http_response_senders
.lock() .lock()
.await .await
.insert(id, (raw_path.clone(), response_sender)); .insert(id, (raw_path.clone(), response_sender));
let message = km.unwrap(); // DOUBLECHECK
send_to_loop.send(message).await.unwrap(); send_to_loop.send(message).await.unwrap();
let from_channel = response_receiver.await.unwrap(); let from_channel = response_receiver.await.unwrap();

View File

@ -19,6 +19,7 @@ pub struct BoundPath {
pub app: ProcessId, pub app: ProcessId,
pub authenticated: bool, pub authenticated: bool,
pub local_only: bool, pub local_only: bool,
pub original_path: String,
} }
#[derive(Serialize, Deserialize)] #[derive(Serialize, Deserialize)]