Skip to content

Commit

Permalink
Make get_token_supply() yieldy
Browse files Browse the repository at this point in the history
When this method reaches out to methods on bank that do reads, yield the thread
  • Loading branch information
steveluscher committed Dec 13, 2024
1 parent 779b59b commit 02f5c94
Showing 1 changed file with 38 additions and 13 deletions.
51 changes: 38 additions & 13 deletions rpc/src/rpc.rs
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ use {
bincode::{config::Options, serialize},
crossbeam_channel::{unbounded, Receiver, Sender},
jsonrpc_core::{
futures::future::{self, FutureExt},
futures::future::{self, FutureExt, OptionFuture},
types::error,
BoxFuture, Error, Metadata, Result,
},
Expand Down Expand Up @@ -1969,15 +1969,25 @@ impl JsonRpcRequestProcessor {
Ok(new_response(&bank, balance))
}

pub fn get_token_supply(
pub async fn get_token_supply(
&self,
mint: &Pubkey,
commitment: Option<CommitmentConfig>,
) -> Result<RpcResponse<UiTokenAmount>> {
let bank = self.bank(commitment);
let mint_account = bank.get_account(mint).ok_or_else(|| {
Error::invalid_params("Invalid param: could not find account".to_string())
})?;
let mint_account = self
.runtime
.spawn_blocking({
let bank = Arc::clone(&bank);
let mint = Pubkey::clone(mint);
move || {
bank.get_account(&mint).ok_or_else(|| {
Error::invalid_params("Invalid param: could not find account".to_string())
})
}
})
.await
.expect("Failed to spawn blocking task")?;
if !is_known_spl_token_id(mint_account.owner()) {
return Err(Error::invalid_params(
"Invalid param: not a Token mint".to_string(),
Expand All @@ -1987,10 +1997,22 @@ impl JsonRpcRequestProcessor {
Error::invalid_params("Invalid param: mint could not be unpacked".to_string())
})?;

let interest_bearing_config = mint
.get_extension::<InterestBearingConfig>()
.map(|x| (*x, bank.clock().unix_timestamp))
.ok();
let interest_bearing_config = OptionFuture::from(
mint.get_extension::<InterestBearingConfig>()
.map(|interest_bearing_config| {
let bank = Arc::clone(&bank);
async move {
let unix_timestamp = self
.runtime
.spawn_blocking(move || bank.clock().unix_timestamp)
.await
.expect("Failed to spawn blocking task");
(*interest_bearing_config, unix_timestamp)
}
})
.ok(),
)
.await;

let supply = token_amount_to_ui_amount_v2(
mint.base.supply,
Expand Down Expand Up @@ -3205,7 +3227,7 @@ pub mod rpc_accounts {
meta: Self::Metadata,
mint_str: String,
commitment: Option<CommitmentConfig>,
) -> Result<RpcResponse<UiTokenAmount>>;
) -> BoxFuture<Result<RpcResponse<UiTokenAmount>>>;
}

pub struct AccountsDataImpl;
Expand Down Expand Up @@ -3283,10 +3305,13 @@ pub mod rpc_accounts {
meta: Self::Metadata,
mint_str: String,
commitment: Option<CommitmentConfig>,
) -> Result<RpcResponse<UiTokenAmount>> {
) -> BoxFuture<Result<RpcResponse<UiTokenAmount>>> {
debug!("get_token_supply rpc request received: {:?}", mint_str);
let mint = verify_pubkey(&mint_str)?;
meta.get_token_supply(&mint, commitment)
async move {
let mint = verify_pubkey(&mint_str)?;
meta.get_token_supply(&mint, commitment).await
}
.boxed()
}
}
}
Expand Down

0 comments on commit 02f5c94

Please sign in to comment.