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…
Reference in a new issue