mirror of
https://github.com/creating2morrow/neveko.git
synced 2025-01-09 12:29:49 +00:00
add exchange and export multisig info orchestration
This commit is contained in:
parent
d21b76df25
commit
660aa3c9bd
3 changed files with 61 additions and 6 deletions
|
@ -136,6 +136,7 @@ fn parse_multisig_message(mid: String) -> MultisigMessageData {
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// // lookup prepare info for vendor
|
/// // lookup prepare info for vendor
|
||||||
|
/// use nevmes_core::db;
|
||||||
/// let s = db::Interface::open();
|
/// let s = db::Interface::open();
|
||||||
/// let key = "prepare-o123-test.b32.i2p";
|
/// let key = "prepare-o123-test.b32.i2p";
|
||||||
/// db::Interface::read(&s.env, &s.handle, &key);
|
/// db::Interface::read(&s.env, &s.handle, &key);
|
||||||
|
@ -168,7 +169,7 @@ pub async fn rx_multisig(m: Json<Message>) {
|
||||||
debug!("writing multisig message type {} for order {}", &data.sub_type, &data.orid);
|
debug!("writing multisig message type {} for order {}", &data.sub_type, &data.orid);
|
||||||
// lookup msig message data by {type}-{order id}-{contact .b32.i2p address}
|
// lookup msig message data by {type}-{order id}-{contact .b32.i2p address}
|
||||||
let msig_key = format!("{}-{}-{}", &data.sub_type, &data.orid, &m.from);
|
let msig_key = format!("{}-{}-{}", &data.sub_type, &data.orid, &m.from);
|
||||||
db::Interface::write(&s.env, &s.handle, &msig_key, &data.info);
|
db::Interface::async_write(&s.env, &s.handle, &msig_key, &data.info).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Message lookup
|
/// Message lookup
|
||||||
|
@ -430,6 +431,9 @@ fn is_fts_clear(r: String) -> bool {
|
||||||
v.len() >= 2 && v[v.len() - 1] == utils::empty_string() && v[0] == utils::empty_string()
|
v.len() >= 2 && v[v.len() - 1] == utils::empty_string() && v[0] == utils::empty_string()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Encrypts and sends the output from the monero-rpc
|
||||||
|
///
|
||||||
|
/// `prepare_multisig_info` method.
|
||||||
pub async fn send_prepare_info(orid: &String, contact: &String) {
|
pub async fn send_prepare_info(orid: &String, contact: &String) {
|
||||||
let s = db::Interface::open();
|
let s = db::Interface::open();
|
||||||
let prepare_info = monero::prepare_wallet().await;
|
let prepare_info = monero::prepare_wallet().await;
|
||||||
|
@ -448,6 +452,9 @@ pub async fn send_prepare_info(orid: &String, contact: &String) {
|
||||||
create(j_message, jwp, MessageType::Multisig).await;
|
create(j_message, jwp, MessageType::Multisig).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Encrypts and sends the output from the monero-rpc
|
||||||
|
///
|
||||||
|
/// `make_multisig_info` method.
|
||||||
pub async fn send_make_info(orid: &String, contact: &String, info: Vec<String>) {
|
pub async fn send_make_info(orid: &String, contact: &String, info: Vec<String>) {
|
||||||
let s = db::Interface::open();
|
let s = db::Interface::open();
|
||||||
let make_info = monero::make_wallet(info).await;
|
let make_info = monero::make_wallet(info).await;
|
||||||
|
@ -466,6 +473,50 @@ pub async fn send_make_info(orid: &String, contact: &String, info: Vec<String>)
|
||||||
create(j_message, jwp, MessageType::Multisig).await;
|
create(j_message, jwp, MessageType::Multisig).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Encrypts and sends the output from the monero-rpc
|
||||||
|
///
|
||||||
|
/// `exchange_multisig_keys` method.
|
||||||
|
pub async fn send_exchange_info(orid: &String, contact: &String, info: Vec<String>) {
|
||||||
|
let s = db::Interface::open();
|
||||||
|
let wallet_password =
|
||||||
|
std::env::var(crate::MONERO_WALLET_PASSWORD).unwrap_or(String::from("password"));
|
||||||
|
let exchange_info = monero::exchange_multisig_keys(false, info, wallet_password).await;
|
||||||
|
let k = format!("{}-{}", "fts-jwp", contact);
|
||||||
|
let jwp = db::Interface::read(&s.env, &s.handle, &k);
|
||||||
|
let body_str = format!("{}:{}:{}", EXCHANGE_MSIG, orid, &exchange_info.result.multisig_info);
|
||||||
|
let message: Message = Message {
|
||||||
|
mid: utils::empty_string(),
|
||||||
|
uid: utils::empty_string(),
|
||||||
|
body: body_str.into_bytes(),
|
||||||
|
created: chrono::Utc::now().timestamp(),
|
||||||
|
from: utils::empty_string(),
|
||||||
|
to: String::from(contact),
|
||||||
|
};
|
||||||
|
let j_message: Json<Message> = utils::message_to_json(&message);
|
||||||
|
create(j_message, jwp, MessageType::Multisig).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Encrypts and sends the output from the monero-rpc
|
||||||
|
///
|
||||||
|
/// `export_multisig_info` method.
|
||||||
|
pub async fn send_export_info(orid: &String, contact: &String) {
|
||||||
|
let s = db::Interface::open();
|
||||||
|
let exchange_info = monero::export_multisig_info().await;
|
||||||
|
let k = format!("{}-{}", "fts-jwp", contact);
|
||||||
|
let jwp = db::Interface::read(&s.env, &s.handle, &k);
|
||||||
|
let body_str = format!("{}:{}:{}", EXPORT_MSIG, orid, &exchange_info.result.info);
|
||||||
|
let message: Message = Message {
|
||||||
|
mid: utils::empty_string(),
|
||||||
|
uid: utils::empty_string(),
|
||||||
|
body: body_str.into_bytes(),
|
||||||
|
created: chrono::Utc::now().timestamp(),
|
||||||
|
from: utils::empty_string(),
|
||||||
|
to: String::from(contact),
|
||||||
|
};
|
||||||
|
let j_message: Json<Message> = utils::message_to_json(&message);
|
||||||
|
create(j_message, jwp, MessageType::Multisig).await;
|
||||||
|
}
|
||||||
|
|
||||||
// Tests
|
// Tests
|
||||||
//-------------------------------------------------------------------------------
|
//-------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
|
@ -120,17 +120,20 @@ pub async fn retrieve_order(
|
||||||
/// Send multisig info for contact's order
|
/// Send multisig info for contact's order
|
||||||
///
|
///
|
||||||
/// Protected: true
|
/// Protected: true
|
||||||
#[post("/multisig/info", data = "<r_info>")]
|
#[post("/", data = "<r_info>")]
|
||||||
pub async fn get_multisig_info(
|
pub async fn get_multisig_info(
|
||||||
r_info: Json<reqres::MultisigInfoRequest>,
|
r_info: Json<reqres::MultisigInfoRequest>,
|
||||||
_jwp: proof::PaymentProof) -> Custom<Json<models::Order>> {
|
_jwp: proof::PaymentProof) -> Custom<Json<models::Order>> {
|
||||||
|
let info: Vec<String> = r_info.info.iter().cloned().collect();
|
||||||
if r_info.msig_type == String::from(message::PREPARE_MSIG) {
|
if r_info.msig_type == String::from(message::PREPARE_MSIG) {
|
||||||
message::send_prepare_info(&r_info.orid, &r_info.contact).await;
|
message::send_prepare_info(&r_info.orid, &r_info.contact).await;
|
||||||
} else {
|
} else if r_info.msig_type == String::from(message::MAKE_MSIG) {
|
||||||
let info: Vec<String> = r_info.info.iter().cloned().collect();
|
|
||||||
message::send_make_info(&r_info.orid, &r_info.contact, info).await;
|
message::send_make_info(&r_info.orid, &r_info.contact, info).await;
|
||||||
|
} else if r_info.msig_type == String::from(message::EXPORT_MSIG) {
|
||||||
|
message::send_export_info(&r_info.orid, &r_info.contact).await;
|
||||||
|
} else {
|
||||||
|
message::send_exchange_info(&r_info.orid, &r_info.contact, info).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
Custom(Status::Ok, Json(Default::default()))
|
Custom(Status::Ok, Json(Default::default()))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -52,6 +52,7 @@ async fn rocket() -> _ {
|
||||||
utils::start_up().await;
|
utils::start_up().await;
|
||||||
rocket::custom(&config)
|
rocket::custom(&config)
|
||||||
.register("/", catchers![internal_error, not_found, payment_required])
|
.register("/", catchers![internal_error, not_found, payment_required])
|
||||||
|
.mount("/multisig/info", routes![controller::get_multisig_info])
|
||||||
.mount("/invoice", routes![controller::gen_invoice])
|
.mount("/invoice", routes![controller::gen_invoice])
|
||||||
.mount("/message/rx", routes![controller::rx_message])
|
.mount("/message/rx", routes![controller::rx_message])
|
||||||
.mount("/message/rx/multisig", routes![controller::rx_multisig_message])
|
.mount("/message/rx/multisig", routes![controller::rx_multisig_message])
|
||||||
|
|
Loading…
Reference in a new issue