From 5a137c3dbbb18a6b90d68d6fb411560d26c17132 Mon Sep 17 00:00:00 2001 From: Ermine Jose Date: Tue, 3 Dec 2024 16:20:32 +0530 Subject: [PATCH] feat: add more debug logs to client API --- autonomi/src/client/archive.rs | 12 +++++++++--- autonomi/src/client/archive_private.rs | 8 ++++++-- autonomi/src/client/data.rs | 8 +++++++- autonomi/src/client/data_private.rs | 1 + autonomi/src/client/external_signer.rs | 4 ++++ autonomi/src/client/fs.rs | 15 +++++++++++++-- autonomi/src/client/fs_private.rs | 6 +++++- autonomi/src/client/mod.rs | 4 ++++ autonomi/src/client/payment.rs | 4 ++++ autonomi/src/client/registers.rs | 20 +++++++++++++++----- autonomi/src/client/utils.rs | 9 ++++++--- autonomi/src/client/vault.rs | 3 ++- evmlib/src/contract/data_payments/mod.rs | 2 +- 13 files changed, 77 insertions(+), 19 deletions(-) diff --git a/autonomi/src/client/archive.rs b/autonomi/src/client/archive.rs index 8eb23bb686..bb0d530417 100644 --- a/autonomi/src/client/archive.rs +++ b/autonomi/src/client/archive.rs @@ -93,13 +93,15 @@ impl Archive { .as_secs(); meta.modified = now; self.map.insert(new_path.to_path_buf(), (data_addr, meta)); + debug!("Renamed file successfully in the archive, old path: {old_path:?} new_path: {new_path:?}"); Ok(()) } /// Add a file to a local archive /// Note that this does not upload the archive to the network pub fn add_file(&mut self, path: PathBuf, data_addr: DataAddr, meta: Metadata) { - self.map.insert(path, (data_addr, meta)); + self.map.insert(path.clone(), (data_addr, meta)); + debug!("Added a new file to the archive, path: {:?}", path); } /// List all files in the archive @@ -160,7 +162,9 @@ impl Client { let bytes = archive .into_bytes() .map_err(|e| PutError::Serialization(format!("Failed to serialize archive: {e:?}")))?; - self.data_put(bytes, wallet.into()).await + let result = self.data_put(bytes, wallet.into()).await; + debug!("Uploaded archive {archive:?} to the network and the address is {result:?}"); + result } /// Get the cost to upload an archive @@ -168,6 +172,8 @@ impl Client { let bytes = archive .into_bytes() .map_err(|e| CostError::Serialization(format!("Failed to serialize archive: {e:?}")))?; - self.data_cost(bytes).await + let result = self.data_cost(bytes).await; + debug!("Calculated the cost to upload archive {archive:?} is {result:?}"); + result } } diff --git a/autonomi/src/client/archive_private.rs b/autonomi/src/client/archive_private.rs index 84927c977c..ee8705be2a 100644 --- a/autonomi/src/client/archive_private.rs +++ b/autonomi/src/client/archive_private.rs @@ -56,13 +56,15 @@ impl PrivateArchive { .as_secs(); meta.modified = now; self.map.insert(new_path.to_path_buf(), (data_addr, meta)); + debug!("Renamed file successfully in the private archive, old path: {old_path:?} new_path: {new_path:?}"); Ok(()) } /// Add a file to a local archive /// Note that this does not upload the archive to the network pub fn add_file(&mut self, path: PathBuf, data_map: PrivateDataAccess, meta: Metadata) { - self.map.insert(path, (data_map, meta)); + self.map.insert(path.clone(), (data_map, meta)); + debug!("Added a new file to the archive, path: {:?}", path); } /// List all files in the archive @@ -129,6 +131,8 @@ impl Client { let bytes = archive .into_bytes() .map_err(|e| PutError::Serialization(format!("Failed to serialize archive: {e:?}")))?; - self.private_data_put(bytes, payment_option).await + let result = self.private_data_put(bytes, payment_option).await; + debug!("Uploaded private archive {archive:?} to the network and address is {result:?}"); + result } } diff --git a/autonomi/src/client/data.rs b/autonomi/src/client/data.rs index 113e0511a5..e7f5d80a8e 100644 --- a/autonomi/src/client/data.rs +++ b/autonomi/src/client/data.rs @@ -134,6 +134,7 @@ impl Client { .fetch_from_data_map_chunk(data_map_chunk.value()) .await?; + debug!("Successfully fetched a blob of data from the network"); Ok(data) } @@ -214,7 +215,7 @@ impl Client { info!("Getting chunk: {addr:?}"); let key = NetworkAddress::from_chunk_address(ChunkAddress::new(addr)).to_record_key(); - + debug!("Fetching chunk from network at: {key:?}"); let get_cfg = GetRecordCfg { get_quorum: Quorum::One, retry_strategy: None, @@ -234,6 +235,10 @@ impl Client { let chunk: Chunk = try_deserialize_record(&record)?; Ok(chunk) } else { + error!( + "Record kind mismatch: expected Chunk, got {:?}", + header.kind + ); Err(NetworkError::RecordKindMismatch(RecordKind::Chunk).into()) } } @@ -267,6 +272,7 @@ impl Client { .map(|quote| quote.2.cost.as_atto()) .sum::(), ); + debug!("Total cost calculated: {total_cost:?}"); Ok(total_cost) } diff --git a/autonomi/src/client/data_private.rs b/autonomi/src/client/data_private.rs index 5f2dd1793c..d31a13f437 100644 --- a/autonomi/src/client/data_private.rs +++ b/autonomi/src/client/data_private.rs @@ -54,6 +54,7 @@ impl Client { ); let data = self.fetch_from_data_map_chunk(data_map.0.value()).await?; + debug!("Successfully fetched a blob of private data from the network"); Ok(data) } diff --git a/autonomi/src/client/external_signer.rs b/autonomi/src/client/external_signer.rs index 6a4e46d524..d3b7ede67d 100644 --- a/autonomi/src/client/external_signer.rs +++ b/autonomi/src/client/external_signer.rs @@ -30,6 +30,10 @@ impl Client { let (quote_payments, free_chunks) = extract_quote_payments(&cost_map); let quotes = cost_map_to_quotes(cost_map); + debug!( + "Got the quotes , quote_payments and freechunks from the network {:?}", + (quotes.clone(), quote_payments.clone(), free_chunks.clone()) + ); Ok((quotes, quote_payments, free_chunks)) } } diff --git a/autonomi/src/client/fs.rs b/autonomi/src/client/fs.rs index 15e32d1bf5..44bb7017dd 100644 --- a/autonomi/src/client/fs.rs +++ b/autonomi/src/client/fs.rs @@ -89,8 +89,10 @@ impl Client { let data = self.data_get(data_addr).await?; if let Some(parent) = to_dest.parent() { tokio::fs::create_dir_all(parent).await?; + debug!("Created parent directories {parent:?} for {to_dest:?}"); } - tokio::fs::write(to_dest, data).await?; + tokio::fs::write(to_dest.clone(), data).await?; + debug!("Downloaded file to {to_dest:?} from the network address {data_addr:?}"); Ok(()) } @@ -101,9 +103,15 @@ impl Client { to_dest: PathBuf, ) -> Result<(), DownloadError> { let archive = self.archive_get(archive_addr).await?; + debug!("Downloaded archive for the directory from the network at {archive_addr:?}"); for (path, addr, _meta) in archive.iter() { self.file_download(*addr, to_dest.join(path)).await?; } + debug!( + "All files in the directory downloaded to {:?} from the network address {:?}", + to_dest.parent(), + archive_addr + ); Ok(()) } @@ -159,6 +167,7 @@ impl Client { info!("Complete archive upload completed in {:?}", start.elapsed()); #[cfg(feature = "loud")] println!("Upload completed in {:?}", start.elapsed()); + debug!("Directory uploaded to the network at {arch_addr:?}"); Ok(arch_addr) } @@ -173,9 +182,10 @@ impl Client { #[cfg(feature = "loud")] println!("Uploading file: {path:?}"); - let data = tokio::fs::read(path).await?; + let data = tokio::fs::read(path.clone()).await?; let data = Bytes::from(data); let addr = self.data_put(data, wallet.into()).await?; + debug!("File {path:?} uploaded to the network at {addr:?}"); Ok(addr) } @@ -217,6 +227,7 @@ impl Client { let archive_cost = self.data_cost(Bytes::from(root_serialized)).await?; total_cost += archive_cost.as_atto(); + debug!("Total cost for the directory: {total_cost:?}"); Ok(total_cost.into()) } } diff --git a/autonomi/src/client/fs_private.rs b/autonomi/src/client/fs_private.rs index 9a49cbd2c1..654fd4cef3 100644 --- a/autonomi/src/client/fs_private.rs +++ b/autonomi/src/client/fs_private.rs @@ -36,8 +36,10 @@ impl Client { let data = self.private_data_get(data_access).await?; if let Some(parent) = to_dest.parent() { tokio::fs::create_dir_all(parent).await?; + debug!("Created parent directories for {to_dest:?}"); } - tokio::fs::write(to_dest, data).await?; + tokio::fs::write(to_dest.clone(), data).await?; + debug!("Downloaded file to {to_dest:?}"); Ok(()) } @@ -52,6 +54,7 @@ impl Client { self.private_file_download(addr.clone(), to_dest.join(path)) .await?; } + debug!("Downloaded directory to {to_dest:?}"); Ok(()) } @@ -129,6 +132,7 @@ impl Client { let data = tokio::fs::read(path).await?; let data = Bytes::from(data); let addr = self.private_data_put(data, wallet.into()).await?; + debug!("Uploaded file successfully in the privateAchive: {addr:?}"); Ok(addr) } } diff --git a/autonomi/src/client/mod.rs b/autonomi/src/client/mod.rs index f039d097a0..dc408e51c1 100644 --- a/autonomi/src/client/mod.rs +++ b/autonomi/src/client/mod.rs @@ -115,6 +115,7 @@ impl Client { ant_networking::target_arch::spawn(handle_event_receiver(event_receiver, sender)); receiver.await.expect("sender should not close")?; + debug!("Client is connected to the network"); Ok(Self { network, @@ -127,6 +128,8 @@ impl Client { let (client_event_sender, client_event_receiver) = tokio::sync::mpsc::channel(CLIENT_EVENT_CHANNEL_SIZE); self.client_event_sender = Arc::new(Some(client_event_sender)); + debug!("All events to the clients are enabled"); + client_event_receiver } } @@ -140,6 +143,7 @@ fn build_client_and_run_swarm(local: bool) -> (Network, mpsc::Receiver { let (receipt, _) = self.pay(content_addrs, &wallet).await?; + debug!( + "Paid for content addresses with wallet and the receipt is {:?}", + receipt + ); Ok(receipt) } PaymentOption::Receipt(receipt) => Ok(receipt), diff --git a/autonomi/src/client/registers.rs b/autonomi/src/client/registers.rs index c405fd6cf7..8a032399a5 100644 --- a/autonomi/src/client/registers.rs +++ b/autonomi/src/client/registers.rs @@ -96,7 +96,11 @@ impl Register { if let Some(value) = initial_value { register.write_atop(&value, &owner)?; } - + debug!( + "Created register {:?} with address: {:?}", + register, + register.address() + ); Ok(register) } @@ -166,10 +170,12 @@ impl Client { } } - Ok(Register { + let register = Register { signed_reg, crdt_reg, - }) + }; + debug!("Fetched register {register:?} from the address: {address} in the network"); + Ok(register) } /// Updates a Register on the network with a new value. This will overwrite existing value(s). @@ -217,7 +223,11 @@ impl Client { register.address() ) })?; - + debug!( + "Updated register {:?} with new value {:?}", + register.address(), + new_value + ); Ok(()) } @@ -244,7 +254,7 @@ impl Client { .map(|quote| quote.2.cost.as_atto()) .sum::(), ); - + debug!("Calculated the cost to create register with name: {name} is {total_cost}"); Ok(total_cost) } diff --git a/autonomi/src/client/utils.rs b/autonomi/src/client/utils.rs index 4962b400eb..9207b035c2 100644 --- a/autonomi/src/client/utils.rs +++ b/autonomi/src/client/utils.rs @@ -34,6 +34,7 @@ use crate::self_encryption::DataMapLevel; impl Client { /// Fetch and decrypt all chunks in the data map. pub(crate) async fn fetch_from_data_map(&self, data_map: &DataMap) -> Result { + debug!("Fetching encrypted data chunks from data map {data_map:?}"); let mut download_tasks = vec![]; for info in data_map.infos() { download_tasks.push(async move { @@ -53,7 +54,7 @@ impl Client { } }); } - + debug!("Successfully fetched all the encrypted chunks"); let encrypted_chunks = process_tasks_with_max_concurrency(download_tasks, *CHUNK_DOWNLOAD_BATCH_SIZE) .await @@ -64,7 +65,7 @@ impl Client { error!("Error decrypting encrypted_chunks: {e:?}"); GetError::Decryption(crate::self_encryption::Error::SelfEncryption(e)) })?; - + debug!("Successfully decrypted all the chunks"); Ok(data) } @@ -153,7 +154,9 @@ impl Client { use_put_record_to: Some(vec![storing_node]), verification, }; - Ok(self.network.put_record(record, &put_cfg).await?) + let payment_upload = Ok(self.network.put_record(record, &put_cfg).await?); + debug!("Successfully stored chunk: {chunk:?} to {storing_node:?}"); + payment_upload } /// Pay for the chunks and get the proof of payment. diff --git a/autonomi/src/client/vault.rs b/autonomi/src/client/vault.rs index baa86ed120..83553e3e16 100644 --- a/autonomi/src/client/vault.rs +++ b/autonomi/src/client/vault.rs @@ -63,10 +63,11 @@ impl Client { &self, secret_key: &VaultSecretKey, ) -> Result<(Bytes, VaultContentType), VaultError> { - info!("Fetching and decrypting vault"); + info!("Fetching and decrypting vault..."); let pad = self.get_vault_from_network(secret_key).await?; let data = pad.decrypt_data(secret_key)?; + debug!("vault data is successfully fetched and decrypted"); Ok((data, pad.data_encoding())) } diff --git a/evmlib/src/contract/data_payments/mod.rs b/evmlib/src/contract/data_payments/mod.rs index 79f90f9b04..ce633fb269 100644 --- a/evmlib/src/contract/data_payments/mod.rs +++ b/evmlib/src/contract/data_payments/mod.rs @@ -81,7 +81,7 @@ where .await? .watch() .await?; - + debug!("Data payments transaction hash: {:?}", tx_hash); Ok(tx_hash) }