sui_json_rpc_api/extended.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
// 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::{
CheckpointedObjectID, EpochInfo, EpochPage, QueryObjectsPage, SuiObjectResponseQuery,
};
use sui_open_rpc_macros::open_rpc;
use sui_types::sui_serde::BigInt;
#[open_rpc(namespace = "suix", tag = "Extended API")]
#[rpc(server, client, namespace = "suix")]
pub trait ExtendedApi {
/// Return a list of epoch info
#[method(name = "getEpochs")]
async fn get_epochs(
&self,
/// optional paging cursor
cursor: Option<BigInt<u64>>,
/// maximum number of items per page
limit: Option<usize>,
/// flag to return results in descending order
descending_order: Option<bool>,
) -> RpcResult<EpochPage>;
/// Return current epoch info
#[method(name = "getCurrentEpoch")]
async fn get_current_epoch(&self) -> RpcResult<EpochInfo>;
/// Return the list of queried objects. Note that this is an enhanced full node only api.
#[method(name = "queryObjects")]
async fn query_objects(
&self,
/// the objects query criteria.
query: SuiObjectResponseQuery,
/// An optional paging cursor. If provided, the query will start from the next item after the specified cursor. Default to start from the first item if not specified.
cursor: Option<CheckpointedObjectID>,
/// Max number of items returned per page, default to [QUERY_MAX_RESULT_LIMIT] if not specified.
limit: Option<usize>,
) -> RpcResult<QueryObjectsPage>;
#[method(name = "getTotalTransactions")]
async fn get_total_transactions(&self) -> RpcResult<BigInt<u64>>;
}