From 1d7dd0a986b8aae2fa39a0eb529c78a9a1073561 Mon Sep 17 00:00:00 2001 From: buffalu <85544055+buffalu@users.noreply.github.com> Date: Fri, 15 Nov 2024 15:43:29 -0600 Subject: [PATCH] Do not use is_startup_completed (#59) (#61) BP #59 --- server/src/geyser_grpc_plugin.rs | 16 ++++------------ 1 file changed, 4 insertions(+), 12 deletions(-) diff --git a/server/src/geyser_grpc_plugin.rs b/server/src/geyser_grpc_plugin.rs index 6aba96b..418292e 100644 --- a/server/src/geyser_grpc_plugin.rs +++ b/server/src/geyser_grpc_plugin.rs @@ -55,6 +55,8 @@ pub struct PluginData { /// Highest slot that an account write has been processed for thus far. highest_write_slot: Arc, + /// Only set to true if account_data_notifications_enabled is true + /// Otherwise, will always be false is_startup_completed: AtomicBool, ignore_startup_updates: bool, account_data_notifications_enabled: bool, @@ -219,6 +221,8 @@ impl GeyserPlugin for GeyserGrpcPlugin { data.runtime.shutdown_background(); } + /// Note: this is called only if account_data_notifications_enabled is set to true. + /// Do not use it for anything except for account updates fn notify_end_of_startup(&self) -> PluginResult<()> { self.data .as_ref() @@ -345,10 +349,6 @@ impl GeyserPlugin for GeyserGrpcPlugin { ) -> PluginResult<()> { let data = self.data.as_ref().expect("plugin must be initialized"); - if data.ignore_startup_updates && !data.is_startup_completed.load(Ordering::Relaxed) { - return Ok(()); - } - debug!("Updating slot {:?} at with status {:?}", slot, status); let status = match status { @@ -386,10 +386,6 @@ impl GeyserPlugin for GeyserGrpcPlugin { ) -> PluginResult<()> { let data = self.data.as_ref().expect("plugin must be initialized"); - if data.ignore_startup_updates && !data.is_startup_completed.load(Ordering::Relaxed) { - return Ok(()); - } - let transaction_update = match transaction { ReplicaTransactionInfoVersions::V0_0_1(tx) => TimestampedTransactionUpdate { ts: Some(prost_types::Timestamp::from(SystemTime::now())), @@ -437,10 +433,6 @@ impl GeyserPlugin for GeyserGrpcPlugin { fn notify_block_metadata(&self, block_info: ReplicaBlockInfoVersions) -> PluginResult<()> { let data = self.data.as_ref().expect("plugin must be initialized"); - if data.ignore_startup_updates && !data.is_startup_completed.load(Ordering::Relaxed) { - return Ok(()); - } - let block = match block_info { ReplicaBlockInfoVersions::V0_0_1(block) => TimestampedBlockUpdate { ts: Some(prost_types::Timestamp::from(SystemTime::now())),