mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-06 10:59:28 +00:00
023afaf7ce
* Initial stab at Bulletproofs+ Does move around the existing Bulletproofs code, does still work as expected. * Make the Clsag RCTPrunable type work with BP and BP+ * Initial set of BP+ bug fixes * Further bug fixes * Remove RING_LEN as a constant * Monero v16 TX support Doesn't implement view tags, nor going back to v14, nor the updated BP clawback logic. * Support v14 and v16 at the same time
53 lines
1.2 KiB
Rust
53 lines
1.2 KiB
Rust
use rand::rngs::OsRng;
|
|
|
|
use curve25519_dalek::constants::ED25519_BASEPOINT_TABLE;
|
|
|
|
use serde_json::json;
|
|
|
|
use monero::{
|
|
network::Network,
|
|
util::{key::PublicKey, address::Address},
|
|
};
|
|
|
|
use monero_serai::{
|
|
Protocol, random_scalar,
|
|
rpc::{EmptyResponse, RpcError, Rpc},
|
|
};
|
|
|
|
pub async fn rpc() -> Rpc {
|
|
let rpc = Rpc::new("http://127.0.0.1:18081".to_string());
|
|
|
|
// Only run once
|
|
if rpc.get_height().await.unwrap() != 1 {
|
|
return rpc;
|
|
}
|
|
|
|
let addr = Address::standard(
|
|
Network::Mainnet,
|
|
PublicKey { point: (&random_scalar(&mut OsRng) * &ED25519_BASEPOINT_TABLE).compress() },
|
|
PublicKey { point: (&random_scalar(&mut OsRng) * &ED25519_BASEPOINT_TABLE).compress() },
|
|
)
|
|
.to_string();
|
|
|
|
// Mine 20 blocks to ensure decoy availability
|
|
mine_block(&rpc, &addr).await.unwrap();
|
|
mine_block(&rpc, &addr).await.unwrap();
|
|
assert!(!matches!(rpc.get_protocol().await.unwrap(), Protocol::Unsupported));
|
|
|
|
rpc
|
|
}
|
|
|
|
pub async fn mine_block(rpc: &Rpc, address: &str) -> Result<EmptyResponse, RpcError> {
|
|
rpc
|
|
.rpc_call(
|
|
"json_rpc",
|
|
Some(json!({
|
|
"method": "generateblocks",
|
|
"params": {
|
|
"wallet_address": address,
|
|
"amount_of_blocks": 10
|
|
},
|
|
})),
|
|
)
|
|
.await
|
|
}
|