summaryrefslogtreecommitdiff
path: root/src/buildtool/execution_api/execution_service/capabilities_server.cpp
diff options
context:
space:
mode:
authorAlberto Sartori <alberto.sartori@huawei.com>2023-01-23 18:31:14 +0100
committerAlberto Sartori <alberto.sartori@huawei.com>2023-02-02 17:57:19 +0100
commitbd66d45945dc186a0d08db7d9845ef657d549577 (patch)
tree51fa0b9c630ed388fc8aa36f5314b30fdc6bd5ff /src/buildtool/execution_api/execution_service/capabilities_server.cpp
parent0658ef369e9dc27ca3a16075fc0f9e20931a2350 (diff)
downloadjustbuild-bd66d45945dc186a0d08db7d9845ef657d549577.tar.gz
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 <klaus.aehlig@huawei.com>
Diffstat (limited to 'src/buildtool/execution_api/execution_service/capabilities_server.cpp')
-rw-r--r--src/buildtool/execution_api/execution_service/capabilities_server.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/src/buildtool/execution_api/execution_service/capabilities_server.cpp b/src/buildtool/execution_api/execution_service/capabilities_server.cpp
new file mode 100644
index 00000000..198d1fb6
--- /dev/null
+++ b/src/buildtool/execution_api/execution_service/capabilities_server.cpp
@@ -0,0 +1,57 @@
+// 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.
+
+#include "src/buildtool/execution_api/execution_service/capabilities_server.hpp"
+
+#include "src/buildtool/compatibility/compatibility.hpp"
+#include "src/buildtool/logging/logger.hpp"
+
+auto CapabilitiesServiceImpl::GetCapabilities(
+ ::grpc::ServerContext* /*context*/,
+ const ::build::bazel::remote::execution::v2::GetCapabilitiesRequest*
+ /*request*/,
+ ::build::bazel::remote::execution::v2::ServerCapabilities* response)
+ -> ::grpc::Status {
+ if (!Compatibility::IsCompatible()) {
+ auto const* str = "GetCapabilities not implemented";
+ Logger::Log(LogLevel::Error, str);
+ return ::grpc::Status{grpc::StatusCode::UNIMPLEMENTED, str};
+ }
+ ::build::bazel::remote::execution::v2::CacheCapabilities cache;
+ ::build::bazel::remote::execution::v2::ExecutionCapabilities exec;
+
+ cache.add_digest_function(
+ ::build::bazel::remote::execution::v2::DigestFunction_Value::
+ DigestFunction_Value_SHA256);
+ cache.mutable_action_cache_update_capabilities()->set_update_enabled(false);
+ static constexpr std::size_t kMaxBatchTransferSize = 1024 * 1024;
+ cache.set_max_batch_total_size_bytes(kMaxBatchTransferSize);
+ static_assert(kMaxBatchTransferSize < GRPC_DEFAULT_MAX_RECV_MESSAGE_LENGTH,
+ "Max batch transfer size too large.");
+ *(response->mutable_cache_capabilities()) = cache;
+
+ exec.set_digest_function(
+ ::build::bazel::remote::execution::v2::DigestFunction_Value::
+ DigestFunction_Value_SHA256);
+ exec.set_exec_enabled(true);
+
+ *(response->mutable_execution_capabilities()) = exec;
+ ::build::bazel::semver::SemVer v{};
+ v.set_major(2);
+ v.set_minor(0);
+
+ *(response->mutable_low_api_version()) = v;
+ *(response->mutable_high_api_version()) = v;
+ return ::grpc::Status::OK;
+}