From d1d7e103ccd3cc84c2ed4a033b6eaf3a2538abbf Mon Sep 17 00:00:00 2001 From: Zeljko Mihaljcic <7150613+zehiko@users.noreply.github.com> Date: Thu, 16 Jan 2025 13:24:42 +0100 Subject: [PATCH 1/3] define Catalog fields name in the protobuf spec crate and use it in the catalog view --- crates/store/re_grpc_client/src/lib.rs | 26 +++++++++++++++++--------- crates/store/re_protos/src/lib.rs | 12 ++++++++++++ 2 files changed, 29 insertions(+), 9 deletions(-) diff --git a/crates/store/re_grpc_client/src/lib.rs b/crates/store/re_grpc_client/src/lib.rs index 63471503527c..c3938634126f 100644 --- a/crates/store/re_grpc_client/src/lib.rs +++ b/crates/store/re_grpc_client/src/lib.rs @@ -22,7 +22,8 @@ use re_protos::{ common::v0::RecordingId, remote_store::v0::{ storage_node_client::StorageNodeClient, CatalogFilter, FetchRecordingRequest, - QueryCatalogRequest, + QueryCatalogRequest, CATALOG_APP_ID_FIELD_NAME, CATALOG_ID_FIELD_NAME, + CATALOG_START_TIME_FIELD_NAME, }, }; use re_types::{ @@ -280,29 +281,36 @@ pub fn store_info_from_catalog_chunk( ) -> Result { let store_id = StoreId::from_string(StoreKind::Recording, recording_id.to_owned()); + println!("TC: {tc:?}"); let (_field, data) = tc .components() - .find(|(f, _)| f.name() == "application_id") + .find(|(f, _)| f.name() == CATALOG_APP_ID_FIELD_NAME) .ok_or(StreamError::ChunkError(re_chunk::ChunkError::Malformed { - reason: "no application_id field found".to_owned(), + reason: "no {APP_ID_FIELD_NAME} field found".to_owned(), }))?; let app_id = data .downcast_array_ref::() .ok_or(StreamError::ChunkError(re_chunk::ChunkError::Malformed { - reason: format!("application_id must be a utf8 array: {:?}", tc.schema_ref()), + reason: format!( + "{CATALOG_APP_ID_FIELD_NAME} must be a utf8 array: {:?}", + tc.schema_ref() + ), }))? .value(0); let (_field, data) = tc .components() - .find(|(f, _)| f.name() == "start_time") + .find(|(f, _)| f.name() == CATALOG_START_TIME_FIELD_NAME) .ok_or(StreamError::ChunkError(re_chunk::ChunkError::Malformed { - reason: "no start_time field found".to_owned(), + reason: "no {START_TIME_FIELD}} field found".to_owned(), }))?; let start_time = data - .downcast_array_ref::() + .downcast_array_ref::() .ok_or(StreamError::ChunkError(re_chunk::ChunkError::Malformed { - reason: format!("start_time must be an int64 array: {:?}", tc.schema_ref()), + reason: format!( + "{CATALOG_START_TIME_FIELD_NAME} must be a Timestamp array: {:?}", + tc.schema_ref() + ), }))? .value(0); @@ -484,7 +492,7 @@ async fn stream_catalog_async( )))?; let recording_uri_arrays: Vec = chunk - .iter_slices::("id".into()) + .iter_slices::(CATALOG_ID_FIELD_NAME.into()) .map(|id| { let rec_id = &id[0]; // each component batch is of length 1 i.e. single 'id' value diff --git a/crates/store/re_protos/src/lib.rs b/crates/store/re_protos/src/lib.rs index e41036697752..df3a13b66375 100644 --- a/crates/store/re_protos/src/lib.rs +++ b/crates/store/re_protos/src/lib.rs @@ -48,8 +48,20 @@ pub mod log_msg { /// Generated types for the remote store gRPC service API v0. pub mod remote_store { + pub mod v0 { pub use crate::v0::rerun_remote_store_v0::*; + + /// Recording catalog mandatory field names. All mandatory metadata fields are prefixed + /// with "rerun_" to avoid conflicts with user-defined fields. + pub const CATALOG_ID_FIELD_NAME: &str = "rerun_recording_id"; + pub const CATALOG_APP_ID_FIELD_NAME: &str = "rerun_application_id"; + pub const CATALOG_START_TIME_FIELD_NAME: &str = "rerun_start_time"; + pub const CATALOG_DESCRIPTION_FIELD_NAME: &str = "rerun_description"; + pub const CATALOG_RECORDING_TYPE_FIELD_NAME: &str = "rerun_recording_type"; + pub const CATALOG_STORAGE_URL_FIELD_NAME: &str = "rerun_storage_url"; + pub const CATALOG_REGISTRATION_TIME_FIELD_NAME: &str = "rerun_registration_time"; + pub const CATALOG_ROW_ID_FIELD_NAME: &str = "rerun_row_id"; } } From 14c8fc9dfee0f7184ab5947575f958c2ac7b2fba Mon Sep 17 00:00:00 2001 From: Zeljko Mihaljcic <7150613+zehiko@users.noreply.github.com> Date: Fri, 17 Jan 2025 08:06:26 +0100 Subject: [PATCH 2/3] remove println --- crates/store/re_grpc_client/src/lib.rs | 1 - 1 file changed, 1 deletion(-) diff --git a/crates/store/re_grpc_client/src/lib.rs b/crates/store/re_grpc_client/src/lib.rs index c3938634126f..1409bd367f4a 100644 --- a/crates/store/re_grpc_client/src/lib.rs +++ b/crates/store/re_grpc_client/src/lib.rs @@ -281,7 +281,6 @@ pub fn store_info_from_catalog_chunk( ) -> Result { let store_id = StoreId::from_string(StoreKind::Recording, recording_id.to_owned()); - println!("TC: {tc:?}"); let (_field, data) = tc .components() .find(|(f, _)| f.name() == CATALOG_APP_ID_FIELD_NAME) From 3a2a8e44c765273ec6fe935a88501c107f50e29d Mon Sep 17 00:00:00 2001 From: Zeljko Mihaljcic <7150613+zehiko@users.noreply.github.com> Date: Fri, 17 Jan 2025 08:11:35 +0100 Subject: [PATCH 3/3] renaming leftovers --- crates/store/re_grpc_client/src/lib.rs | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/crates/store/re_grpc_client/src/lib.rs b/crates/store/re_grpc_client/src/lib.rs index 1409bd367f4a..e85f5bb31002 100644 --- a/crates/store/re_grpc_client/src/lib.rs +++ b/crates/store/re_grpc_client/src/lib.rs @@ -285,7 +285,7 @@ pub fn store_info_from_catalog_chunk( .components() .find(|(f, _)| f.name() == CATALOG_APP_ID_FIELD_NAME) .ok_or(StreamError::ChunkError(re_chunk::ChunkError::Malformed { - reason: "no {APP_ID_FIELD_NAME} field found".to_owned(), + reason: "no {CATALOG_APP_ID_FIELD_NAME} field found".to_owned(), }))?; let app_id = data .downcast_array_ref::() @@ -301,7 +301,7 @@ pub fn store_info_from_catalog_chunk( .components() .find(|(f, _)| f.name() == CATALOG_START_TIME_FIELD_NAME) .ok_or(StreamError::ChunkError(re_chunk::ChunkError::Malformed { - reason: "no {START_TIME_FIELD}} field found".to_owned(), + reason: "no {CATALOG_START_TIME_FIELD_NAME}} field found".to_owned(), }))?; let start_time = data .downcast_array_ref::()