refactor(tvix/castore): move *Node and Directory to crate root
*Node and Directory are types of the tvix-castore model, not the tvix DirectoryService model. A DirectoryService only happens to send Directories. Move types into individual files in a nodes/ subdirectory, as it's gotten too cluttered in a single file, and (re-)export all types from the crate root. This has the effect that we now cannot poke at private fields directly from other files inside `crate::directoryservice` (as it's not all in the same file anymore), but that's a good thing, it now forces us to go through the proper accessors. For the same reasons, we currently also need to introduce the `rename` functions on each *Node directly. A followup is gonna move the names out of the individual enum kinds, so we can better represent "unnamed nodes". Change-Id: Icdb34dcfe454c41c94f2396e8e99973d27db8418 Reviewed-on: https://cl.tvl.fyi/c/depot/+/12199 Reviewed-by: yuka <yuka@yuka.dev> Autosubmit: flokli <flokli@flokli.de> Tested-by: BuildkiteCI
This commit is contained in:
parent
2f4185ff1a
commit
c7845f3c88
42 changed files with 620 additions and 622 deletions
|
|
@ -52,7 +52,7 @@ pub async fn get(
|
|||
StatusCode::NOT_FOUND
|
||||
})?;
|
||||
|
||||
let root_node: tvix_castore::directoryservice::Node = (&root_node).try_into().map_err(|e| {
|
||||
let root_node: tvix_castore::Node = (&root_node).try_into().map_err(|e| {
|
||||
warn!(err=%e, "root node validation failed");
|
||||
StatusCode::BAD_REQUEST
|
||||
})?;
|
||||
|
|
|
|||
|
|
@ -67,11 +67,10 @@ pub async fn get(
|
|||
})?;
|
||||
|
||||
// encode the (unnamed) root node in the NAR url itself.
|
||||
let root_node = tvix_castore::directoryservice::Node::try_from(
|
||||
path_info.node.as_ref().expect("root node must not be none"),
|
||||
)
|
||||
.unwrap() // PathInfo is validated
|
||||
.rename("".into());
|
||||
let root_node =
|
||||
tvix_castore::Node::try_from(path_info.node.as_ref().expect("root node must not be none"))
|
||||
.unwrap() // PathInfo is validated
|
||||
.rename("".into());
|
||||
|
||||
let mut buf = Vec::new();
|
||||
Node::encode(&(&root_node).into(), &mut buf);
|
||||
|
|
@ -126,7 +125,7 @@ pub async fn put(
|
|||
|
||||
// Lookup root node with peek, as we don't want to update the LRU list.
|
||||
// We need to be careful to not hold the RwLock across the await point.
|
||||
let maybe_root_node: Option<tvix_castore::directoryservice::Node> = root_nodes
|
||||
let maybe_root_node: Option<tvix_castore::Node> = root_nodes
|
||||
.read()
|
||||
.peek(&narinfo.nar_hash)
|
||||
.and_then(|v| v.try_into().ok());
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue