|
14 | 14 |
|
15 | 15 | //! JSON-RPC Stub generation for the Owner API
|
16 | 16 | use grin_wallet_libwallet::RetrieveTxQueryArgs;
|
| 17 | +use libwallet::mwixnet::SwapReq; |
17 | 18 | use uuid::Uuid;
|
18 | 19 |
|
19 | 20 | use crate::config::{TorConfig, WalletConfig};
|
20 | 21 | use crate::core::core::OutputFeatures;
|
21 | 22 | use crate::core::global;
|
22 | 23 | use crate::keychain::{Identifier, Keychain};
|
23 | 24 | use crate::libwallet::{
|
24 |
| - AcctPathMapping, Amount, BuiltOutput, Error, InitTxArgs, IssueInvoiceTxArgs, NodeClient, |
25 |
| - NodeHeightResult, OutputCommitMapping, PaymentProof, Slate, SlateVersion, Slatepack, |
26 |
| - SlatepackAddress, StatusMessage, TxLogEntry, VersionedSlate, ViewWallet, WalletInfo, |
27 |
| - WalletLCProvider, |
| 25 | + mwixnet::MixnetReqCreationParams, AcctPathMapping, Amount, BuiltOutput, Error, InitTxArgs, |
| 26 | + IssueInvoiceTxArgs, NodeClient, NodeHeightResult, OutputCommitMapping, PaymentProof, Slate, |
| 27 | + SlateVersion, Slatepack, SlatepackAddress, StatusMessage, TxLogEntry, VersionedSlate, |
| 28 | + ViewWallet, WalletInfo, WalletLCProvider, |
28 | 29 | };
|
29 | 30 | use crate::util::logger::LoggingConfig;
|
30 | 31 | use crate::util::secp::key::{PublicKey, SecretKey};
|
31 |
| -use crate::util::{static_secp_instance, Mutex, ZeroingString}; |
| 32 | +use crate::util::secp::pedersen::Commitment; |
| 33 | +use crate::util::{from_hex, static_secp_instance, Mutex, ZeroingString}; |
32 | 34 | use crate::{ECDHPubkey, Ed25519SecretKey, Owner, Token};
|
33 | 35 | use easy_jsonrpc_mw;
|
34 | 36 | use grin_wallet_util::OnionV3Address;
|
@@ -1963,6 +1965,63 @@ pub trait OwnerRpc {
|
1963 | 1965 | features: OutputFeatures,
|
1964 | 1966 | amount: Amount,
|
1965 | 1967 | ) -> Result<BuiltOutput, Error>;
|
| 1968 | + |
| 1969 | + /** |
| 1970 | + Networked version of [Owner::build_output](struct.Owner.html#method.create_mwixnet_req). |
| 1971 | + ``` |
| 1972 | + # grin_wallet_api::doctest_helper_json_rpc_owner_assert_response!( |
| 1973 | + # r#" |
| 1974 | + { |
| 1975 | + "jsonrpc": "2.0", |
| 1976 | + "method": "create_mwixnet_req", |
| 1977 | + "params": { |
| 1978 | + "token": "d202964900000000d302964900000000d402964900000000d502964900000000", |
| 1979 | + "commitment": "08e1da9e6dc4d6e808a718b2f110a991dd775d65ce5ae408a4e1f002a4961aa9e7", |
| 1980 | + "fee_per_hop": "5000000", |
| 1981 | + "lock_output": true, |
| 1982 | + "server_keys": [ |
| 1983 | + "97444ae673bb92c713c1a2f7b8882ffbfc1c67401a280a775dce1a8651584332", |
| 1984 | + "0c9414341f2140ed34a5a12a6479bf5a6404820d001ab81d9d3e8cc38f049b4e", |
| 1985 | + "b58ece97d60e71bb7e53218400b0d67bfe6a3cb7d3b4a67a44f8fb7c525cbca5" |
| 1986 | + ] |
| 1987 | + }, |
| 1988 | + "id": 1 |
| 1989 | + } |
| 1990 | + # "# |
| 1991 | + # , |
| 1992 | + # r#" |
| 1993 | + { |
| 1994 | + "id": 1, |
| 1995 | + "jsonrpc": "2.0", |
| 1996 | + "result": { |
| 1997 | + "Ok": { |
| 1998 | + "comsig": "099561ed0be59f6502ee358ee4f6760cd16d6be04d58d7a2c1bf2fd09dd7fd2d291beaae5483c6f18d1ceaae6321f06f9ba129a1ee9e7d15f152c67397a621538b5c10bbeb95140dee815c02657c91152939afe389458dc59af095e8e8e5c81a08", |
| 1999 | + "onion": { |
| 2000 | + "commit": "08e1da9e6dc4d6e808a718b2f110a991dd775d65ce5ae408a4e1f002a4961aa9e7", |
| 2001 | + "data": [ |
| 2002 | + "37f68116475e1aa6b58fc911addbd0e04e7aa19ab3e82e7b5cfcaf57d82cf35e7388ce51711cc5ef8cf7630f7dc7229878f91c7ec85991a7fc0051a7bbc66569db3a3aa89ef490055f3c", |
| 2003 | + "b9ff8c0c1699808efce46d581647c65764a28e813023ae677d688282422a07505ae1a051037d7ba58f3279846d0300800fc1c5bfcc548dab815e9fd2f29df9515170c41fa6e4e44b8bcb", |
| 2004 | + "62ea6b8369686a0415e1e752b9b4d6e66cf5b6066a2d3c60d8818890a55f3adff4601466f4c6e6b646568b99ae93549a3595b7a7b4be815ced87d9297cabbd69518d7b2ed6edd14007528fd346aaea765a1165fe886666627ebcab9588b8ee1c9e98395ae67913c48eb6e924581b40182fce807f97312fb07fd5e216d99941f2b488babce4078a50cd66b28b30a66c4f54fcc127437408a99b30ffd6c3d0d8c7d39e864fc04e321b8c10138c8852d4cad0a4f2780412b9dadcc6e0f2657b7803a81bccb809ca392464be2e01755be7377d0e815698ad6ea51d4617cc92c3ccf852f038e33cc9c90992438ba5c49cca7cc188b682da684e2f4c9733a84a7b64ac5c2216ebf5926f0ee67b664fb5bab799109cbee755ce1aebc8cd352fea51cd84c333cb958093c53544c3f3ab05dba64d8f041c3b179796b476ec04b11044e39db6994ab767315e52cc0ef023432ec88ade2911612db7e74e0923889f765b58b00e3869c5072a4e882c1b721913f63bda986b8c97b7ae575f0d4be596a1ac3cd0db96ce6074ee000b32018b3bda16d7dba34a13ba9c3ce983946414c16e278351a3411cb8ef2cb8ef5b6e1667c4c58bc797c0324ae4fec8960d684e561c0e833ee4c3331c6c439b59042a62993535e23cc8a8a4cf705c0f9b1d62db4e3d76c22c01138800414b143ddff471e4df4413e842a1b41f43cc9647e47145fd6c86d4d1a34fb2f62f5a55b31c9353ee34743c548eff955f2d2143c1a86cbcb452104f96d0142db31153021bbeed995c71a92de8fb1f97269533a508085c543fcb3ee57000bb265e74187b858403aa97b6c7b085e5d5b6025cbfe5f6926d33c835f90e60fc62013e80bbe0a855da5938b4b8f83ac29c5e8251827795356222079a6d1612e2fdf93bd7836d1613c7a353ada48ce256f880bbbb3108e037e3b5647101bd4d549101b0ee73d2248a932a802a3b1beb0b69d777c4285d57e91d83e96fe2f8a1a2f182fe2c6ca37b18460cf8d7f56c201147b9be19f1d01f8ad305c1e9c4dd79b5d8719d6550432352cf737082b1e9de7a083ffbe1" |
| 2005 | + ], |
| 2006 | + "pubkey": "e7ee7d51b11d09f268ade98bc9d7ae9be3c4ac124ce1c3a40e50d34460fa5f08" |
| 2007 | + } |
| 2008 | + } |
| 2009 | + } |
| 2010 | + } |
| 2011 | + # "# |
| 2012 | + # , 5, true, true, false, false); |
| 2013 | + ``` |
| 2014 | + * |
| 2015 | + */ |
| 2016 | + |
| 2017 | + fn create_mwixnet_req( |
| 2018 | + &self, |
| 2019 | + token: Token, |
| 2020 | + commitment: String, |
| 2021 | + fee_per_hop: String, |
| 2022 | + lock_output: bool, |
| 2023 | + server_keys: Vec<String>, |
| 2024 | + ) -> Result<SwapReq, Error>; |
1966 | 2025 | }
|
1967 | 2026 |
|
1968 | 2027 | impl<L, C, K> OwnerRpc for Owner<L, C, K>
|
@@ -2372,6 +2431,44 @@ where
|
2372 | 2431 | ) -> Result<BuiltOutput, Error> {
|
2373 | 2432 | Owner::build_output(self, (&token.keychain_mask).as_ref(), features, amount.0)
|
2374 | 2433 | }
|
| 2434 | + |
| 2435 | + fn create_mwixnet_req( |
| 2436 | + &self, |
| 2437 | + token: Token, |
| 2438 | + commitment: String, |
| 2439 | + fee_per_hop: String, |
| 2440 | + lock_output: bool, |
| 2441 | + server_keys: Vec<String>, |
| 2442 | + ) -> Result<SwapReq, Error> { |
| 2443 | + let commit = |
| 2444 | + Commitment::from_vec(from_hex(&commitment).map_err(|e| Error::CommitDeser(e))?); |
| 2445 | + |
| 2446 | + let secp_inst = static_secp_instance(); |
| 2447 | + let secp = secp_inst.lock(); |
| 2448 | + |
| 2449 | + let mut keys = vec![]; |
| 2450 | + for key in server_keys { |
| 2451 | + keys.push(SecretKey::from_slice( |
| 2452 | + &secp, |
| 2453 | + &grin_util::from_hex(&key).map_err(|e| Error::ServerKeyDeser(e))?, |
| 2454 | + )?) |
| 2455 | + } |
| 2456 | + |
| 2457 | + let req_params = MixnetReqCreationParams { |
| 2458 | + server_keys: keys, |
| 2459 | + fee_per_hop: fee_per_hop |
| 2460 | + .parse::<u64>() |
| 2461 | + .map_err(|_| Error::U64Deser(fee_per_hop))?, |
| 2462 | + }; |
| 2463 | + |
| 2464 | + Owner::create_mwixnet_req( |
| 2465 | + self, |
| 2466 | + (&token.keychain_mask).as_ref(), |
| 2467 | + &req_params, |
| 2468 | + &commit, |
| 2469 | + lock_output, |
| 2470 | + ) |
| 2471 | + } |
2375 | 2472 | }
|
2376 | 2473 |
|
2377 | 2474 | /// helper to set up a real environment to run integrated doctests
|
|
0 commit comments