feat(tvix): Implement AddIndirectRoot, SyncWithGC
Implement RPC handlers and client methods for the AddWithRoot and
SyncWithGC calls. With this and sandboxing disabled, the following
derivation is now building successfully:
    derivation {
      name = "test";
      builder = "/bin/sh";
      args = [ "-c" "echo 1 > $out" ];
      system = "x86_64-linux";
    }
Co-authored-by: Vincent Ambo <mail@tazj.in>
Change-Id: I245dca0dfca882e2eae5d93364287a8b79fead71
Reviewed-on: https://cl.tvl.fyi/c/depot/+/1637
Reviewed-by: tazjin <mail@tazj.in>
Reviewed-by: kanepyork <rikingcoding@gmail.com>
Tested-by: BuildkiteCI
			
			
This commit is contained in:
		
							parent
							
								
									d8386d6f7e
								
							
						
					
					
						commit
						5feed69260
					
				
					 2 changed files with 32 additions and 2 deletions
				
			
		
							
								
								
									
										9
									
								
								third_party/nix/src/libstore/rpc-store.cc
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								third_party/nix/src/libstore/rpc-store.cc
									
										
									
									
										vendored
									
									
								
							|  | @ -15,6 +15,7 @@ | |||
| #include <grpcpp/impl/codegen/status.h> | ||||
| #include <grpcpp/impl/codegen/sync_stream.h> | ||||
| #include <grpcpp/security/credentials.h> | ||||
| #include <sys/ucontext.h> | ||||
| 
 | ||||
| #include "libproto/worker.grpc.pb.h" | ||||
| #include "libproto/worker.pb.h" | ||||
|  | @ -355,11 +356,15 @@ void RpcStore::addTempRoot(const Path& path) { | |||
| } | ||||
| 
 | ||||
| void RpcStore::addIndirectRoot(const Path& path) { | ||||
|   throw Unsupported(absl::StrCat("Not implemented ", __func__)); | ||||
|   ClientContext ctx; | ||||
|   google::protobuf::Empty response; | ||||
|   SuccessOrThrow(stub_->AddIndirectRoot(&ctx, StorePath(path), &response)); | ||||
| } | ||||
| 
 | ||||
| void RpcStore::syncWithGC() { | ||||
|   throw Unsupported(absl::StrCat("Not implemented ", __func__)); | ||||
|   ClientContext ctx; | ||||
|   google::protobuf::Empty response; | ||||
|   SuccessOrThrow(stub_->SyncWithGC(&ctx, kEmpty, &response)); | ||||
| } | ||||
| 
 | ||||
| Roots RpcStore::findRoots(bool censor) { | ||||
|  |  | |||
|  | @ -1,5 +1,6 @@ | |||
| #include "nix-daemon-proto.hh" | ||||
| 
 | ||||
| #include <filesystem> | ||||
| #include <sstream> | ||||
| 
 | ||||
| #include <absl/strings/str_cat.h> | ||||
|  | @ -227,6 +228,30 @@ class WorkerServiceImpl final : public WorkerService::Service { | |||
|     return Status::OK; | ||||
|   } | ||||
| 
 | ||||
|   Status AddIndirectRoot(grpc::ServerContext*, | ||||
|                          const nix::proto::StorePath* request, | ||||
|                          google::protobuf::Empty*) override { | ||||
|     auto path = std::filesystem::canonical(request->path()); | ||||
|     ASSERT_INPUT_STORE_PATH(path); | ||||
| 
 | ||||
|     return HandleExceptions( | ||||
|         [&]() -> Status { | ||||
|           store_->addIndirectRoot(path); | ||||
|           return Status::OK; | ||||
|         }, | ||||
|         __FUNCTION__); | ||||
|   } | ||||
| 
 | ||||
|   Status SyncWithGC(grpc::ServerContext*, const google::protobuf::Empty*, | ||||
|                     google::protobuf::Empty*) override { | ||||
|     return HandleExceptions( | ||||
|         [&]() -> Status { | ||||
|           store_->syncWithGC(); | ||||
|           return Status::OK; | ||||
|         }, | ||||
|         __FUNCTION__); | ||||
|   } | ||||
| 
 | ||||
|   Status QuerySubstitutablePathInfos( | ||||
|       grpc::ServerContext*, const StorePaths* request, | ||||
|       nix::proto::SubstitutablePathInfos* response) override { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue