#api #transaction #radix #within #request #internet-computer #gateway

ic-radix-rs

A library for interacting Radix DLT within the Internet Computer

3 releases

0.0.3 Jun 10, 2024
0.0.2 Jun 10, 2024
0.0.1 May 16, 2024

#49 in #internet-computer

MIT license

1MB
7.5K SLoC

ic-radix-rs

A Rust implementation of the Radix Gateway API Client for the Internet Computer.

Features

  • Perform API Calls to the Radix Gateway API within canisters

Usage

Add the following to your Cargo.toml:

[dependencies]
ic-radix-rs = "0.0.1"

Example

use candid::{export_service, CandidType, Deserialize};
use ic_cdk::api::management_canister::http_request::{HttpResponse, TransformArgs};
use ic_radix_rs::apis::transaction_api::transaction_construction;
use serde::Serialize;

#[ic_cdk::update]
async fn example_transaction_construction() -> Response {
    let cfg = ic_radix_rs::apis::configuration::Configuration::new();
    let result = transaction_construction(&cfg).await.unwrap();
    Response {
        network: result.ledger_state.network,
        state_version: result.ledger_state.state_version,
        proposer_round_timestamp: result.ledger_state.proposer_round_timestamp,
        epoch: result.ledger_state.epoch,
        round: result.ledger_state.round,
    }
}

#[ic_cdk::query]
fn transform(args: TransformArgs) -> HttpResponse {
    args.response
}

#[derive(CandidType, Deserialize, Serialize)]
struct Response {
    /// The logical name of the network
    pub network: String,
    /// The state version of the ledger. Each transaction increments the state version by 1.
    pub state_version: i64,
    /// The proposer round timestamp of the consensus round when this transaction was committed to ledger. This is not guaranteed to be strictly increasing, as it is computed as an average across the validator set. If this is significantly behind the current timestamp, the Network Gateway is likely reporting out-dated information, or the network has stalled.
    pub proposer_round_timestamp: String,
    /// The epoch number of the ledger at this state version.
    pub epoch: i64,
    /// The consensus round in the epoch that this state version was committed in.
    pub round: i64,
}

Start a local replica:

dfx start

Deploy the canister:

dfx deploy

Call the canister:

dfx canister call examples_backend example_transaction_construction

Then you will get a response like this:

(
  record {
    state_version = 84_154_806 : int64;
    proposer_round_timestamp = "2024-05-16T07:31:34.07Z";
    network = "mainnet";
    epoch = 98_981 : int64;
    round = 161 : int64;
  },
)

Dependencies

~4–14MB
~200K SLoC