From 8689b9fb22b117d36e1997b7139f0daeacf7142f Mon Sep 17 00:00:00 2001 From: Ashwin Sekar Date: Wed, 9 Aug 2023 20:15:24 +0000 Subject: [PATCH] rpc: get_feature_activation_slot should not error for inactive features --- rpc-client/src/rpc_client.rs | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/rpc-client/src/rpc_client.rs b/rpc-client/src/rpc_client.rs index 3e60381a413725..afccd7af003290 100644 --- a/rpc-client/src/rpc_client.rs +++ b/rpc-client/src/rpc_client.rs @@ -4029,15 +4029,22 @@ impl RpcClient { } pub fn get_feature_activation_slot(&self, feature_id: &Pubkey) -> ClientResult> { - self.get_account(feature_id) - .and_then(|feature_account| { - bincode::deserialize(feature_account.data()).map_err(|_| { - ClientError::from(ErrorKind::Custom( - "Failed to deserialize feature account".to_string(), - )) - }) + self.get_account_with_commitment(feature_id, self.commitment()) + .and_then(|maybe_feature_account| { + maybe_feature_account + .value + .map(|feature_account| { + bincode::deserialize(feature_account.data()).map_err(|_| { + ClientError::from(ErrorKind::Custom( + "Failed to deserialize feature account".to_string(), + )) + }) + }) + .transpose() + }) + .map(|maybe_feature: Option| { + maybe_feature.and_then(|feature| feature.activated_at) }) - .map(|feature: Feature| feature.activated_at) } fn invoke>>(&self, f: F) -> ClientResult {