From 2a5ec4acf8579b37c24c1bd8024a4c504b25eeae Mon Sep 17 00:00:00 2001 From: Pankaj Garg Date: Thu, 26 Oct 2023 12:58:20 -0700 Subject: [PATCH] Cleanup cargo registry code (#33879) --- cargo-registry/src/crate_handler.rs | 54 +++++++++++++---------------- cargo-registry/src/main.rs | 7 ++-- 2 files changed, 28 insertions(+), 33 deletions(-) diff --git a/cargo-registry/src/crate_handler.rs b/cargo-registry/src/crate_handler.rs index 043c69252c4e17..d1d013314eed95 100644 --- a/cargo-registry/src/crate_handler.rs +++ b/cargo-registry/src/crate_handler.rs @@ -102,7 +102,7 @@ pub(crate) struct Program { id: Pubkey, _tempdir: Arc, meta: PackageMetaData, - crate_bytes: CrateTarGz, + packed_crate: PackedCrate, } impl Program { @@ -117,7 +117,7 @@ impl Program { if APPEND_CRATE_TO_ELF { let program_id_str = Program::program_id_to_crate_name(self.id); let crate_tar_gz = - CrateTarGz::new_rebased(&self.crate_bytes, &self.meta, &program_id_str)?; + PackedCrate::new_rebased(&self.packed_crate, &self.meta, &program_id_str)?; let crate_len = u32::to_le_bytes(crate_tar_gz.0.len() as u32); program_data.extend_from_slice(&crate_tar_gz.0); program_data.extend_from_slice(&crate_len); @@ -175,8 +175,7 @@ impl Program { .saturating_sub(length as usize); let crate_end = data_len.saturating_sub(sizeof_length); - let crate_bytes = CrateTarGz(Bytes::copy_from_slice(&data[crate_start..crate_end])); - self.crate_bytes = crate_bytes; + self.packed_crate = PackedCrate(Bytes::copy_from_slice(&data[crate_start..crate_end])); } Ok(()) } @@ -200,15 +199,16 @@ impl From<&UnpackedCrate> for Program { id: value.program_id, _tempdir: value.tempdir.clone(), meta: value.meta.clone(), - crate_bytes: value.crate_bytes.clone(), + packed_crate: value.packed_crate.clone(), } } } +/// Contents of a .crate file #[derive(Clone, Default)] -pub(crate) struct CrateTarGz(pub(crate) Bytes); +pub(crate) struct PackedCrate(pub(crate) Bytes); -impl CrateTarGz { +impl PackedCrate { fn new(value: UnpackedCrate) -> Result { let mut archive = Builder::new(Vec::new()); archive.mode(HeaderMode::Deterministic); @@ -225,7 +225,7 @@ impl CrateTarGz { let mut zipped_data = Vec::new(); encoder.read_to_end(&mut zipped_data)?; - Ok(CrateTarGz(Bytes::from(zipped_data))) + Ok(PackedCrate(Bytes::from(zipped_data))) } fn new_rebased(&self, meta: &PackageMetaData, target_base: &str) -> Result { @@ -272,8 +272,6 @@ impl CrateTarGz { } } -pub(crate) struct CratePackage(pub(crate) Bytes); - pub(crate) struct UnpackedCrate { meta: PackageMetaData, cksum: String, @@ -281,14 +279,14 @@ pub(crate) struct UnpackedCrate { program_path: String, program_id: Pubkey, keypair: Option, - crate_bytes: CrateTarGz, + packed_crate: PackedCrate, } impl UnpackedCrate { - fn decompress(crate_bytes: CrateTarGz, meta: PackageMetaData) -> Result { - let cksum = format!("{:x}", Sha256::digest(&crate_bytes.0)); + fn decompress(packed_crate: PackedCrate, meta: PackageMetaData) -> Result { + let cksum = format!("{:x}", Sha256::digest(&packed_crate.0)); - let decoder = GzDecoder::new(crate_bytes.0.as_ref()); + let decoder = GzDecoder::new(packed_crate.0.as_ref()); let mut archive = Archive::new(decoder); let tempdir = tempdir()?; @@ -316,22 +314,19 @@ impl UnpackedCrate { program_path, program_id: keypair.pubkey(), keypair: Some(keypair), - crate_bytes, + packed_crate, }) } - pub(crate) fn unpack(value: CratePackage) -> Result { - let bytes = value.0; + pub(crate) fn new(bytes: Bytes) -> Result { let (meta, offset) = PackageMetaData::new(&bytes)?; let (_crate_file_length, length_size) = PackageMetaData::read_u32_length(&bytes.slice(offset..))?; - let crate_bytes = CrateTarGz(bytes.slice(offset.saturating_add(length_size)..)); - UnpackedCrate::decompress(crate_bytes, meta) + let packed_crate = PackedCrate(bytes.slice(offset.saturating_add(length_size)..)); + UnpackedCrate::decompress(packed_crate, meta) } -} -impl UnpackedCrate { pub(crate) fn publish( &self, client: Arc, @@ -362,22 +357,21 @@ impl UnpackedCrate { id: Pubkey, vers: &str, client: Arc, - ) -> Result<(CrateTarGz, PackageMetaData), Error> { - let crate_obj = Self::new_empty(id, vers)?; - let mut program = Program::from(&crate_obj); + ) -> Result<(PackedCrate, PackageMetaData), Error> { + let unpacked = Self::new_empty(id, vers)?; + let mut program = Program::from(&unpacked); program.dump(client)?; // Decompile the program // Generate a Cargo.toml - let mut meta = crate_obj.meta.clone(); + let mut meta = unpacked.meta.clone(); if APPEND_CRATE_TO_ELF { - let version = program.crate_bytes.version(); - meta.vers = version; - Ok((program.crate_bytes, meta)) + meta.vers = program.packed_crate.version(); + Ok((program.packed_crate, meta)) } else { - CrateTarGz::new(crate_obj).map(|file| (file, meta)) + PackedCrate::new(unpacked).map(|file| (file, meta)) } } @@ -421,7 +415,7 @@ impl UnpackedCrate { program_path, program_id: id, keypair: None, - crate_bytes: CrateTarGz::default(), + packed_crate: PackedCrate::default(), }) } diff --git a/cargo-registry/src/main.rs b/cargo-registry/src/main.rs index c98fcb23bd364c..0bfc2c7f3ff004 100644 --- a/cargo-registry/src/main.rs +++ b/cargo-registry/src/main.rs @@ -2,7 +2,7 @@ use { crate::{ client::Client, - crate_handler::{CratePackage, Error, Program, UnpackedCrate}, + crate_handler::{Error, Program, UnpackedCrate}, sparse_index::RegistryIndex, }, hyper::{ @@ -38,14 +38,15 @@ impl CargoRegistryService { match bytes { Ok(data) => { - let Ok(crate_object) = UnpackedCrate::unpack(CratePackage(data)) else { + let Ok(unpacked_crate) = UnpackedCrate::new(data) else { return response_builder::error_response( hyper::StatusCode::INTERNAL_SERVER_ERROR, "Failed to parse the crate information", ); }; let Ok(result) = - tokio::task::spawn_blocking(move || crate_object.publish(client, index)).await + tokio::task::spawn_blocking(move || unpacked_crate.publish(client, index)) + .await else { return response_builder::error_response( hyper::StatusCode::INTERNAL_SERVER_ERROR,