From bd66d45945dc186a0d08db7d9845ef657d549577 Mon Sep 17 00:00:00 2001 From: Alberto Sartori Date: Mon, 23 Jan 2023 18:31:14 +0100 Subject: execution-service: add new subcommand execute This subcommand starts a single node remote execution service honoring the just native remote protocol. If the flag --compatible is provided, the execution service will honor the original remote build execution protocol. New command line args supported by this subcommand: -p,--port INT: Execution service will listen to this port. If unset, the service will listen to the first available one. --info-file TEXT: Write the used port, interface, and pid to this file in JSON format. If the file exists, it will be overwritten. -i,--interface TEXT: Interface to use. If unset, the loopback device is used. --pid-file TEXT Write pid to this file in plain txt. If the file exists, it will be overwritten. --tls-server-cert TEXT: Path to the TLS server certificate. --tls-server-key TEXT: Path to the TLS server key. Co-authored by: Klaus Aehlig --- .../execution_service/capabilities_server.hpp | 38 ++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 src/buildtool/execution_api/execution_service/capabilities_server.hpp (limited to 'src/buildtool/execution_api/execution_service/capabilities_server.hpp') diff --git a/src/buildtool/execution_api/execution_service/capabilities_server.hpp b/src/buildtool/execution_api/execution_service/capabilities_server.hpp new file mode 100644 index 00000000..62bc4852 --- /dev/null +++ b/src/buildtool/execution_api/execution_service/capabilities_server.hpp @@ -0,0 +1,38 @@ +// Copyright 2023 Huawei Cloud Computing Technology Co., Ltd. +// +// Licensed under the Apache License, Version 2.0 (the "License"); +// you may not use this file except in compliance with the License. +// You may obtain a copy of the License at +// +// http://www.apache.org/licenses/LICENSE-2.0 +// +// Unless required by applicable law or agreed to in writing, software +// distributed under the License is distributed on an "AS IS" BASIS, +// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +// See the License for the specific language governing permissions and +// limitations under the License. + +#ifndef CAPABILITIES_SERVER_HPP +#define CAPABILITIES_SERVER_HPP + +#include "build/bazel/remote/execution/v2/remote_execution.grpc.pb.h" + +class CapabilitiesServiceImpl final + : public build::bazel::remote::execution::v2::Capabilities::Service { + public: + // GetCapabilities returns the server capabilities configuration of the + // remote endpoint. + // Only the capabilities of the services supported by the endpoint will + // be returned: + // * Execution + CAS + Action Cache endpoints should return both + // CacheCapabilities and ExecutionCapabilities. + // * Execution only endpoints should return ExecutionCapabilities. + // * CAS + Action Cache only endpoints should return CacheCapabilities. + auto GetCapabilities( + ::grpc::ServerContext* context, + const ::build::bazel::remote::execution::v2::GetCapabilitiesRequest* + request, + ::build::bazel::remote::execution::v2::ServerCapabilities* response) + -> ::grpc::Status override; +}; +#endif -- cgit v1.2.3