mirror of
https://github.com/comit-network/xmr-btc-swap.git
synced 2025-01-23 22:01:21 -05:00
Choose correct lock output automatically
This commit is contained in:
parent
134287d195
commit
a04d6efb39
@ -15,7 +15,7 @@ use monero::{PrivateKey, PublicKey};
|
|||||||
use monero::{Transaction, TransactionPrefix, TxIn, TxOut, VarInt};
|
use monero::{Transaction, TransactionPrefix, TxIn, TxOut, VarInt};
|
||||||
use monero_rpc::monerod;
|
use monero_rpc::monerod;
|
||||||
use monero_rpc::monerod::{GetOutputsOut, MonerodRpc};
|
use monero_rpc::monerod::{GetOutputsOut, MonerodRpc};
|
||||||
use monero_wallet::{MonerodClientExt, Wallet};
|
use monero_wallet::{MonerodClientExt};
|
||||||
use rand::rngs::OsRng;
|
use rand::rngs::OsRng;
|
||||||
use rand::{Rng, SeedableRng};
|
use rand::{Rng, SeedableRng};
|
||||||
use std::convert::TryInto;
|
use std::convert::TryInto;
|
||||||
@ -28,7 +28,7 @@ use std::iter;
|
|||||||
async fn make_blocks() {
|
async fn make_blocks() {
|
||||||
let client = monerod::Client::localhost(18081).unwrap();
|
let client = monerod::Client::localhost(18081).unwrap();
|
||||||
|
|
||||||
client.generateblocks(10, "47HCnKkBEeYfX5pScvBETAKdjBEPN7FcXEJPUqDPzWGCc6wC8VAdS8CjdtgKuSaY72K8fkoswjp176vbSPS8hzS17EZv8gj".to_owned()).await.unwrap();
|
client.generateblocks(10, "498AVruCDWgP9Az9LjMm89VWjrBrSZ2W2K3HFBiyzzrRjUJWUcCVxvY1iitfuKoek2FdX6MKGAD9Qb1G1P8QgR5jPmmt3Vj".to_owned()).await.unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[tokio::test]
|
#[tokio::test]
|
||||||
@ -45,14 +45,19 @@ async fn monerod_integration_test() {
|
|||||||
|
|
||||||
let lock_address = monero::Address::from_keypair(monero::Network::Mainnet, &lock_kp);
|
let lock_address = monero::Address::from_keypair(monero::Network::Mainnet, &lock_kp);
|
||||||
|
|
||||||
let spend_tx = "c9b8c57097fe3af0bffcc7470355afa804be2cad0c559a99506ac040cb93d62d"
|
dbg!(lock_address.to_string());
|
||||||
|
|
||||||
|
let lock_tx = "fccc6c5177f3af65c6c9b26199854da1efcd9b826502d55582ba4882c35410e0"
|
||||||
.parse()
|
.parse()
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
let mut o_indexes_response = client.get_o_indexes(spend_tx).await.unwrap();
|
let o_indexes_response = client.get_o_indexes(lock_tx).await.unwrap();
|
||||||
|
|
||||||
// TODO: Cannot rely on this, because outputs are shuffled
|
let transaction = client.get_transactions(&[lock_tx]).await.unwrap().pop().unwrap();
|
||||||
let real_key_offset = o_indexes_response.o_indexes.pop().unwrap();
|
|
||||||
|
let our_output = transaction.check_outputs(&ViewPair::from(&lock_kp), 0..1, 0..1).expect("to have outputs in this transaction").pop().expect("to own at least one output");
|
||||||
|
|
||||||
|
let real_key_offset = o_indexes_response.o_indexes[our_output.index];
|
||||||
|
|
||||||
let (lower, upper) = client.calculate_key_offset_boundaries().await.unwrap();
|
let (lower, upper) = client.calculate_key_offset_boundaries().await.unwrap();
|
||||||
|
|
||||||
@ -96,7 +101,7 @@ async fn monerod_integration_test() {
|
|||||||
|
|
||||||
let relative_key_offsets = to_relative_offsets(&key_offsets);
|
let relative_key_offsets = to_relative_offsets(&key_offsets);
|
||||||
|
|
||||||
let lock_amount = 10_000_000;
|
let lock_amount = 1_000_000_000_000;
|
||||||
let fee = 10_000;
|
let fee = 10_000;
|
||||||
let spend_amount = lock_amount - fee;
|
let spend_amount = lock_amount - fee;
|
||||||
// TODO: Pay lock amount to shared address (s_prime_a + s_b)
|
// TODO: Pay lock amount to shared address (s_prime_a + s_b)
|
||||||
@ -109,6 +114,7 @@ async fn monerod_integration_test() {
|
|||||||
// TODO: Modify API to let us determine the blindings ahead of time
|
// TODO: Modify API to let us determine the blindings ahead of time
|
||||||
let (bulletproof, out_pk) =
|
let (bulletproof, out_pk) =
|
||||||
monero::make_bulletproof(&mut rng, &[spend_amount], &[out_blinding]).unwrap();
|
monero::make_bulletproof(&mut rng, &[spend_amount], &[out_blinding]).unwrap();
|
||||||
|
|
||||||
let out_pk = out_pk
|
let out_pk = out_pk
|
||||||
.iter()
|
.iter()
|
||||||
.map(|c| monero::util::ringct::CtKey {
|
.map(|c| monero::util::ringct::CtKey {
|
||||||
@ -155,7 +161,7 @@ async fn monerod_integration_test() {
|
|||||||
|
|
||||||
let pseudo_out = {
|
let pseudo_out = {
|
||||||
let amount = Scalar::from(lock_amount);
|
let amount = Scalar::from(lock_amount);
|
||||||
let blinding = -out_blinding;
|
let blinding = out_blinding;
|
||||||
|
|
||||||
let commitment = (blinding * ED25519_BASEPOINT_POINT) + (amount * H.point.decompress().unwrap());
|
let commitment = (blinding * ED25519_BASEPOINT_POINT) + (amount * H.point.decompress().unwrap());
|
||||||
|
|
||||||
|
@ -100,7 +100,7 @@ impl Client {
|
|||||||
let response = response.json::<SendRawTransactionResponse>().await?;
|
let response = response.json::<SendRawTransactionResponse>().await?;
|
||||||
|
|
||||||
if response.status == Status::Failed {
|
if response.status == Status::Failed {
|
||||||
anyhow::bail!("Response status failed")
|
anyhow::bail!("Response status failed: {:?}", response)
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
@ -218,6 +218,14 @@ pub struct SendRawTransactionRequest {
|
|||||||
pub struct SendRawTransactionResponse {
|
pub struct SendRawTransactionResponse {
|
||||||
pub status: Status,
|
pub status: Status,
|
||||||
pub reason: String,
|
pub reason: String,
|
||||||
|
pub double_spend: bool,
|
||||||
|
pub fee_too_low: bool,
|
||||||
|
pub invalid_input: bool,
|
||||||
|
pub invalid_output: bool,
|
||||||
|
pub low_mixin: bool,
|
||||||
|
pub not_relayed: bool,
|
||||||
|
pub overspend: bool,
|
||||||
|
pub too_big: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Copy, Debug, Deserialize, PartialEq)]
|
#[derive(Clone, Copy, Debug, Deserialize, PartialEq)]
|
||||||
|
Loading…
Reference in New Issue
Block a user