feat(tvix/store/bin): print store path
After ingestion of the contents into the store, this will use the NonCachingNARCalculationService to create a NAR stream or the contents of the path, and use our Derivation output path calculation machinery to determine the output path (using recursive hashing strategy). In a real-world scenario, we obviously want to cache these calculations, but this should be sufficient to tinker around with it. Change-Id: I9b2e69384414f0be1bdcb5a99a4bfd46e8db9932 Reviewed-on: https://cl.tvl.fyi/c/depot/+/8317 Autosubmit: flokli <flokli@flokli.de> Reviewed-by: tazjin <tazjin@tvl.su> Tested-by: BuildkiteCI
This commit is contained in:
parent
80aaadfc19
commit
49cb2a2b1f
1 changed files with 38 additions and 0 deletions
|
@ -1,11 +1,17 @@
|
||||||
use clap::Subcommand;
|
use clap::Subcommand;
|
||||||
use data_encoding::BASE64;
|
use data_encoding::BASE64;
|
||||||
|
use nix_compat::derivation::Derivation;
|
||||||
|
use nix_compat::derivation::Output;
|
||||||
|
use nix_compat::nixhash::HashAlgo;
|
||||||
|
use nix_compat::nixhash::NixHash;
|
||||||
|
use nix_compat::nixhash::NixHashWithMode;
|
||||||
use std::path::PathBuf;
|
use std::path::PathBuf;
|
||||||
use tracing_subscriber::prelude::*;
|
use tracing_subscriber::prelude::*;
|
||||||
use tvix_store::blobservice::SledBlobService;
|
use tvix_store::blobservice::SledBlobService;
|
||||||
use tvix_store::chunkservice::SledChunkService;
|
use tvix_store::chunkservice::SledChunkService;
|
||||||
use tvix_store::directoryservice::SledDirectoryService;
|
use tvix_store::directoryservice::SledDirectoryService;
|
||||||
use tvix_store::import::import_path;
|
use tvix_store::import::import_path;
|
||||||
|
use tvix_store::nar::NARCalculationService;
|
||||||
use tvix_store::nar::NonCachingNARCalculationService;
|
use tvix_store::nar::NonCachingNARCalculationService;
|
||||||
use tvix_store::pathinfoservice::SledPathInfoService;
|
use tvix_store::pathinfoservice::SledPathInfoService;
|
||||||
use tvix_store::proto::blob_service_server::BlobServiceServer;
|
use tvix_store::proto::blob_service_server::BlobServiceServer;
|
||||||
|
@ -127,6 +133,12 @@ async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||||
router.serve(listen_address).await?;
|
router.serve(listen_address).await?;
|
||||||
}
|
}
|
||||||
Commands::Import { paths } => {
|
Commands::Import { paths } => {
|
||||||
|
let nar_calculation_service = NonCachingNARCalculationService::new(
|
||||||
|
blob_service.clone(),
|
||||||
|
chunk_service.clone(),
|
||||||
|
directory_service.clone(),
|
||||||
|
);
|
||||||
|
|
||||||
for path in paths {
|
for path in paths {
|
||||||
let root_node = import_path(
|
let root_node = import_path(
|
||||||
&mut blob_service,
|
&mut blob_service,
|
||||||
|
@ -135,6 +147,32 @@ async fn main() -> Result<(), Box<dyn std::error::Error>> {
|
||||||
&path,
|
&path,
|
||||||
)?;
|
)?;
|
||||||
|
|
||||||
|
let nar_hash = NixHashWithMode::Recursive(NixHash::new(
|
||||||
|
HashAlgo::Sha256,
|
||||||
|
nar_calculation_service
|
||||||
|
.calculate_nar(&root_node)?
|
||||||
|
.nar_sha256,
|
||||||
|
));
|
||||||
|
|
||||||
|
let mut drv = Derivation::default();
|
||||||
|
drv.outputs.insert(
|
||||||
|
"out".to_string(),
|
||||||
|
Output {
|
||||||
|
path: "".to_string(),
|
||||||
|
hash_with_mode: Some(nar_hash),
|
||||||
|
},
|
||||||
|
);
|
||||||
|
drv.calculate_output_paths(
|
||||||
|
path.file_name()
|
||||||
|
.expect("path must not be ..")
|
||||||
|
.to_str()
|
||||||
|
.expect("path must be valid unicode"),
|
||||||
|
// Note the derivation_or_fod_hash argument is *unused* for FODs, so it doesn't matter what we pass here.
|
||||||
|
&NixHash::new(HashAlgo::Sha256, vec![]),
|
||||||
|
)?;
|
||||||
|
|
||||||
|
println!("{}", drv.outputs.get("out").unwrap().path);
|
||||||
|
|
||||||
match root_node {
|
match root_node {
|
||||||
tvix_store::proto::node::Node::Directory(directory_node) => {
|
tvix_store::proto::node::Node::Directory(directory_node) => {
|
||||||
info!(
|
info!(
|
||||||
|
|
Loading…
Reference in a new issue