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
// Copyright (C) 2023 Entropy Cryptography Inc.
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU Affero General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Affero General Public License for more details.
//
// You should have received a copy of the GNU Affero General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
//! A client interface for communicating with the Entropy blockchain
#![allow(clippy::all)]
pub use subxt::PolkadotConfig as EntropyConfig;
use subxt::{
backend::{legacy::LegacyRpcMethods, rpc::RpcClient},
OnlineClient,
};
#[subxt::subxt(
runtime_metadata_path = "entropy_metadata.scale",
substitute_type(
path = "entropy_shared::types::KeyVisibility",
with = "::subxt::utils::Static<::entropy_shared::KeyVisibility>",
),
substitute_type(
path = "entropy_shared::types::ValidatorInfo",
with = "::subxt::utils::Static<::entropy_shared::ValidatorInfo>",
)
)]
pub mod entropy {}
/// Creates an api instance to talk to chain
/// Chain endpoint set on launch
pub async fn get_api(url: &str) -> Result<OnlineClient<EntropyConfig>, subxt::Error> {
// insecure url is fine since binaries are on the same machine
let api = OnlineClient::<EntropyConfig>::from_insecure_url(url).await?;
Ok(api)
}
/// Creates a rpc instance to talk to chain
/// Chain endpoint set on launch
pub async fn get_rpc(url: &str) -> Result<LegacyRpcMethods<EntropyConfig>, subxt::Error> {
// insecure url is fine since binaries are on the same machine
let rpc_client = RpcClient::from_insecure_url(url).await?;
let rpc_methods = LegacyRpcMethods::<EntropyConfig>::new(rpc_client);
Ok(rpc_methods)
}