sui_json_rpc_api/coin.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
// Copyright (c) Mysten Labs, Inc.
// SPDX-License-Identifier: Apache-2.0
use jsonrpsee::core::RpcResult;
use jsonrpsee::proc_macros::rpc;
use sui_json_rpc_types::{Balance, CoinPage, SuiCoinMetadata};
use sui_open_rpc_macros::open_rpc;
use sui_types::balance::Supply;
use sui_types::base_types::SuiAddress;
#[open_rpc(namespace = "suix", tag = "Coin Query API")]
#[rpc(server, client, namespace = "suix")]
pub trait CoinReadApi {
/// Return all Coin<`coin_type`> objects owned by an address.
#[method(name = "getCoins")]
async fn get_coins(
&self,
/// the owner's Sui address
owner: SuiAddress,
/// optional type name for the coin (e.g., 0x168da5bf1f48dafc111b0a488fa454aca95e0b5e::usdc::USDC), default to 0x2::sui::SUI if not specified.
coin_type: Option<String>,
/// optional paging cursor
cursor: Option<String>,
/// maximum number of items per page
limit: Option<usize>,
) -> RpcResult<CoinPage>;
/// Return all Coin objects owned by an address.
#[method(name = "getAllCoins")]
async fn get_all_coins(
&self,
/// the owner's Sui address
owner: SuiAddress,
/// optional paging cursor
cursor: Option<String>,
/// maximum number of items per page
limit: Option<usize>,
) -> RpcResult<CoinPage>;
/// Return the total coin balance for one coin type, owned by the address owner.
#[method(name = "getBalance")]
async fn get_balance(
&self,
/// the owner's Sui address
owner: SuiAddress,
/// optional type names for the coin (e.g., 0x168da5bf1f48dafc111b0a488fa454aca95e0b5e::usdc::USDC), default to 0x2::sui::SUI if not specified.
coin_type: Option<String>,
) -> RpcResult<Balance>;
/// Return the total coin balance for all coin type, owned by the address owner.
#[method(name = "getAllBalances")]
async fn get_all_balances(
&self,
/// the owner's Sui address
owner: SuiAddress,
) -> RpcResult<Vec<Balance>>;
/// Return metadata (e.g., symbol, decimals) for a coin. Note that if the coin's metadata was
/// wrapped in the transaction that published its marker type, or the latest version of the
/// metadata object is wrapped or deleted, it will not be found.
#[method(name = "getCoinMetadata")]
async fn get_coin_metadata(
&self,
/// type name for the coin (e.g., 0x168da5bf1f48dafc111b0a488fa454aca95e0b5e::usdc::USDC)
coin_type: String,
) -> RpcResult<Option<SuiCoinMetadata>>;
/// Return total supply for a coin
#[method(name = "getTotalSupply")]
async fn get_total_supply(
&self,
/// type name for the coin (e.g., 0x168da5bf1f48dafc111b0a488fa454aca95e0b5e::usdc::USDC)
coin_type: String,
) -> RpcResult<Supply>;
}