mirror of
https://github.com/comit-network/xmr-btc-swap.git
synced 2025-12-01 04:56:41 -05:00
* feat(gui): Monero wallet
* progress
* refactor
* progress, dont delete wallet, re-fetch approvals and background periodically
* show transaction history correctly
* Enable fetching tx hashes
* Try add the wallet listener event callbacks, not working
* fix: Redeem XMR to internal main wallet, not temp wallet
* type safety
* refactoring of callback system
* make free floating functions generic
* refactor: Format files
* refactor(gui): Split wallet components and redesign balanceOverview component
* refactor(gui): Add action buttons and transaction section
* wrapper event listener
* progress, compiles
* works!
* WORKS! Event received on balance change
* refactor: format and slight refactorings and comments
* refactor(gui): Start with implementation of send dialog
- new number input
- new button variant and size
* add @tauri-apps/plugin-dialog
* feat(gui): Add permissions for file dialog
* fix(monero-harness): Compile issue
* feat(gui): Extract seed from Monero wallet and use for derivation, allow opening existing wallet file
* feat(gui): Always refresh the approval list from frontend when resolving
* fix(monero-rpc-pool): Implement Into<String> for ServerInfo
* fix(monero-sys): Use oneshot channel for all wallets
* feat(gui, monero-sys): Display recently opened wallets
* small refactors
* fix(gui): Enable background_sync, display temp "Loading..." if values are null
* feat(gui): Remove headers from pages, show selected navigation item
* feat(gui): Explicitly tell user if no swaps have been made yet
* feat(gui): send sync and history updates
* feat(gui): Fetch monero wallet details when context becomes availiable
* feat(gui): Display Monero primary address without modal
* feat(gui): Make "swap" button on wallet page take you to "/swap"
* feat(gui): Rework send modal, adjust number input, added send to field
* feat(gui): set block restore height, not working
* refactor(gui): Optimize number input and add support for switching between currency
* feat(gui): Display real fiat currency prices in send modal
* feat(gui): Add error message for too high send amount
* feat(gui): Modern UI for SeedSelectionDialog
* feat(gui): Wrap MoneroWalletActions
* wip
* refactoring approval callback
* feat(gui): Send Direction of Transaction in History to Frontend
* feat(gui): Let user approve transaction before publishing
* feat: Display 8 digits for Monero amounts by default
* feat(monero-sys): Store pending (non published) transactions in Mutex map inside wallet thread
This allows seperating signing and publishing transactions cleanly
* dprint fmt
* fix(gui): Refresh Monero wallet history C++ struct before serializing
* feat(monero-rpc-pool): Fail after three JSON-RPC errors
* feat(monero-sys): Add wrapper around verify_wallet_password
* feat(gui): Allow opening password-protected Wallets
* refactor: fmt, remove receive button
* fix(gui): Convert to XMR before converting into Fiat
* feat(gui): Add dialog for setting restore height
* feat(gui): block height can be changed, blocks when too low
* refactor(monero-sys): Remove old WalletListener code
* feat(gui): Continually ask for user to select wallet and enter password, if user rejects, offer to select different wallet
* refactor(swap): Extract "select Monero wallet" into own function
* refactor(tauri): Dont kill monero-wallet-rpc
* refactor(tauri): Avoid multiple concurrent Contexts starting
* refactor: Change "Cancel" to "Change wallet" on PasswordEntryDialog
* feat(gui): show curent block height, fix blockage
* Cargo.lock update
* refactor(monero-sys): Use match instead of is_err() and expect(...)
* refactor: better context for WalletHandle constructor method errors handling
* refactor(monero-sys): Common open_with<F>(path: String, daemon: Daemon, wallet_op: F) function
* feat: check empty password before requeston password for wallet
* feat: Remove "Checking for available remote nodes" from frontend
* feat(gui): Allow sweeping entire Monero balance
* feat(monero-rpc-pool): Keep alive TCP connections, do not record JSON-RPC errors as failure if >=3 nodes failed
If >=3 nodes failed we assume it was an actual issue on our side, not an issue with the node
* refactor(swap): Remove dead code
* add comment to WalletHandleListener::on_refreshed{...}
* feat(gui): show current block height in the field
* refactor: remove unused UserCancelledError;
* refactor: No Arc<Mutex<_>> for Pending TXs map
* refactor: remove redundant } catch (error) {
* feat: add our new crates to `OUR_CRATES` in tracing util
* fix(gui): Add math.ceil to piconero conversion to ensure integer
* fix(gui): Close menu when option is clicked
* review and improve/reduce uses of unsafe, also remove unique_ptr wrapper around TransactionHistory to avoid double free
* fix(gui): Use monero amount from units.tsx
* fix(gui): Use PromiseInvokeButton for simplification for approving of send transaction
* update comment, rename function
* refactor(gui): Fix alignment of amounts
* refactor(gui): Remove sending and refreshing states from wallet
* fix(cli, gui): use old seed flow on no tauri, fix minor issues in gui
* fix: use the new named function
* refactor(gui): Add skeletons for monero wallet when still loading
* refactor(gui): Remove isLoading from wallet slice
* feat(gui): Add success dialog after send transaction was approved
* fix(gui): Floor piconero amount in sendMoneroTransaction
* feat(gui): Allow view on explorer button on send success modal
* feat(backend): save the wallet state on events
* fix(structure): move throttle into its own crate
* fix(log): remove spammy logs
* fix(logs): log folder in confid
* remove "sync progress: " log
* small refactors
* save wallet at most every 60s
* remove useless logs
* underscore unused variables
* feat(gui): Add timestamp of the tx
* feat(gui): Add the legacy wallet init option
* legac ybutton
* Fix(gui, asb): reverse the log config
remove log in bridge.h
cleanup
* use none for .store(..)
* display dot for running swap
---------
Co-authored-by: Maksim Kirillov <maksim.kirillov@staticlabs.de>
Co-authored-by: b-enedict <benedict.seuss@gmail.com>
Co-authored-by: einliterflasche <einliterflasche@pm.me>
100 lines
3.3 KiB
Rust
100 lines
3.3 KiB
Rust
use monero_sys::{Daemon, WalletHandle};
|
|
|
|
const PLACEHOLDER_NODE: &str = "http://127.0.0.1:18081";
|
|
|
|
#[tokio::test]
|
|
async fn test_sign_message() {
|
|
tracing_subscriber::fmt()
|
|
.with_env_filter("info,test=debug,sign_message=trace,monero_sys=trace")
|
|
.with_test_writer()
|
|
.init();
|
|
|
|
let temp_dir = tempfile::tempdir().unwrap();
|
|
let daemon = Daemon {
|
|
address: PLACEHOLDER_NODE.into(),
|
|
ssl: false,
|
|
};
|
|
|
|
let wallet_name = "test_signing_wallet";
|
|
let wallet_path = temp_dir.path().join(wallet_name).display().to_string();
|
|
|
|
tracing::info!("Creating wallet for message signing test");
|
|
let wallet = WalletHandle::open_or_create(
|
|
wallet_path,
|
|
daemon,
|
|
monero::Network::Stagenet,
|
|
false, // No background sync
|
|
)
|
|
.await
|
|
.expect("Failed to create wallet");
|
|
|
|
let main_address = wallet.main_address().await;
|
|
tracing::info!("Wallet main address: {}", main_address);
|
|
|
|
// Test message to sign
|
|
let test_message = "Hello, World! This is a test message for signing.";
|
|
|
|
tracing::info!("Testing message signing with spend key (default address)");
|
|
let signature_spend = wallet
|
|
.sign_message(test_message, None, false)
|
|
.await
|
|
.expect("Failed to sign message with spend key");
|
|
|
|
tracing::info!("Signature with spend key: {}", signature_spend);
|
|
assert!(!signature_spend.is_empty(), "Signature should not be empty");
|
|
assert!(
|
|
signature_spend.len() > 10,
|
|
"Signature should be reasonably long"
|
|
);
|
|
|
|
tracing::info!("Testing message signing with view key (default address)");
|
|
let signature_view = wallet
|
|
.sign_message(test_message, None, true)
|
|
.await
|
|
.expect("Failed to sign message with view key");
|
|
|
|
tracing::info!("Signature with view key: {}", signature_view);
|
|
assert!(!signature_view.is_empty(), "Signature should not be empty");
|
|
assert!(
|
|
signature_view.len() > 10,
|
|
"Signature should be reasonably long"
|
|
);
|
|
|
|
// Signatures should be different when using different keys
|
|
assert_ne!(
|
|
signature_spend, signature_view,
|
|
"Spend key and view key signatures should be different"
|
|
);
|
|
|
|
tracing::info!("Testing message signing with spend key (explicit address)");
|
|
let signature_explicit = wallet
|
|
.sign_message(test_message, Some(&main_address.to_string()), false)
|
|
.await
|
|
.expect("Failed to sign message with explicit address");
|
|
|
|
tracing::info!("Signature with explicit address: {}", signature_explicit);
|
|
assert!(
|
|
!signature_explicit.is_empty(),
|
|
"Signature should not be empty"
|
|
);
|
|
|
|
// When using the same key and same address (main address), signatures should be the same
|
|
assert_eq!(
|
|
signature_spend, signature_explicit,
|
|
"Signatures should be the same when using same key and address"
|
|
);
|
|
|
|
tracing::info!("Testing empty message signing");
|
|
let signature_empty = wallet
|
|
.sign_message("", None, false)
|
|
.await
|
|
.expect("Failed to sign empty message");
|
|
|
|
tracing::info!("Signature for empty message: {}", signature_empty);
|
|
assert!(
|
|
!signature_empty.is_empty(),
|
|
"Signature should not be empty even for empty message"
|
|
);
|
|
|
|
tracing::info!("All message signing tests passed!");
|
|
}
|