From 6cabf8a656e59ee7e0fc3cc540dec2feef345dc7 Mon Sep 17 00:00:00 2001 From: Will Yang Date: Mon, 16 Dec 2024 10:53:02 -0800 Subject: [PATCH] extend PrunableRange::get_range to return an error if from_cp is not < to_cp. Output warning if it tries to fetch from cp_mapping and can't. and remove warning in framework/lib.rs around cp_mapping --- .../src/handlers/cp_sequence_numbers.rs | 53 ++++++++++++------- crates/sui-indexer-alt-framework/src/lib.rs | 5 -- .../src/pipeline/mod.rs | 1 - 3 files changed, 34 insertions(+), 25 deletions(-) diff --git a/crates/sui-indexer-alt-framework/src/handlers/cp_sequence_numbers.rs b/crates/sui-indexer-alt-framework/src/handlers/cp_sequence_numbers.rs index 0355201911627..7ae447639f4de 100644 --- a/crates/sui-indexer-alt-framework/src/handlers/cp_sequence_numbers.rs +++ b/crates/sui-indexer-alt-framework/src/handlers/cp_sequence_numbers.rs @@ -11,6 +11,7 @@ use diesel_async::RunQueryDsl; use sui_field_count::FieldCount; use sui_pg_db::{self as db, Connection}; use sui_types::full_checkpoint_content::CheckpointData; +use tracing::warn; #[derive(Insertable, Selectable, Queryable, Debug, Clone, FieldCount)] #[diesel(table_name = cp_sequence_numbers)] @@ -20,18 +21,25 @@ pub struct StoredCpSequenceNumbers { pub epoch: i64, } -<<<<<<< HEAD:crates/sui-indexer-alt-framework/src/handlers/cp_sequence_numbers.rs pub struct CpSequenceNumbers; -======= /// A struct that can be instantiated by the pruner task to map a `from` and `to` checkpoint to its /// corresponding `tx_lo` and containing epoch. The `from` checkpoint is expected to be inclusive, /// and the `to` checkpoint is exclusive. This requires the existence of the `checkpoint_metadata` /// table. ->>>>>>> 0ad4e6f393 (address first set of comments. trait fn prune still accepts from and to checkpoints, up to handler prune to decide what it needs. doc comments for PrunableRange regarding what it expects on instantiation):crates/sui-indexer-alt-framework/src/handlers/cp_mapping.rs pub struct PrunableRange { - from: StoredCpMapping, - to: StoredCpMapping, + from: StoredCpSequenceNumbers, + to: StoredCpSequenceNumbers, +} + +#[derive(Debug, thiserror::Error)] +pub enum RangeError { + #[error("Invalid checkpoint range: `from` {0} is greater than `to` {1}")] + InvalidCheckpointRange(u64, u64), + #[error("No checkpoint mapping found for checkpoints {0} and {1}")] + NoCheckpointMapping(u64, u64), + #[error("Database error: {0}")] + DbError(diesel::result::Error), } impl PrunableRange { @@ -43,21 +51,28 @@ impl PrunableRange { conn: &mut Connection<'_>, from_cp: u64, to_cp: u64, - ) -> QueryResult { - let results = cp_mapping::table - .select(StoredCpMapping::as_select()) - .filter(cp_mapping::cp_sequence_number.eq_any([from_cp as i64, to_cp as i64])) - .order(cp_mapping::cp_sequence_number.asc()) - .load::(conn) - .await?; - - match results.as_slice() { - [first, .., last] => Ok(PrunableRange { - from: first.clone(), - to: last.clone(), - }), - _ => Err(diesel::result::Error::NotFound), + ) -> Result { + if from_cp > to_cp { + return Err(RangeError::InvalidCheckpointRange(from_cp, to_cp)); } + + let results = cp_sequence_numbers::table + .select(StoredCpSequenceNumbers::as_select()) + .filter(cp_sequence_numbers::cp_sequence_number.eq_any([from_cp as i64, to_cp as i64])) + .order(cp_sequence_numbers::cp_sequence_number.asc()) + .load::(conn) + .await + .map_err(RangeError::DbError)?; + + let [first, last] = results.as_slice() else { + warn!("No checkpoint mapping found for checkpoint {from_cp} and {to_cp}. Found {} mapping(s) instead of 2", results.len()); + return Err(RangeError::NoCheckpointMapping(from_cp, to_cp)); + }; + + Ok(PrunableRange { + from: first.clone(), + to: last.clone(), + }) } /// Inclusive start and exclusive end range of prunable checkpoints. diff --git a/crates/sui-indexer-alt-framework/src/lib.rs b/crates/sui-indexer-alt-framework/src/lib.rs index 258ba8f0d5893..ad07b09718563 100644 --- a/crates/sui-indexer-alt-framework/src/lib.rs +++ b/crates/sui-indexer-alt-framework/src/lib.rs @@ -302,11 +302,6 @@ impl Indexer { ); } - let cp_mapping_enabled = self.added_pipelines.contains("cp_mapping"); - if !cp_mapping_enabled { - warn!("cp_mapping pipeline is not enabled on this indexer instance. Tables configured for pruning may not actually be pruned if cp_mapping is not written to."); - } - let metrics_handle = self .metrics_service .run() diff --git a/crates/sui-indexer-alt-framework/src/pipeline/mod.rs b/crates/sui-indexer-alt-framework/src/pipeline/mod.rs index bfcff97743a3b..08604023d0f66 100644 --- a/crates/sui-indexer-alt-framework/src/pipeline/mod.rs +++ b/crates/sui-indexer-alt-framework/src/pipeline/mod.rs @@ -3,7 +3,6 @@ use std::time::Duration; -pub use crate::handlers::cp_mapping::PrunableRange; use crate::watermarks::CommitterWatermark; pub use processor::Processor;