1pub mod config;
21pub mod indexer;
22pub mod proto;
23pub mod reader;
24pub mod schema;
25
26use std::path::Path;
27
28use prometheus::Registry;
29use sui_consistent_store::DbOptions;
30use sui_indexer_alt_framework::IndexerArgs;
31use sui_indexer_alt_framework::ingestion::BoxedStreamingClient;
32use sui_indexer_alt_framework::ingestion::ClientArgs;
33use sui_indexer_alt_framework::ingestion::IngestionConfig;
34use sui_indexer_alt_framework::ingestion::ingestion_client::IngestionClient;
35use sui_indexer_alt_framework::ingestion::streaming_client::GrpcStreamingClient;
36use sui_indexer_alt_framework::metrics::IngestionMetrics;
37use sui_indexer_alt_framework::pipeline::CommitterConfig;
38use sui_indexer_alt_framework::service::Service;
39
40pub use crate::config::CommitterLayer;
41pub use crate::config::ConsistencyConfig;
42pub use crate::config::PipelineLayer;
43pub use crate::config::PrunerConfig;
44pub use crate::config::RestoreLayer;
45pub use crate::config::ServiceConfig;
46pub use crate::indexer::Indexer;
47pub use crate::indexer::METRICS_PREFIX;
48pub use crate::indexer::Store;
49pub use crate::indexer::checkpoint_broadcast::CheckpointBroadcast;
50pub use crate::indexer::checkpoint_broadcast::seed_watermark_to_tip as seed_checkpoint_broadcast_watermark;
51pub use crate::indexer::pruner::prune_history_cohort;
52pub use crate::indexer::restore::HISTORY_COHORT;
53pub use crate::indexer::restore::LIVE_COHORT;
54pub use crate::indexer::restore::floor_unrestored_pipelines;
55pub use crate::indexer::restore::restore_indexes;
56pub use crate::indexer::restore::seed_current_epoch_start;
57pub use crate::indexer::restore::seed_history_cohort;
58pub use crate::reader::RpcStoreReader;
59pub use crate::schema::RpcStoreSchema;
60pub use crate::schema::default_rocksdb_config;
61
62pub async fn start_indexer(
77 path: impl AsRef<Path>,
78 indexer_args: IndexerArgs,
79 client_args: ClientArgs,
80 db_options: DbOptions,
81 ingestion_config: IngestionConfig,
82 config: ServiceConfig,
83 registry: &Registry,
84) -> anyhow::Result<Service> {
85 let metrics_prefix = Some(METRICS_PREFIX);
86
87 let ingestion_metrics = IngestionMetrics::new(metrics_prefix, registry);
92 let ingestion_client = IngestionClient::new(client_args.ingestion, ingestion_metrics)?;
93 let streaming_client: Option<BoxedStreamingClient> =
94 client_args.streaming.streaming_url.map(|uri| {
95 Box::new(GrpcStreamingClient::new(
96 uri,
97 ingestion_config.streaming_connection_timeout(),
98 ingestion_config.streaming_statement_timeout(),
99 )) as BoxedStreamingClient
100 });
101
102 let mut indexer = Indexer::new(
103 path,
104 indexer_args,
105 ingestion_client,
106 streaming_client,
107 config.consistency,
108 config.pruner,
109 ingestion_config,
110 db_options,
111 registry,
112 )
113 .await?;
114
115 let committer = config.committer.finish(CommitterConfig::default());
116 indexer.add_pipelines(config.pipeline, committer).await?;
117
118 indexer.run().await
119}