mirror of
https://github.com/serai-dex/serai.git
synced 2024-12-25 13:09:30 +00:00
695d1f0ecf
* Remove subxt Removes ~20 crates from our Cargo.lock. Removes downloading the metadata and enables removing the getMetadata RPC route (relevant to #379). Moves forward #337. Done now due to distinctions in the subxt 0.32 API surface which make it justifiable to not update. * fmt, update due to deny triggering on a yanked crate * Correct the handling of substrate_block_notifier now that it's ephemeral, not long-lived * Correct URL in tests/coordinator from ws to http
48 lines
1 KiB
Rust
48 lines
1 KiB
Rust
use core::time::Duration;
|
|
|
|
use tokio::time::sleep;
|
|
|
|
use scale::Encode;
|
|
|
|
use serai_client::Serai;
|
|
|
|
#[allow(dead_code)]
|
|
pub async fn publish_tx(serai: &Serai, tx: &[u8]) -> [u8; 32] {
|
|
let mut latest = serai
|
|
.block(serai.latest_finalized_block_hash().await.unwrap())
|
|
.await
|
|
.unwrap()
|
|
.unwrap()
|
|
.number();
|
|
|
|
serai.publish(tx).await.unwrap();
|
|
|
|
// Get the block it was included in
|
|
// TODO: Add an RPC method for this/check the guarantee on the subscription
|
|
let mut ticks = 0;
|
|
loop {
|
|
latest += 1;
|
|
|
|
let block = {
|
|
let mut block;
|
|
while {
|
|
block = serai.finalized_block_by_number(latest).await.unwrap();
|
|
block.is_none()
|
|
} {
|
|
sleep(Duration::from_secs(1)).await;
|
|
ticks += 1;
|
|
|
|
if ticks > 60 {
|
|
panic!("60 seconds without inclusion in a finalized block");
|
|
}
|
|
}
|
|
block.unwrap()
|
|
};
|
|
|
|
for transaction in block.transactions() {
|
|
if transaction.encode() == tx {
|
|
return block.hash();
|
|
}
|
|
}
|
|
}
|
|
}
|