diff --git a/CHANGELOG.md b/CHANGELOG.md index 32f4537df8211..96e504894a591 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,6 +15,7 @@ We are happy to announce the following GA libraries. Unless specifically noted, the APIs in these libraries are stable, and are ready for production use. - [Gemini Enterprise for Customer Experience API](google/cloud/ces/README.md) +- [Cluster Director API](google/cloud/hypercomputecluster/README.md) - [Vector Search API](google/cloud/vectorsearch/README.md) - [Vision AI API](/google/cloud/visionai/README.md) - [Workload Manager](/google/cloud/workloadmanager/README.md) diff --git a/README.md b/README.md index b2607cf6eb1d8..1a100f46ea188 100644 --- a/README.md +++ b/README.md @@ -317,6 +317,9 @@ See each library's `README.md` file for more information about: - [GKE Recommender API](google/cloud/gkerecommender/README.md) [[quickstart]](google/cloud/gkerecommender/quickstart/README.md) [[reference]](https://cloud.google.com/cpp/docs/reference/gkerecommender/latest) +- [Cluster Director API](google/cloud/hypercomputecluster/README.md) + [[quickstart]](google/cloud/hypercomputecluster/quickstart/README.md) + [[reference]](https://cloud.google.com/cpp/docs/reference/hypercomputecluster/latest) - [Google Cloud IAM](google/cloud/iam/README.md) [[quickstart]](google/cloud/iam/quickstart/README.md) [[reference]](https://cloud.google.com/cpp/docs/reference/iam/latest) diff --git a/ci/abi-dumps/google_cloud_cpp_hypercomputecluster.expected.abi.dump.gz b/ci/abi-dumps/google_cloud_cpp_hypercomputecluster.expected.abi.dump.gz new file mode 100644 index 0000000000000..b2ba2a9091bf2 Binary files /dev/null and b/ci/abi-dumps/google_cloud_cpp_hypercomputecluster.expected.abi.dump.gz differ diff --git a/ci/cloudbuild/builds/check-api.sh b/ci/cloudbuild/builds/check-api.sh index 937944db782ec..984e2da49d4db 100755 --- a/ci/cloudbuild/builds/check-api.sh +++ b/ci/cloudbuild/builds/check-api.sh @@ -74,6 +74,8 @@ function check_abi() { elif [[ "${shortlib}" == "storage_grpc" ]]; then # `storage_grpc` uses the same header location as `storage` public_headers="${prefix}/include/google/cloud/storage" + elif [[ "${shortlib}" =~ "hypercomputecluster" ]]; then + : elif [[ "${shortlib}" =~ "compute" ]]; then # Compute libs are also special as their headers are in subdirectories. local computelib="${library#google_cloud_cpp_compute_}" diff --git a/ci/etc/expected_install_directories b/ci/etc/expected_install_directories index fa28cfa35540d..d3818966f52a2 100644 --- a/ci/etc/expected_install_directories +++ b/ci/etc/expected_install_directories @@ -801,6 +801,10 @@ ./include/google/cloud/gkerecommender/v1 ./include/google/cloud/gkerecommender/v1/internal ./include/google/cloud/gkerecommender/v1/mocks +./include/google/cloud/hypercomputecluster +./include/google/cloud/hypercomputecluster/v1 +./include/google/cloud/hypercomputecluster/v1/internal +./include/google/cloud/hypercomputecluster/v1/mocks ./include/google/cloud/iam ./include/google/cloud/iam/admin ./include/google/cloud/iam/admin/v1 @@ -1431,6 +1435,8 @@ ./lib64/cmake/google_cloud_cpp_gkemulticloud_mocks ./lib64/cmake/google_cloud_cpp_gkerecommender ./lib64/cmake/google_cloud_cpp_gkerecommender_mocks +./lib64/cmake/google_cloud_cpp_hypercomputecluster +./lib64/cmake/google_cloud_cpp_hypercomputecluster_mocks ./lib64/cmake/google_cloud_cpp_iam ./lib64/cmake/google_cloud_cpp_iam_mocks ./lib64/cmake/google_cloud_cpp_iap diff --git a/cmake/GoogleCloudCppFeatures.cmake b/cmake/GoogleCloudCppFeatures.cmake index d014acc8a52c4..b8beb5e44b9f5 100644 --- a/cmake/GoogleCloudCppFeatures.cmake +++ b/cmake/GoogleCloudCppFeatures.cmake @@ -114,6 +114,7 @@ set(GOOGLE_CLOUD_CPP_GA_LIBRARIES "gkehub" "gkemulticloud" "gkerecommender" + "hypercomputecluster" "iam" "iap" "ids" diff --git a/external/googleapis/protodeps/hypercomputecluster.deps b/external/googleapis/protodeps/hypercomputecluster.deps new file mode 100644 index 0000000000000..ce4eebcf1a3ab --- /dev/null +++ b/external/googleapis/protodeps/hypercomputecluster.deps @@ -0,0 +1,9 @@ +@googleapis//google/api:annotations_proto +@googleapis//google/api:client_proto +@googleapis//google/api:field_behavior_proto +@googleapis//google/api:field_info_proto +@googleapis//google/api:http_proto +@googleapis//google/api:launch_stage_proto +@googleapis//google/api:resource_proto +@googleapis//google/longrunning:operations_proto +@googleapis//google/rpc:status_proto diff --git a/external/googleapis/protolists/hypercomputecluster.list b/external/googleapis/protolists/hypercomputecluster.list new file mode 100644 index 0000000000000..3f84bbb372d12 --- /dev/null +++ b/external/googleapis/protolists/hypercomputecluster.list @@ -0,0 +1,2 @@ +@googleapis//google/cloud/hypercomputecluster/v1:hypercompute_cluster.proto +@googleapis//google/cloud/hypercomputecluster/v1:operation_metadata.proto diff --git a/external/googleapis/update_libraries.sh b/external/googleapis/update_libraries.sh index 65672303c0f3b..e7ff82d878410 100755 --- a/external/googleapis/update_libraries.sh +++ b/external/googleapis/update_libraries.sh @@ -178,6 +178,7 @@ declare -A -r LIBRARIES=( )" ["gkemulticloud"]="@googleapis//google/cloud/gkemulticloud/v1:gkemulticloud_cc_grpc" ["grafeas"]="@googleapis//grafeas/v1:grafeas_cc_grpc" + ["hypercomputecluster"]="@googleapis//google/cloud/hypercomputecluster/v1:hypercomputecluster_cc_grpc" ["iam"]="@googleapis//google/iam/admin/v1:admin_cc_grpc" ["iam_v2"]="@googleapis//google/iam/v2:iam_cc_grpc" ["iam_v3"]="@googleapis//google/iam/v3:iam_cc_grpc" diff --git a/generator/generator_config.textproto b/generator/generator_config.textproto index 82a54193a27f3..5ab6619374345 100644 --- a/generator/generator_config.textproto +++ b/generator/generator_config.textproto @@ -2664,6 +2664,14 @@ service { retryable_status_codes: ["kUnavailable"] } +# Hypercompute Cluster +service { + service_proto_path: "google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto" + product_path: "google/cloud/hypercomputecluster/v1" + initial_copyright_year: "2026" + retryable_status_codes: ["kUnavailable"] +} + # IAM service { service_proto_path: "google/iam/credentials/v1/iamcredentials.proto" diff --git a/google/cloud/hypercomputecluster/BUILD.bazel b/google/cloud/hypercomputecluster/BUILD.bazel new file mode 100644 index 0000000000000..da0ca0e4a24f1 --- /dev/null +++ b/google/cloud/hypercomputecluster/BUILD.bazel @@ -0,0 +1,31 @@ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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. + +load("//bazel:gapic.bzl", "cc_gapic_library") + +package(default_visibility = ["//visibility:private"]) + +licenses(["notice"]) # Apache 2.0 + +service_dirs = ["v1/"] + +googleapis_deps = [ + "@googleapis//google/cloud/hypercomputecluster/v1:hypercomputecluster_cc_grpc", +] + +cc_gapic_library( + name = "hypercomputecluster", + googleapis_deps = googleapis_deps, + service_dirs = service_dirs, +) diff --git a/google/cloud/hypercomputecluster/CMakeLists.txt b/google/cloud/hypercomputecluster/CMakeLists.txt new file mode 100644 index 0000000000000..2998318431044 --- /dev/null +++ b/google/cloud/hypercomputecluster/CMakeLists.txt @@ -0,0 +1,37 @@ +# ~~~ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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(GoogleCloudCppLibrary) + +google_cloud_cpp_add_gapic_library(hypercomputecluster "Cluster Director API" + SERVICE_DIRS "v1/") + +if (BUILD_TESTING AND GOOGLE_CLOUD_CPP_ENABLE_CXX_EXCEPTIONS) + add_executable(hypercomputecluster_quickstart "quickstart/quickstart.cc") + target_link_libraries(hypercomputecluster_quickstart + PRIVATE google-cloud-cpp::hypercomputecluster) + google_cloud_cpp_add_common_options(hypercomputecluster_quickstart) + add_test( + NAME hypercomputecluster_quickstart + COMMAND + cmake -P "${PROJECT_SOURCE_DIR}/cmake/quickstart-runner.cmake" + $ GOOGLE_CLOUD_PROJECT + GOOGLE_CLOUD_CPP_TEST_REGION) + set_tests_properties( + hypercomputecluster_quickstart + PROPERTIES LABELS "integration-test;quickstart" PASS_REGULAR_EXPRESSION + "Permanent error.*gcloud-cpp.retry.function=ListClusters") +endif () diff --git a/google/cloud/hypercomputecluster/README.md b/google/cloud/hypercomputecluster/README.md new file mode 100644 index 0000000000000..30e93082fdec8 --- /dev/null +++ b/google/cloud/hypercomputecluster/README.md @@ -0,0 +1,62 @@ +# Cluster Director API C++ Client Library + +This directory contains an idiomatic C++ client library for the +[Cluster Director API][cloud-service-docs]. + +The Cluster Director API allows you to deploy, manage, and monitor clusters that +run AI, ML, or HPC workloads. + +While this library is **GA**, please note that the Google Cloud C++ client +libraries do **not** follow [Semantic Versioning](https://semver.org/). + +## Quickstart + +The [quickstart/](quickstart/README.md) directory contains a minimal environment +to get started using this client library in a larger project. The following +"Hello World" program is used in this quickstart, and should give you a taste of +this library. + + + +```cc +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h" +#include "google/cloud/location.h" +#include + +int main(int argc, char* argv[]) try { + if (argc != 3) { + std::cerr << "Usage: " << argv[0] << " project-id location-id\n"; + return 1; + } + + auto const location = google::cloud::Location(argv[1], argv[2]); + + namespace hypercomputecluster = ::google::cloud::hypercomputecluster_v1; + auto client = hypercomputecluster::HypercomputeClusterClient( + hypercomputecluster::MakeHypercomputeClusterConnection()); + + for (auto r : client.ListClusters(location.FullName())) { + if (!r) throw std::move(r).status(); + std::cout << r->DebugString() << "\n"; + } + + return 0; +} catch (google::cloud::Status const& status) { + std::cerr << "google::cloud::Status thrown: " << status << "\n"; + return 1; +} +``` + + + +## More Information + +- Official documentation about the [Cluster Director API][cloud-service-docs] + service +- [Reference doxygen documentation][doxygen-link] for each release of this + client library +- Detailed header comments in our [public `.h`][source-link] files + +[cloud-service-docs]: https://cloud.google.com/cluster-director/docs +[doxygen-link]: https://cloud.google.com/cpp/docs/reference/hypercomputecluster/latest/ +[source-link]: https://github.com/googleapis/google-cloud-cpp/tree/main/google/cloud/hypercomputecluster diff --git a/google/cloud/hypercomputecluster/doc/environment-variables.dox b/google/cloud/hypercomputecluster/doc/environment-variables.dox new file mode 100644 index 0000000000000..ee9ac6cd98695 --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/environment-variables.dox @@ -0,0 +1,49 @@ +/*! +@page hypercomputecluster-env Environment Variables + +A number of environment variables can be used to configure the behavior of +the library. There are also functions to configure this behavior in code. The +environment variables are convenient when troubleshooting problems. + +@section hypercomputecluster-env-endpoint Endpoint Overrides + + + +- `GOOGLE_CLOUD_CPP_HYPERCOMPUTE_CLUSTER_ENDPOINT=...` overrides the + `EndpointOption` (which defaults to "hypercomputecluster.googleapis.com") + used by `MakeHypercomputeClusterConnection()`. + + + +@see google::cloud::EndpointOption + +@section hypercomputecluster-env-logging Logging + +`GOOGLE_CLOUD_CPP_ENABLE_TRACING=rpc`: turns on tracing for most gRPC +calls. The library injects an additional Stub decorator that prints each gRPC +request and response. Unless you have configured your own logging backend, +you should also set `GOOGLE_CLOUD_CPP_ENABLE_CLOG` to produce any output on +the program's console. + +@see google::cloud::LoggingComponentsOption + +`GOOGLE_CLOUD_CPP_TRACING_OPTIONS=...`: modifies the behavior of gRPC tracing, +including whether messages will be output on multiple lines, or whether +string/bytes fields will be truncated. + +@see google::cloud::GrpcTracingOptionsOption + +`GOOGLE_CLOUD_CPP_ENABLE_CLOG=yes`: turns on logging in the library, basically +the library always "logs" but the logging infrastructure has no backend to +actually print anything until the application sets a backend or they set this +environment variable. + +@see google::cloud::LogBackend +@see google::cloud::LogSink + +@section hypercomputecluster-env-project Setting the Default Project + +`GOOGLE_CLOUD_PROJECT=...`: is used in examples and integration tests to +configure the GCP project. This has no effect in the library. + +*/ diff --git a/google/cloud/hypercomputecluster/doc/main.dox b/google/cloud/hypercomputecluster/doc/main.dox new file mode 100644 index 0000000000000..c9555d27a1ac0 --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/main.dox @@ -0,0 +1,49 @@ +/*! + +@mainpage Cluster Director API C++ Client Library + +An idiomatic C++ client library for the [Cluster Director API][cloud-service-docs]. + +The Cluster Director API allows you to deploy, manage, and monitor clusters +that run AI, ML, or HPC workloads. + +While this library is **GA**, please note that the Google Cloud C++ client libraries do **not** follow +[Semantic Versioning](https://semver.org/). + +@tableofcontents{HTML:2} + +## Quickstart + +The following shows the code that you'll run in the +`google/cloud/hypercomputecluster/quickstart/` directory, +which should give you a taste of the Cluster Director API C++ client library API. + +@snippet quickstart.cc all + +## Main classes + + +The main class in this library is +[`hypercomputecluster_v1::HypercomputeClusterClient`](@ref google::cloud::hypercomputecluster_v1::HypercomputeClusterClient). All RPCs are exposed +as member functions of this class. Other classes provide helpers, configuration +parameters, and infrastructure to mock +[`hypercomputecluster_v1::HypercomputeClusterClient`](@ref google::cloud::hypercomputecluster_v1::HypercomputeClusterClient) when testing your +application. + + +## More Information + +- @ref common-error-handling - describes how the library reports errors. +- @ref hypercomputecluster-override-endpoint - describes how to override the default + endpoint. +- @ref hypercomputecluster-override-authentication - describes how to change the + authentication credentials used by the library. +- @ref hypercomputecluster-override-retry - describes how to change the default retry + policies. +- @ref hypercomputecluster-env - describes environment variables that can configure the + behavior of the library. +- @ref hypercomputecluster-override-universe-domain - describes how to override the default universe domain. + +[cloud-service-docs]: https://cloud.google.com/cluster-director/docs + +*/ diff --git a/google/cloud/hypercomputecluster/doc/options.dox b/google/cloud/hypercomputecluster/doc/options.dox new file mode 100644 index 0000000000000..8cf39686b26d5 --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/options.dox @@ -0,0 +1,10 @@ +/*! +@defgroup google-cloud-hypercomputecluster-options Cluster Director API Configuration Options + +This library uses the same mechanism (`google::cloud::Options`) and the common +[options](@ref options) as all other C++ client libraries for its configuration. +Some `*Option` classes, which are only used in this library, are documented in +this page. + +@see @ref options - for an overview of client library configuration. +*/ diff --git a/google/cloud/hypercomputecluster/doc/override-authentication.dox b/google/cloud/hypercomputecluster/doc/override-authentication.dox new file mode 100644 index 0000000000000..9c3929d69c11b --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/override-authentication.dox @@ -0,0 +1,35 @@ +/*! +@page hypercomputecluster-override-authentication How to Override the Authentication Credentials + +Unless otherwise configured, the client libraries use +[Application Default Credentials] to authenticate with Google Cloud Services. +While this works for most applications, in some cases you may need to override +this default. You can do so by providing the +[UnifiedCredentialsOption](@ref google::cloud::UnifiedCredentialsOption) +The following example shows how to explicitly load a service account key file: + + +@snippet hypercompute_cluster_client_samples.cc with-service-account + + + +Keep in mind that we chose this as an example because it is relatively easy to +understand. Consult the [Best practices for managing service account keys] +guide for more details. + +@see @ref guac - for more information on the factory functions to create +`google::cloud::Credentials` objects. + +[Best practices for managing service account keys]: https://cloud.google.com/iam/docs/best-practices-for-managing-service-account-keys +[Application Default Credentials]: https://cloud.google.com/docs/authentication#adc + +*/ + +// + +/*! @page hypercomputecluster_v1::HypercomputeClusterClient-service-account-snippet Override hypercomputecluster_v1::HypercomputeClusterClient Authentication Defaults + +@snippet google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc with-service-account + +*/ +// diff --git a/google/cloud/hypercomputecluster/doc/override-endpoint.dox b/google/cloud/hypercomputecluster/doc/override-endpoint.dox new file mode 100644 index 0000000000000..dd2d6131f72ec --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/override-endpoint.dox @@ -0,0 +1,25 @@ +/*! +@page hypercomputecluster-override-endpoint How to Override the Default Endpoint + +In some cases, you may need to override the default endpoint used by the client +library. Use the +[EndpointOption](@ref google::cloud::EndpointOption) when initializing the +client library to change this default. + + +For example, this will override the default endpoint for `hypercomputecluster_v1::HypercomputeClusterClient`: + +@snippet hypercompute_cluster_client_samples.cc set-client-endpoint + + + +*/ + +// + +/*! @page hypercomputecluster_v1::HypercomputeClusterClient-endpoint-snippet Override hypercomputecluster_v1::HypercomputeClusterClient Endpoint Configuration + +@snippet google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc set-client-endpoint + +*/ +// diff --git a/google/cloud/hypercomputecluster/doc/override-retry-policies.dox b/google/cloud/hypercomputecluster/doc/override-retry-policies.dox new file mode 100644 index 0000000000000..14e9b652b0c30 --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/override-retry-policies.dox @@ -0,0 +1,108 @@ +/*! +@page hypercomputecluster-override-retry Override Retry, Backoff, and Idempotency Policies + +When it is safe to do so, the library automatically retries requests that fail +due to a transient error. The library then uses [exponential backoff] to backoff +before trying again. Which operations are considered safe to retry, which +errors are treated as transient failures, the details of the exponential backoff +algorithm, and for how long the library retries are all configurable via +policies. + +This document provides examples showing how to override the default policies. + +The policies can be set when the `*Connection` object is created. The library +provides default policies for any policy that is not set. The application can +also override some (or all) policies when the `*Client` object is created. This +can be useful if multiple `*Client` objects share the same `*Connection` object, +but you want different retry behavior in some of the clients. Finally, the +application can override some retry policies when calling a specific member +function. + +The library uses three different options to control the retry loop. The options +have per-client names. + +@section hypercomputecluster-override-retry-retry-policy Configuring the transient errors and retry duration + +The `*RetryPolicyOption` controls: + +- Which errors are to be treated as transient errors. +- How long the library will keep retrying transient errors. + +You can provide your own class for this option. The library also provides two +built-in policies: + +- `*LimitedErrorCountRetryPolicy`: stops retrying after a specified number + of transient errors. +- `*LimitedTimeRetryPolicy`: stops retrying after a specified time. + +Note that a library may have more than one version of these classes. Their name +match the `*Client` and `*Connection` object they are intended to be used +with. Some `*Client` objects treat different error codes as transient errors. +In most cases, only [kUnavailable](@ref google::cloud::StatusCode) is treated +as a transient error. + +@section hypercomputecluster-override-retry-backoff-policy Controlling the backoff algorithm + +The `*BackoffPolicyOption` controls how long the client library will wait +before retrying a request that failed with a transient error. You can provide +your own class for this option. + +The only built-in backoff policy is +[`ExponentialBackoffPolicy`](@ref google::cloud::ExponentialBackoffPolicy). +This class implements a truncated exponential backoff algorithm, with jitter. +In summary, it doubles the current backoff time after each failure. The actual +backoff time for an RPC is chosen at random, but never exceeds the current +backoff. The current backoff is doubled after each failure, but never exceeds +(or is "truncated") if it reaches a prescribed maximum. + +@section hypercomputecluster-override-retry-idempotency-policy Controlling which operations are retryable + +The `*IdempotencyPolicyOption` controls which requests are retryable, as some +requests are never safe to retry. + +Only one built-in idempotency policy is provided by the library. The name +matches the name of the client it is intended for. For example, `FooBarClient` +will use `FooBarIdempotencyPolicy`. This policy is very conservative. + +@section hypercomputecluster-override-retry-example Example + + +For example, this will override the retry policies for `hypercomputecluster_v1::HypercomputeClusterClient`: + +@snippet hypercompute_cluster_client_samples.cc set-retry-policy + +This assumes you have created a custom idempotency policy. Such as: + +@snippet hypercompute_cluster_client_samples.cc custom-idempotency-policy + +This will override the polling policies for `hypercomputecluster_v1::HypercomputeClusterClient` + +@snippet hypercompute_cluster_client_samples.cc set-polling-policy + + + + +@section hypercomputecluster-override-retry-more-information More Information + +@see google::cloud::Options +@see google::cloud::BackoffPolicy +@see google::cloud::ExponentialBackoffPolicy + +[exponential backoff]: https://en.wikipedia.org/wiki/Exponential_backoff + +*/ + +// + +/*! @page hypercomputecluster_v1::HypercomputeClusterClient-retry-snippet Override hypercomputecluster_v1::HypercomputeClusterClient Retry Policies + +This shows how to override the retry policies for hypercomputecluster_v1::HypercomputeClusterClient: + +@snippet google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc set-retry-policy + +Assuming you have created a custom idempotency policy. Such as: + +@snippet google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc custom-idempotency-policy + +*/ +// diff --git a/google/cloud/hypercomputecluster/doc/override-universe-domain.dox b/google/cloud/hypercomputecluster/doc/override-universe-domain.dox new file mode 100644 index 0000000000000..5eb65167a1d14 --- /dev/null +++ b/google/cloud/hypercomputecluster/doc/override-universe-domain.dox @@ -0,0 +1,24 @@ +/*! +@page hypercomputecluster-override-universe-domain How to Override the Default Universe Domain + +In some cases, you may need to override the default universe domain used by the +client library. Use `AddUniverseDomainOption` when initializing the client +library to change this default. + + +For example, this will override the default universe domain for `hypercomputecluster_v1::HypercomputeClusterClient`: + +@snippet hypercompute_cluster_client_samples.cc set-client-universe-domain + + + +*/ + +// + +/*! @page hypercomputecluster_v1::HypercomputeClusterClient-universe-domain-snippet Override hypercomputecluster_v1::HypercomputeClusterClient Universe Domain + +@snippet google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc set-client-universe-domain + +*/ +// diff --git a/google/cloud/hypercomputecluster/quickstart/.bazelrc b/google/cloud/hypercomputecluster/quickstart/.bazelrc new file mode 100644 index 0000000000000..c884db46c2b4d --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/.bazelrc @@ -0,0 +1,30 @@ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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. + +# Use host-OS-specific config lines from bazelrc files. +build --enable_platform_specific_config=true + +# The project requires C++ >= 14. By default Bazel adds `-std=c++0x` which +# disables C++14 features, even if the compilers defaults to C++ >= 14 +build:linux --cxxopt=-std=c++14 +build:macos --cxxopt=-std=c++14 +# Protobuf and gRPC require (or soon will require) C++14 to compile the "host" +# targets, such as protoc and the grpc plugin. +build:linux --host_cxxopt=-std=c++14 +build:macos --host_cxxopt=-std=c++14 + +# Do not create the convenience links. They are inconvenient when the build +# runs inside a docker image or if one builds a quickstart and then builds +# the project separately. +build --experimental_convenience_symlinks=ignore diff --git a/google/cloud/hypercomputecluster/quickstart/BUILD.bazel b/google/cloud/hypercomputecluster/quickstart/BUILD.bazel new file mode 100644 index 0000000000000..c019e0419b1ed --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/BUILD.bazel @@ -0,0 +1,25 @@ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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. + +licenses(["notice"]) # Apache 2.0 + +cc_binary( + name = "quickstart", + srcs = [ + "quickstart.cc", + ], + deps = [ + "@google_cloud_cpp//:hypercomputecluster", + ], +) diff --git a/google/cloud/hypercomputecluster/quickstart/CMakeLists.txt b/google/cloud/hypercomputecluster/quickstart/CMakeLists.txt new file mode 100644 index 0000000000000..b6e22881b2577 --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/CMakeLists.txt @@ -0,0 +1,32 @@ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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. + +# This file shows how to use the Cluster Director API C++ client library from a +# larger CMake project. + +cmake_minimum_required(VERSION 3.22...3.31) +project(google-cloud-cpp-hypercomputecluster-quickstart CXX) + +find_package(google_cloud_cpp_hypercomputecluster REQUIRED) + +# MSVC requires some additional code to select the correct runtime library +if (VCPKG_TARGET_TRIPLET MATCHES "-static$") + set(CMAKE_MSVC_RUNTIME_LIBRARY "MultiThreaded$<$:Debug>") +else () + set(CMAKE_MSVC_RUNTIME_LIBRARY "MultiThreaded$<$:Debug>DLL") +endif () + +# Define your targets. +add_executable(quickstart quickstart.cc) +target_link_libraries(quickstart google-cloud-cpp::hypercomputecluster) diff --git a/google/cloud/hypercomputecluster/quickstart/Makefile b/google/cloud/hypercomputecluster/quickstart/Makefile new file mode 100644 index 0000000000000..21b36a552c763 --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/Makefile @@ -0,0 +1,35 @@ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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. + +# This is a minimal Makefile to show how to use the Cluster Director API C++ client +# for developers who use make(1) as their build system. + +# The CXX, CXXFLAGS and CXXLD variables are hard-coded. These values work for +# our tests, but applications would typically make them configurable parameters. +CXX=g++ +CXXFLAGS= +CXXLD=$(CXX) +BIN=. + +all: $(BIN)/quickstart + +# Configuration variables to compile and link against the Cluster Director API C++ +# client library. +CLIENT_MODULE := google_cloud_cpp_hypercomputecluster +CLIENT_CXXFLAGS := $(shell pkg-config $(CLIENT_MODULE) --cflags) +CLIENT_CXXLDFLAGS := $(shell pkg-config $(CLIENT_MODULE) --libs-only-L) +CLIENT_LIBS := $(shell pkg-config $(CLIENT_MODULE) --libs-only-l) + +$(BIN)/quickstart: quickstart.cc + $(CXXLD) $(CXXFLAGS) $(CLIENT_CXXFLAGS) $(CLIENT_CXXLDFLAGS) -o $@ $^ $(CLIENT_LIBS) diff --git a/google/cloud/hypercomputecluster/quickstart/README.md b/google/cloud/hypercomputecluster/quickstart/README.md new file mode 100644 index 0000000000000..7913ded3486c4 --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/README.md @@ -0,0 +1,135 @@ +# HOWTO: using the Cluster Director API C++ client in your project + +This directory contains small examples showing how to use the Cluster Director +API C++ client library in your own project. These instructions assume that you +have some experience as a C++ developer and that you have a working C++ +toolchain (compiler, linker, etc.) installed on your platform. + +- Packaging maintainers or developers who prefer to install the library in a + fixed directory (such as `/usr/local` or `/opt`) should consult the + [packaging guide](/doc/packaging.md). +- Developers who prefer using a package manager such as + [vcpkg](https://vcpkg.io), or [Conda](https://conda.io), should follow the + instructions for their package manager. +- Developers wanting to use the libraries as part of a larger CMake or Bazel + project should consult the current document. Note that there are similar + documents for each library in their corresponding directories. +- Developers wanting to compile the library just to run some examples or tests + should consult the + [building and installing](/README.md#building-and-installing) section of the + top-level README file. +- Contributors and developers to `google-cloud-cpp` should consult the guide to + [set up a development workstation][howto-setup-dev-workstation]. + +## Before you begin + +To run the quickstart examples you will need a working Google Cloud Platform +(GCP) project. + +## Configuring authentication for the C++ Client Library + +Like most Google Cloud Platform (GCP) services, Cluster Director API requires +that your application authenticates with the service before accessing any data. +If you are not familiar with GCP authentication please take this opportunity to +review the [Authentication methods at Google][authentication-quickstart]. + +## Using with Bazel + +> :warning: If you are using Windows or macOS there are additional instructions +> at the end of this document. + +1. Install Bazel using [the instructions][bazel-install] from the `bazel.build` + website. + +1. Compile this example using Bazel: + + ```bash + cd $HOME/google-cloud-cpp/google/cloud/hypercomputecluster/quickstart + bazel build ... + ``` + + Note that Bazel automatically downloads and compiles all dependencies of the + project. As it is often the case with C++ libraries, compiling these + dependencies may take several minutes. + +1. Run the example, changing the placeholder(s) to appropriate values: + + ```bash + bazel run :quickstart -- [...] + ``` + +## Using with CMake + +> :warning: If you are using Windows or macOS there are additional instructions +> at the end of this document. + +1. Install CMake. The package managers for most Linux distributions include a + package for CMake. Likewise, you can install CMake on Windows using a package + manager such as [chocolatey][choco-cmake-link], and on macOS using + [homebrew][homebrew-cmake-link]. You can also obtain the software directly + from the [cmake.org](https://cmake.org/download/). + +1. Install the dependencies with your favorite tools. As an example, if you use + [vcpkg](https://github.com/Microsoft/vcpkg.git): + + ```bash + cd $HOME/vcpkg + ./vcpkg install google-cloud-cpp[core,hypercomputecluster] + ``` + + Note that, as it is often the case with C++ libraries, compiling these + dependencies may take several minutes. + +1. Configure CMake, if necessary, configure the directory where you installed + the dependencies: + + ```bash + cd $HOME/google-cloud-cpp/google/cloud/hypercomputecluster/quickstart + cmake -S . -B .build -DCMAKE_TOOLCHAIN_FILE=$HOME/vcpkg/scripts/buildsystems/vcpkg.cmake + cmake --build .build + ``` + +1. Run the example, changing the placeholder(s) to appropriate values: + + ```bash + .build/quickstart [...] + ``` + +## Platform Specific Notes + +### macOS + +gRPC [requires][grpc-roots-pem-bug] an environment variable to configure the +trust store for SSL certificates, you can download and configure this using: + +```bash +curl -Lo roots.pem https://pki.google.com/roots.pem +export GRPC_DEFAULT_SSL_ROOTS_FILE_PATH="$PWD/roots.pem" +``` + +### Windows + +Bazel tends to create very long file names and paths. You may need to use a +short directory to store the build output, such as `c:\b`, and instruct Bazel to +use it via: + +```shell +bazel --output_user_root=c:\b build ... +``` + +gRPC [requires][grpc-roots-pem-bug] an environment variable to configure the +trust store for SSL certificates, you can download and configure this using: + +```console +@powershell -NoProfile -ExecutionPolicy unrestricted -Command ^ + (new-object System.Net.WebClient).Downloadfile( ^ + 'https://pki.google.com/roots.pem', 'roots.pem') +set GRPC_DEFAULT_SSL_ROOTS_FILE_PATH=%cd%\roots.pem +``` + +[authentication-quickstart]: https://cloud.google.com/docs/authentication/client-libraries "Authenticate for using client libraries" +[bazel-install]: https://docs.bazel.build/versions/main/install.html +[choco-cmake-link]: https://chocolatey.org/packages/cmake +[grpc-roots-pem-bug]: https://github.com/grpc/grpc/issues/16571 +[homebrew-cmake-link]: https://formulae.brew.sh/formula/cmake +[howto-setup-dev-workstation]: /doc/contributor/howto-guide-setup-development-workstation.md diff --git a/google/cloud/hypercomputecluster/quickstart/WORKSPACE.bazel b/google/cloud/hypercomputecluster/quickstart/WORKSPACE.bazel new file mode 100644 index 0000000000000..2618d8ca88fb0 --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/WORKSPACE.bazel @@ -0,0 +1,53 @@ +# Copyright 2026 Google LLC +# +# 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 +# +# https://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. + +# A minimal WORKSPACE file showing how to use the Cluster Director API +# C++ client library in Bazel-based projects. +workspace(name = "qs") + +# Add the necessary Starlark functions to fetch google-cloud-cpp. +load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive") + +# Fetch the Google Cloud C++ libraries. +# NOTE: Update this version and SHA256 as needed. +http_archive( + name = "google_cloud_cpp", + sha256 = "699955112a4c57ae9111fbadeff1698674a1762acd77daf36360e6dfc227dc93", + strip_prefix = "google-cloud-cpp-2.42.0", + url = "https://github.com/googleapis/google-cloud-cpp/archive/v2.42.0.tar.gz", +) + +load("@google_cloud_cpp//bazel:workspace0.bzl", "gl_cpp_workspace0") + +gl_cpp_workspace0() + +load("@google_cloud_cpp//bazel:workspace1.bzl", "gl_cpp_workspace1") + +gl_cpp_workspace1() + +load("@google_cloud_cpp//bazel:workspace2.bzl", "gl_cpp_workspace2") + +gl_cpp_workspace2() + +load("@google_cloud_cpp//bazel:workspace3.bzl", "gl_cpp_workspace3") + +gl_cpp_workspace3() + +load("@google_cloud_cpp//bazel:workspace4.bzl", "gl_cpp_workspace4") + +gl_cpp_workspace4() + +load("@google_cloud_cpp//bazel:workspace5.bzl", "gl_cpp_workspace5") + +gl_cpp_workspace5() diff --git a/google/cloud/hypercomputecluster/quickstart/quickstart.cc b/google/cloud/hypercomputecluster/quickstart/quickstart.cc new file mode 100644 index 0000000000000..a3369bbbfb677 --- /dev/null +++ b/google/cloud/hypercomputecluster/quickstart/quickstart.cc @@ -0,0 +1,42 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +//! [all] +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h" +#include "google/cloud/location.h" +#include + +int main(int argc, char* argv[]) try { + if (argc != 3) { + std::cerr << "Usage: " << argv[0] << " project-id location-id\n"; + return 1; + } + + auto const location = google::cloud::Location(argv[1], argv[2]); + + namespace hypercomputecluster = ::google::cloud::hypercomputecluster_v1; + auto client = hypercomputecluster::HypercomputeClusterClient( + hypercomputecluster::MakeHypercomputeClusterConnection()); + + for (auto r : client.ListClusters(location.FullName())) { + if (!r) throw std::move(r).status(); + std::cout << r->DebugString() << "\n"; + } + + return 0; +} catch (google::cloud::Status const& status) { + std::cerr << "google::cloud::Status thrown: " << status << "\n"; + return 1; +} +//! [all] diff --git a/google/cloud/hypercomputecluster/v1/.repo-metadata.json b/google/cloud/hypercomputecluster/v1/.repo-metadata.json new file mode 100644 index 0000000000000..75d22f9dc60f0 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/.repo-metadata.json @@ -0,0 +1,14 @@ +{ + "api_id": "hypercomputecluster.googleapis.com", + "api_shortname": "hypercomputecluster", + "client_documentation": "https://cloud.google.com/cpp/docs/reference/hypercomputecluster/latest", + "distribution_name": "google-cloud-cpp", + "issue_tracker": "https://issuetracker.google.com/issues?q=componentid:1907878%20status=open", + "language": "cpp", + "library_type": "GAPIC_AUTO", + "name_pretty": "Cluster Director API", + "product_documentation": "https://cloud.google.com/cluster-director/docs", + "release_level": "stable", + "repo": "googleapis/google-cloud-cpp", + "requires_billing": true +} diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.cc b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.cc new file mode 100644 index 0000000000000..7b30445818207 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.cc @@ -0,0 +1,284 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h" +#include +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterClient::HypercomputeClusterClient( + std::shared_ptr connection, Options opts) + : connection_(std::move(connection)), + options_( + internal::MergeOptions(std::move(opts), connection_->options())) {} +HypercomputeClusterClient::~HypercomputeClusterClient() = default; + +StreamRange +HypercomputeClusterClient::ListClusters(std::string const& parent, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::ListClustersRequest request; + request.set_parent(parent); + return connection_->ListClusters(request); +} + +StreamRange +HypercomputeClusterClient::ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListClusters(std::move(request)); +} + +StatusOr +HypercomputeClusterClient::GetCluster(std::string const& name, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::GetClusterRequest request; + request.set_name(name); + return connection_->GetCluster(request); +} + +StatusOr +HypercomputeClusterClient::GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetCluster(request); +} + +future> +HypercomputeClusterClient::CreateCluster( + std::string const& parent, + google::cloud::hypercomputecluster::v1::Cluster const& cluster, + std::string const& cluster_id, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::CreateClusterRequest request; + request.set_parent(parent); + *request.mutable_cluster() = cluster; + request.set_cluster_id(cluster_id); + return connection_->CreateCluster(request); +} + +StatusOr +HypercomputeClusterClient::CreateCluster( + NoAwaitTag, std::string const& parent, + google::cloud::hypercomputecluster::v1::Cluster const& cluster, + std::string const& cluster_id, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::CreateClusterRequest request; + request.set_parent(parent); + *request.mutable_cluster() = cluster; + request.set_cluster_id(cluster_id); + return connection_->CreateCluster(NoAwaitTag{}, request); +} + +future> +HypercomputeClusterClient::CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->CreateCluster(request); +} + +StatusOr +HypercomputeClusterClient::CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->CreateCluster(NoAwaitTag{}, request); +} + +future> +HypercomputeClusterClient::CreateCluster( + google::longrunning::Operation const& operation, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->CreateCluster(operation); +} + +future> +HypercomputeClusterClient::UpdateCluster( + google::cloud::hypercomputecluster::v1::Cluster const& cluster, + google::protobuf::FieldMask const& update_mask, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::UpdateClusterRequest request; + *request.mutable_cluster() = cluster; + *request.mutable_update_mask() = update_mask; + return connection_->UpdateCluster(request); +} + +StatusOr +HypercomputeClusterClient::UpdateCluster( + NoAwaitTag, google::cloud::hypercomputecluster::v1::Cluster const& cluster, + google::protobuf::FieldMask const& update_mask, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::UpdateClusterRequest request; + *request.mutable_cluster() = cluster; + *request.mutable_update_mask() = update_mask; + return connection_->UpdateCluster(NoAwaitTag{}, request); +} + +future> +HypercomputeClusterClient::UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->UpdateCluster(request); +} + +StatusOr +HypercomputeClusterClient::UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->UpdateCluster(NoAwaitTag{}, request); +} + +future> +HypercomputeClusterClient::UpdateCluster( + google::longrunning::Operation const& operation, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->UpdateCluster(operation); +} + +future> +HypercomputeClusterClient::DeleteCluster(std::string const& name, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::DeleteClusterRequest request; + request.set_name(name); + return connection_->DeleteCluster(request); +} + +StatusOr +HypercomputeClusterClient::DeleteCluster(NoAwaitTag, std::string const& name, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::hypercomputecluster::v1::DeleteClusterRequest request; + request.set_name(name); + return connection_->DeleteCluster(NoAwaitTag{}, request); +} + +future> +HypercomputeClusterClient::DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->DeleteCluster(request); +} + +StatusOr +HypercomputeClusterClient::DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->DeleteCluster(NoAwaitTag{}, request); +} + +future> +HypercomputeClusterClient::DeleteCluster( + google::longrunning::Operation const& operation, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->DeleteCluster(operation); +} + +StreamRange +HypercomputeClusterClient::ListLocations( + google::cloud::location::ListLocationsRequest request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListLocations(std::move(request)); +} + +StatusOr +HypercomputeClusterClient::GetLocation( + google::cloud::location::GetLocationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetLocation(request); +} + +StreamRange +HypercomputeClusterClient::ListOperations(std::string const& name, + std::string const& filter, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::longrunning::ListOperationsRequest request; + request.set_name(name); + request.set_filter(filter); + return connection_->ListOperations(request); +} + +StreamRange +HypercomputeClusterClient::ListOperations( + google::longrunning::ListOperationsRequest request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListOperations(std::move(request)); +} + +StatusOr +HypercomputeClusterClient::GetOperation(std::string const& name, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::longrunning::GetOperationRequest request; + request.set_name(name); + return connection_->GetOperation(request); +} + +StatusOr +HypercomputeClusterClient::GetOperation( + google::longrunning::GetOperationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetOperation(request); +} + +Status HypercomputeClusterClient::DeleteOperation(std::string const& name, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::longrunning::DeleteOperationRequest request; + request.set_name(name); + return connection_->DeleteOperation(request); +} + +Status HypercomputeClusterClient::DeleteOperation( + google::longrunning::DeleteOperationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->DeleteOperation(request); +} + +Status HypercomputeClusterClient::CancelOperation(std::string const& name, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::longrunning::CancelOperationRequest request; + request.set_name(name); + return connection_->CancelOperation(request); +} + +Status HypercomputeClusterClient::CancelOperation( + google::longrunning::CancelOperationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->CancelOperation(request); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h new file mode 100644 index 0000000000000..89f9774d4e77a --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h @@ -0,0 +1,936 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CLIENT_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CLIENT_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include "google/cloud/future.h" +#include "google/cloud/no_await_tag.h" +#include "google/cloud/options.h" +#include "google/cloud/polling_policy.h" +#include "google/cloud/status_or.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/// +/// Service describing handlers for resources +/// +/// @par Equality +/// +/// Instances of this class created via copy-construction or copy-assignment +/// always compare equal. Instances created with equal +/// `std::shared_ptr<*Connection>` objects compare equal. Objects that compare +/// equal share the same underlying resources. +/// +/// @par Performance +/// +/// Creating a new instance of this class is a relatively expensive operation, +/// new objects establish new connections to the service. In contrast, +/// copy-construction, move-construction, and the corresponding assignment +/// operations are relatively efficient as the copies share all underlying +/// resources. +/// +/// @par Thread Safety +/// +/// Concurrent access to different instances of this class, even if they compare +/// equal, is guaranteed to work. Two or more threads operating on the same +/// instance of this class is not guaranteed to work. Since copy-construction +/// and move-construction is a relatively efficient operation, consider using +/// such a copy when using this class from multiple threads. +/// +class HypercomputeClusterClient { + public: + explicit HypercomputeClusterClient( + std::shared_ptr connection, + Options opts = {}); + ~HypercomputeClusterClient(); + + ///@{ + /// @name Copy and move support + HypercomputeClusterClient(HypercomputeClusterClient const&) = default; + HypercomputeClusterClient& operator=(HypercomputeClusterClient const&) = + default; + HypercomputeClusterClient(HypercomputeClusterClient&&) = default; + HypercomputeClusterClient& operator=(HypercomputeClusterClient&&) = default; + ///@} + + ///@{ + /// @name Equality + friend bool operator==(HypercomputeClusterClient const& a, + HypercomputeClusterClient const& b) { + return a.connection_ == b.connection_; + } + friend bool operator!=(HypercomputeClusterClient const& a, + HypercomputeClusterClient const& b) { + return !(a == b); + } + ///@} + + // clang-format off + /// + /// Lists Clusters in a given project and location. + /// + /// @param parent Required. Parent location of the clusters to list, in the format + /// `projects/{project}/locations/{location}`. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [StreamRange](@ref google::cloud::StreamRange) + /// to iterate of the results. See the documentation of this type for + /// details. In brief, this class has `begin()` and `end()` member + /// functions returning a iterator class meeting the + /// [input iterator requirements]. The value type for this iterator is a + /// [`StatusOr`] as the iteration may fail even after some values are + /// retrieved successfully, for example, if there is a network disconnect. + /// An empty set of results does not indicate an error, it indicates + /// that there are no resources meeting the request criteria. + /// On a successful iteration the `StatusOr` contains elements of type + /// [google.cloud.hypercomputecluster.v1.Cluster], or rather, + /// the C++ class generated by Protobuf from that type. Please consult the + /// Protobuf documentation for details on the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.ListClustersRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L213} + /// + // clang-format on + StreamRange ListClusters( + std::string const& parent, Options opts = {}); + + // clang-format off + /// + /// Lists Clusters in a given project and location. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.hypercomputecluster.v1.ListClustersRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [StreamRange](@ref google::cloud::StreamRange) + /// to iterate of the results. See the documentation of this type for + /// details. In brief, this class has `begin()` and `end()` member + /// functions returning a iterator class meeting the + /// [input iterator requirements]. The value type for this iterator is a + /// [`StatusOr`] as the iteration may fail even after some values are + /// retrieved successfully, for example, if there is a network disconnect. + /// An empty set of results does not indicate an error, it indicates + /// that there are no resources meeting the request criteria. + /// On a successful iteration the `StatusOr` contains elements of type + /// [google.cloud.hypercomputecluster.v1.Cluster], or rather, + /// the C++ class generated by Protobuf from that type. Please consult the + /// Protobuf documentation for details on the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.ListClustersRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L213} + /// + // clang-format on + StreamRange ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request, + Options opts = {}); + + // clang-format off + /// + /// Gets details of a single Cluster. + /// + /// @param name Required. Name of the cluster to retrieve, in the format + /// `projects/{project}/locations/{location}/clusters/{cluster}`. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return the result of the RPC. The response message type + /// ([google.cloud.hypercomputecluster.v1.Cluster]) + /// is mapped to a C++ class using the [Protobuf mapping rules]. + /// If the request fails, the [`StatusOr`] contains the error details. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.GetClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L265} + /// + // clang-format on + StatusOr GetCluster( + std::string const& name, Options opts = {}); + + // clang-format off + /// + /// Gets details of a single Cluster. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.hypercomputecluster.v1.GetClusterRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return the result of the RPC. The response message type + /// ([google.cloud.hypercomputecluster.v1.Cluster]) + /// is mapped to a C++ class using the [Protobuf mapping rules]. + /// If the request fails, the [`StatusOr`] contains the error details. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.GetClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L265} + /// + // clang-format on + StatusOr GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request, + Options opts = {}); + + // clang-format off + /// + /// Creates a new Cluster in a given project and location. + /// + /// @param parent Required. Parent location in which the cluster should be created, in the + /// format `projects/{project}/locations/{location}`. + /// @param cluster Required. Cluster to create. + /// @param cluster_id Required. ID of the cluster to create. Must conform to + /// [RFC-1034](https://datatracker.ietf.org/doc/html/rfc1034) (lower-case, + /// alphanumeric, and at most 63 characters). + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return A [`future`] that becomes satisfied when the LRO + /// ([Long Running Operation]) completes or the polling policy in effect + /// for this call is exhausted. The future is satisfied with an error if + /// the LRO completes with an error or the polling policy is exhausted. + /// In this case the [`StatusOr`] returned by the future contains the + /// error. If the LRO completes successfully the value of the future + /// contains the LRO's result. For this RPC the result is a + /// [google.cloud.hypercomputecluster.v1.Cluster] proto message. + /// The C++ class representing this message is created by Protobuf, using + /// the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [Long Running Operation]: https://google.aip.dev/151 + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.CreateClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L278} + /// + // clang-format on + future> + CreateCluster(std::string const& parent, + google::cloud::hypercomputecluster::v1::Cluster const& cluster, + std::string const& cluster_id, Options opts = {}); + + // clang-format off + /// + /// @copybrief CreateCluster + /// + /// Specifying the [`NoAwaitTag`] immediately returns the + /// [`google::longrunning::Operation`] that corresponds to the Long Running + /// Operation that has been started. No polling for operation status occurs. + /// + /// [`NoAwaitTag`]: @ref google::cloud::NoAwaitTag + /// + // clang-format on + StatusOr CreateCluster( + NoAwaitTag, std::string const& parent, + google::cloud::hypercomputecluster::v1::Cluster const& cluster, + std::string const& cluster_id, Options opts = {}); + + // clang-format off + /// + /// Creates a new Cluster in a given project and location. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.hypercomputecluster.v1.CreateClusterRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return A [`future`] that becomes satisfied when the LRO + /// ([Long Running Operation]) completes or the polling policy in effect + /// for this call is exhausted. The future is satisfied with an error if + /// the LRO completes with an error or the polling policy is exhausted. + /// In this case the [`StatusOr`] returned by the future contains the + /// error. If the LRO completes successfully the value of the future + /// contains the LRO's result. For this RPC the result is a + /// [google.cloud.hypercomputecluster.v1.Cluster] proto message. + /// The C++ class representing this message is created by Protobuf, using + /// the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [Long Running Operation]: https://google.aip.dev/151 + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.CreateClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L278} + /// + // clang-format on + future> + CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief CreateCluster + /// + /// Specifying the [`NoAwaitTag`] immediately returns the + /// [`google::longrunning::Operation`] that corresponds to the Long Running + /// Operation that has been started. No polling for operation status occurs. + /// + /// [`NoAwaitTag`]: @ref google::cloud::NoAwaitTag + /// + // clang-format on + StatusOr CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief CreateCluster + /// + /// This method accepts a `google::longrunning::Operation` that corresponds + /// to a previously started Long Running Operation (LRO) and polls the status + /// of the LRO in the background. + /// + // clang-format on + future> + CreateCluster(google::longrunning::Operation const& operation, + Options opts = {}); + + // clang-format off + /// + /// Updates the parameters of a single Cluster. + /// + /// @param cluster Required. Cluster to update. + /// @param update_mask Optional. Mask specifying which fields in the cluster to update. All paths + /// must be specified explicitly - wildcards are not supported. At least one + /// path must be provided. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return A [`future`] that becomes satisfied when the LRO + /// ([Long Running Operation]) completes or the polling policy in effect + /// for this call is exhausted. The future is satisfied with an error if + /// the LRO completes with an error or the polling policy is exhausted. + /// In this case the [`StatusOr`] returned by the future contains the + /// error. If the LRO completes successfully the value of the future + /// contains the LRO's result. For this RPC the result is a + /// [google.cloud.hypercomputecluster.v1.Cluster] proto message. + /// The C++ class representing this message is created by Protobuf, using + /// the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [Long Running Operation]: https://google.aip.dev/151 + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.UpdateClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L307} + /// + // clang-format on + future> + UpdateCluster(google::cloud::hypercomputecluster::v1::Cluster const& cluster, + google::protobuf::FieldMask const& update_mask, + Options opts = {}); + + // clang-format off + /// + /// @copybrief UpdateCluster + /// + /// Specifying the [`NoAwaitTag`] immediately returns the + /// [`google::longrunning::Operation`] that corresponds to the Long Running + /// Operation that has been started. No polling for operation status occurs. + /// + /// [`NoAwaitTag`]: @ref google::cloud::NoAwaitTag + /// + // clang-format on + StatusOr UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::Cluster const& cluster, + google::protobuf::FieldMask const& update_mask, Options opts = {}); + + // clang-format off + /// + /// Updates the parameters of a single Cluster. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.hypercomputecluster.v1.UpdateClusterRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return A [`future`] that becomes satisfied when the LRO + /// ([Long Running Operation]) completes or the polling policy in effect + /// for this call is exhausted. The future is satisfied with an error if + /// the LRO completes with an error or the polling policy is exhausted. + /// In this case the [`StatusOr`] returned by the future contains the + /// error. If the LRO completes successfully the value of the future + /// contains the LRO's result. For this RPC the result is a + /// [google.cloud.hypercomputecluster.v1.Cluster] proto message. + /// The C++ class representing this message is created by Protobuf, using + /// the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [Long Running Operation]: https://google.aip.dev/151 + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.Cluster]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L149} + /// [google.cloud.hypercomputecluster.v1.UpdateClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L307} + /// + // clang-format on + future> + UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief UpdateCluster + /// + /// Specifying the [`NoAwaitTag`] immediately returns the + /// [`google::longrunning::Operation`] that corresponds to the Long Running + /// Operation that has been started. No polling for operation status occurs. + /// + /// [`NoAwaitTag`]: @ref google::cloud::NoAwaitTag + /// + // clang-format on + StatusOr UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief UpdateCluster + /// + /// This method accepts a `google::longrunning::Operation` that corresponds + /// to a previously started Long Running Operation (LRO) and polls the status + /// of the LRO in the background. + /// + // clang-format on + future> + UpdateCluster(google::longrunning::Operation const& operation, + Options opts = {}); + + // clang-format off + /// + /// Deletes a single Cluster. + /// + /// @param name Required. Name of the cluster to delete, in the format + /// `projects/{project}/locations/{location}/clusters/{cluster}`. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return A [`future`] that becomes satisfied when the LRO + /// ([Long Running Operation]) completes or the polling policy in effect + /// for this call is exhausted. The future is satisfied with an error if + /// the LRO completes with an error or the polling policy is exhausted. + /// In this case the [`StatusOr`] returned by the future contains the + /// error. If the LRO completes successfully the value of the future + /// contains the LRO's result. For this RPC the result is a + /// [google.cloud.hypercomputecluster.v1.OperationMetadata] proto message. + /// The C++ class representing this message is created by Protobuf, using + /// the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [Long Running Operation]: https://google.aip.dev/151 + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.DeleteClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L328} + /// [google.cloud.hypercomputecluster.v1.OperationMetadata]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/operation_metadata.proto#L36} + /// + // clang-format on + future> + DeleteCluster(std::string const& name, Options opts = {}); + + // clang-format off + /// + /// @copybrief DeleteCluster + /// + /// Specifying the [`NoAwaitTag`] immediately returns the + /// [`google::longrunning::Operation`] that corresponds to the Long Running + /// Operation that has been started. No polling for operation status occurs. + /// + /// [`NoAwaitTag`]: @ref google::cloud::NoAwaitTag + /// + // clang-format on + StatusOr DeleteCluster( + NoAwaitTag, std::string const& name, Options opts = {}); + + // clang-format off + /// + /// Deletes a single Cluster. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.hypercomputecluster.v1.DeleteClusterRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return A [`future`] that becomes satisfied when the LRO + /// ([Long Running Operation]) completes or the polling policy in effect + /// for this call is exhausted. The future is satisfied with an error if + /// the LRO completes with an error or the polling policy is exhausted. + /// In this case the [`StatusOr`] returned by the future contains the + /// error. If the LRO completes successfully the value of the future + /// contains the LRO's result. For this RPC the result is a + /// [google.cloud.hypercomputecluster.v1.OperationMetadata] proto message. + /// The C++ class representing this message is created by Protobuf, using + /// the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [Long Running Operation]: https://google.aip.dev/151 + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.hypercomputecluster.v1.DeleteClusterRequest]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto#L328} + /// [google.cloud.hypercomputecluster.v1.OperationMetadata]: @googleapis_reference_link{google/cloud/hypercomputecluster/v1/operation_metadata.proto#L36} + /// + // clang-format on + future> + DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief DeleteCluster + /// + /// Specifying the [`NoAwaitTag`] immediately returns the + /// [`google::longrunning::Operation`] that corresponds to the Long Running + /// Operation that has been started. No polling for operation status occurs. + /// + /// [`NoAwaitTag`]: @ref google::cloud::NoAwaitTag + /// + // clang-format on + StatusOr DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief DeleteCluster + /// + /// This method accepts a `google::longrunning::Operation` that corresponds + /// to a previously started Long Running Operation (LRO) and polls the status + /// of the LRO in the background. + /// + // clang-format on + future> + DeleteCluster(google::longrunning::Operation const& operation, + Options opts = {}); + + // clang-format off + /// + /// Lists information about the supported locations for this service. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.location.ListLocationsRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [StreamRange](@ref google::cloud::StreamRange) + /// to iterate of the results. See the documentation of this type for + /// details. In brief, this class has `begin()` and `end()` member + /// functions returning a iterator class meeting the + /// [input iterator requirements]. The value type for this iterator is a + /// [`StatusOr`] as the iteration may fail even after some values are + /// retrieved successfully, for example, if there is a network disconnect. + /// An empty set of results does not indicate an error, it indicates + /// that there are no resources meeting the request criteria. + /// On a successful iteration the `StatusOr` contains elements of type + /// [google.cloud.location.Location], or rather, + /// the C++ class generated by Protobuf from that type. Please consult the + /// Protobuf documentation for details on the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.location.ListLocationsRequest]: @googleapis_reference_link{google/cloud/location/locations.proto#L58} + /// [google.cloud.location.Location]: @googleapis_reference_link{google/cloud/location/locations.proto#L88} + /// + // clang-format on + StreamRange ListLocations( + google::cloud::location::ListLocationsRequest request, Options opts = {}); + + // clang-format off + /// + /// Gets information about a location. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.cloud.location.GetLocationRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return the result of the RPC. The response message type + /// ([google.cloud.location.Location]) + /// is mapped to a C++ class using the [Protobuf mapping rules]. + /// If the request fails, the [`StatusOr`] contains the error details. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.cloud.location.GetLocationRequest]: @googleapis_reference_link{google/cloud/location/locations.proto#L82} + /// [google.cloud.location.Location]: @googleapis_reference_link{google/cloud/location/locations.proto#L88} + /// + // clang-format on + StatusOr GetLocation( + google::cloud::location::GetLocationRequest const& request, + Options opts = {}); + + // clang-format off + /// + /// Lists operations that match the specified filter in the request. If the + /// server doesn't support this method, it returns `UNIMPLEMENTED`. + /// + /// @param name The name of the operation's parent resource. + /// @param filter The standard list filter. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [StreamRange](@ref google::cloud::StreamRange) + /// to iterate of the results. See the documentation of this type for + /// details. In brief, this class has `begin()` and `end()` member + /// functions returning a iterator class meeting the + /// [input iterator requirements]. The value type for this iterator is a + /// [`StatusOr`] as the iteration may fail even after some values are + /// retrieved successfully, for example, if there is a network disconnect. + /// An empty set of results does not indicate an error, it indicates + /// that there are no resources meeting the request criteria. + /// On a successful iteration the `StatusOr` contains elements of type + /// [google.longrunning.Operation], or rather, + /// the C++ class generated by Protobuf from that type. Please consult the + /// Protobuf documentation for details on the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.ListOperationsRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L167} + /// [google.longrunning.Operation]: @googleapis_reference_link{google/longrunning/operations.proto#L121} + /// + // clang-format on + StreamRange ListOperations( + std::string const& name, std::string const& filter, Options opts = {}); + + // clang-format off + /// + /// Lists operations that match the specified filter in the request. If the + /// server doesn't support this method, it returns `UNIMPLEMENTED`. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.longrunning.ListOperationsRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [StreamRange](@ref google::cloud::StreamRange) + /// to iterate of the results. See the documentation of this type for + /// details. In brief, this class has `begin()` and `end()` member + /// functions returning a iterator class meeting the + /// [input iterator requirements]. The value type for this iterator is a + /// [`StatusOr`] as the iteration may fail even after some values are + /// retrieved successfully, for example, if there is a network disconnect. + /// An empty set of results does not indicate an error, it indicates + /// that there are no resources meeting the request criteria. + /// On a successful iteration the `StatusOr` contains elements of type + /// [google.longrunning.Operation], or rather, + /// the C++ class generated by Protobuf from that type. Please consult the + /// Protobuf documentation for details on the [Protobuf mapping rules]. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.ListOperationsRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L167} + /// [google.longrunning.Operation]: @googleapis_reference_link{google/longrunning/operations.proto#L121} + /// + // clang-format on + StreamRange ListOperations( + google::longrunning::ListOperationsRequest request, Options opts = {}); + + // clang-format off + /// + /// Gets the latest state of a long-running operation. Clients can use this + /// method to poll the operation result at intervals as recommended by the API + /// service. + /// + /// @param name The name of the operation resource. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return the result of the RPC. The response message type + /// ([google.longrunning.Operation]) + /// is mapped to a C++ class using the [Protobuf mapping rules]. + /// If the request fails, the [`StatusOr`] contains the error details. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.GetOperationRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L160} + /// [google.longrunning.Operation]: @googleapis_reference_link{google/longrunning/operations.proto#L121} + /// + // clang-format on + StatusOr GetOperation(std::string const& name, + Options opts = {}); + + // clang-format off + /// + /// Gets the latest state of a long-running operation. Clients can use this + /// method to poll the operation result at intervals as recommended by the API + /// service. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.longrunning.GetOperationRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return the result of the RPC. The response message type + /// ([google.longrunning.Operation]) + /// is mapped to a C++ class using the [Protobuf mapping rules]. + /// If the request fails, the [`StatusOr`] contains the error details. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.GetOperationRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L160} + /// [google.longrunning.Operation]: @googleapis_reference_link{google/longrunning/operations.proto#L121} + /// + // clang-format on + StatusOr GetOperation( + google::longrunning::GetOperationRequest const& request, + Options opts = {}); + + // clang-format off + /// + /// Deletes a long-running operation. This method indicates that the client is + /// no longer interested in the operation result. It does not cancel the + /// operation. If the server doesn't support this method, it returns + /// `google.rpc.Code.UNIMPLEMENTED`. + /// + /// @param name The name of the operation resource to be deleted. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [`Status`] object. If the request failed, the + /// status contains the details of the failure. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.DeleteOperationRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L219} + /// + // clang-format on + Status DeleteOperation(std::string const& name, Options opts = {}); + + // clang-format off + /// + /// Deletes a long-running operation. This method indicates that the client is + /// no longer interested in the operation result. It does not cancel the + /// operation. If the server doesn't support this method, it returns + /// `google.rpc.Code.UNIMPLEMENTED`. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.longrunning.DeleteOperationRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [`Status`] object. If the request failed, the + /// status contains the details of the failure. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.DeleteOperationRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L219} + /// + // clang-format on + Status DeleteOperation( + google::longrunning::DeleteOperationRequest const& request, + Options opts = {}); + + // clang-format off + /// + /// Starts asynchronous cancellation on a long-running operation. The server + /// makes a best effort to cancel the operation, but success is not + /// guaranteed. If the server doesn't support this method, it returns + /// `google.rpc.Code.UNIMPLEMENTED`. Clients can use + /// [Operations.GetOperation][google.longrunning.Operations.GetOperation] or + /// other methods to check whether the cancellation succeeded or whether the + /// operation completed despite cancellation. On successful cancellation, + /// the operation is not deleted; instead, it becomes an operation with + /// an [Operation.error][google.longrunning.Operation.error] value with a + /// [google.rpc.Status.code][google.rpc.Status.code] of `1`, corresponding to + /// `Code.CANCELLED`. + /// + /// @param name The name of the operation resource to be cancelled. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [`Status`] object. If the request failed, the + /// status contains the details of the failure. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.CancelOperationRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L212} + /// [google.longrunning.Operation.error]: @googleapis_reference_link{google/longrunning/operations.proto#L144} + /// [google.longrunning.Operations.GetOperation]: @googleapis_reference_link{google/longrunning/operations.proto#L70} + /// [google.rpc.Status.code]: @googleapis_reference_link{google/rpc/status.proto#L38} + /// + // clang-format on + Status CancelOperation(std::string const& name, Options opts = {}); + + // clang-format off + /// + /// Starts asynchronous cancellation on a long-running operation. The server + /// makes a best effort to cancel the operation, but success is not + /// guaranteed. If the server doesn't support this method, it returns + /// `google.rpc.Code.UNIMPLEMENTED`. Clients can use + /// [Operations.GetOperation][google.longrunning.Operations.GetOperation] or + /// other methods to check whether the cancellation succeeded or whether the + /// operation completed despite cancellation. On successful cancellation, + /// the operation is not deleted; instead, it becomes an operation with + /// an [Operation.error][google.longrunning.Operation.error] value with a + /// [google.rpc.Status.code][google.rpc.Status.code] of `1`, corresponding to + /// `Code.CANCELLED`. + /// + /// @param request Unary RPCs, such as the one wrapped by this + /// function, receive a single `request` proto message which includes all + /// the inputs for the RPC. In this case, the proto message is a + /// [google.longrunning.CancelOperationRequest]. + /// Proto messages are converted to C++ classes by Protobuf, using the + /// [Protobuf mapping rules]. + /// @param opts Optional. Override the class-level options, such as retry and + /// backoff policies. + /// @return a [`Status`] object. If the request failed, the + /// status contains the details of the failure. + /// + /// [Protobuf mapping rules]: https://protobuf.dev/reference/cpp/cpp-generated/ + /// [input iterator requirements]: https://en.cppreference.com/w/cpp/named_req/InputIterator + /// [`std::string`]: https://en.cppreference.com/w/cpp/string/basic_string + /// [`future`]: @ref google::cloud::future + /// [`StatusOr`]: @ref google::cloud::StatusOr + /// [`Status`]: @ref google::cloud::Status + /// [google.longrunning.CancelOperationRequest]: @googleapis_reference_link{google/longrunning/operations.proto#L212} + /// [google.longrunning.Operation.error]: @googleapis_reference_link{google/longrunning/operations.proto#L144} + /// [google.longrunning.Operations.GetOperation]: @googleapis_reference_link{google/longrunning/operations.proto#L70} + /// [google.rpc.Status.code]: @googleapis_reference_link{google/rpc/status.proto#L38} + /// + // clang-format on + Status CancelOperation( + google::longrunning::CancelOperationRequest const& request, + Options opts = {}); + + private: + std::shared_ptr connection_; + Options options_; +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CLIENT_H diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.cc b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.cc new file mode 100644 index 0000000000000..8aa038ff4054f --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.cc @@ -0,0 +1,188 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.h" +#include "google/cloud/background_threads.h" +#include "google/cloud/common_options.h" +#include "google/cloud/credentials.h" +#include "google/cloud/grpc_options.h" +#include "google/cloud/internal/pagination_range.h" +#include "google/cloud/internal/unified_grpc_credentials.h" +#include +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterConnection::~HypercomputeClusterConnection() = default; + +StreamRange +HypercomputeClusterConnection::ListClusters( + google::cloud::hypercomputecluster::v1:: + ListClustersRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StatusOr +HypercomputeClusterConnection::GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +future> +HypercomputeClusterConnection::CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +StatusOr +HypercomputeClusterConnection::CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const&) { + return StatusOr( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +future> +HypercomputeClusterConnection::CreateCluster( + google::longrunning::Operation const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +future> +HypercomputeClusterConnection::UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +StatusOr +HypercomputeClusterConnection::UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const&) { + return StatusOr( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +future> +HypercomputeClusterConnection::UpdateCluster( + google::longrunning::Operation const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +future> +HypercomputeClusterConnection::DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +StatusOr +HypercomputeClusterConnection::DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const&) { + return StatusOr( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +future> +HypercomputeClusterConnection::DeleteCluster( + google::longrunning::Operation const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +StreamRange +HypercomputeClusterConnection::ListLocations( + google::cloud::location:: + ListLocationsRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StatusOr +HypercomputeClusterConnection::GetLocation( + google::cloud::location::GetLocationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +StreamRange +HypercomputeClusterConnection::ListOperations( + google::longrunning:: + ListOperationsRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StatusOr +HypercomputeClusterConnection::GetOperation( + google::longrunning::GetOperationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +Status HypercomputeClusterConnection::DeleteOperation( + google::longrunning::DeleteOperationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +Status HypercomputeClusterConnection::CancelOperation( + google::longrunning::CancelOperationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +std::shared_ptr +MakeHypercomputeClusterConnection(Options options) { + internal::CheckExpectedOptions(options, + __func__); + options = hypercomputecluster_v1_internal::HypercomputeClusterDefaultOptions( + std::move(options)); + auto background = internal::MakeBackgroundThreadsFactory(options)(); + auto auth = internal::CreateAuthenticationStrategy(background->cq(), options); + auto stub = + hypercomputecluster_v1_internal::CreateDefaultHypercomputeClusterStub( + std::move(auth), options); + return hypercomputecluster_v1_internal:: + MakeHypercomputeClusterTracingConnection( + std::make_shared( + std::move(background), std::move(stub), std::move(options))); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h new file mode 100644 index 0000000000000..5acbc19a5d3eb --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h @@ -0,0 +1,292 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CONNECTION_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CONNECTION_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.pb.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_retry_traits.h" +#include "google/cloud/backoff_policy.h" +#include "google/cloud/future.h" +#include "google/cloud/internal/retry_policy_impl.h" +#include "google/cloud/no_await_tag.h" +#include "google/cloud/options.h" +#include "google/cloud/polling_policy.h" +#include "google/cloud/status_or.h" +#include "google/cloud/stream_range.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/// The retry policy for `HypercomputeClusterConnection`. +class HypercomputeClusterRetryPolicy : public ::google::cloud::RetryPolicy { + public: + /// Creates a new instance of the policy, reset to the initial state. + virtual std::unique_ptr clone() const = 0; +}; + +/** + * A retry policy for `HypercomputeClusterConnection` based on counting errors. + * + * This policy stops retrying if: + * - An RPC returns a non-transient error. + * - More than a prescribed number of transient failures is detected. + * + * In this class the following status codes are treated as transient errors: + * - [`kUnavailable`](@ref google::cloud::StatusCode) + */ +class HypercomputeClusterLimitedErrorCountRetryPolicy + : public HypercomputeClusterRetryPolicy { + public: + /** + * Create an instance that tolerates up to @p maximum_failures transient + * errors. + * + * @note Disable the retry loop by providing an instance of this policy with + * @p maximum_failures == 0. + */ + explicit HypercomputeClusterLimitedErrorCountRetryPolicy(int maximum_failures) + : impl_(maximum_failures) {} + + HypercomputeClusterLimitedErrorCountRetryPolicy( + HypercomputeClusterLimitedErrorCountRetryPolicy&& rhs) noexcept + : HypercomputeClusterLimitedErrorCountRetryPolicy( + rhs.maximum_failures()) {} + HypercomputeClusterLimitedErrorCountRetryPolicy( + HypercomputeClusterLimitedErrorCountRetryPolicy const& rhs) noexcept + : HypercomputeClusterLimitedErrorCountRetryPolicy( + rhs.maximum_failures()) {} + + int maximum_failures() const { return impl_.maximum_failures(); } + + bool OnFailure(Status const& status) override { + return impl_.OnFailure(status); + } + bool IsExhausted() const override { return impl_.IsExhausted(); } + bool IsPermanentFailure(Status const& status) const override { + return impl_.IsPermanentFailure(status); + } + std::unique_ptr clone() const override { + return std::make_unique( + maximum_failures()); + } + + // This is provided only for backwards compatibility. + using BaseType = HypercomputeClusterRetryPolicy; + + private: + google::cloud::internal::LimitedErrorCountRetryPolicy< + hypercomputecluster_v1_internal::HypercomputeClusterRetryTraits> + impl_; +}; + +/** + * A retry policy for `HypercomputeClusterConnection` based on elapsed time. + * + * This policy stops retrying if: + * - An RPC returns a non-transient error. + * - The elapsed time in the retry loop exceeds a prescribed duration. + * + * In this class the following status codes are treated as transient errors: + * - [`kUnavailable`](@ref google::cloud::StatusCode) + */ +class HypercomputeClusterLimitedTimeRetryPolicy + : public HypercomputeClusterRetryPolicy { + public: + /** + * Constructor given a `std::chrono::duration<>` object. + * + * @tparam DurationRep a placeholder to match the `Rep` tparam for @p + * duration's type. The semantics of this template parameter are + * documented in `std::chrono::duration<>`. In brief, the underlying + * arithmetic type used to store the number of ticks. For our purposes it + * is simply a formal parameter. + * @tparam DurationPeriod a placeholder to match the `Period` tparam for @p + * duration's type. The semantics of this template parameter are + * documented in `std::chrono::duration<>`. In brief, the length of the + * tick in seconds, expressed as a `std::ratio<>`. For our purposes it is + * simply a formal parameter. + * @param maximum_duration the maximum time allowed before the policy expires. + * While the application can express this time in any units they desire, + * the class truncates to milliseconds. + * + * @see https://en.cppreference.com/w/cpp/chrono/duration for more information + * about `std::chrono::duration`. + */ + template + explicit HypercomputeClusterLimitedTimeRetryPolicy( + std::chrono::duration maximum_duration) + : impl_(maximum_duration) {} + + HypercomputeClusterLimitedTimeRetryPolicy( + HypercomputeClusterLimitedTimeRetryPolicy&& rhs) noexcept + : HypercomputeClusterLimitedTimeRetryPolicy(rhs.maximum_duration()) {} + HypercomputeClusterLimitedTimeRetryPolicy( + HypercomputeClusterLimitedTimeRetryPolicy const& rhs) noexcept + : HypercomputeClusterLimitedTimeRetryPolicy(rhs.maximum_duration()) {} + + std::chrono::milliseconds maximum_duration() const { + return impl_.maximum_duration(); + } + + bool OnFailure(Status const& status) override { + return impl_.OnFailure(status); + } + bool IsExhausted() const override { return impl_.IsExhausted(); } + bool IsPermanentFailure(Status const& status) const override { + return impl_.IsPermanentFailure(status); + } + std::unique_ptr clone() const override { + return std::make_unique( + maximum_duration()); + } + + // This is provided only for backwards compatibility. + using BaseType = HypercomputeClusterRetryPolicy; + + private: + google::cloud::internal::LimitedTimeRetryPolicy< + hypercomputecluster_v1_internal::HypercomputeClusterRetryTraits> + impl_; +}; + +/** + * The `HypercomputeClusterConnection` object for `HypercomputeClusterClient`. + * + * This interface defines virtual methods for each of the user-facing overload + * sets in `HypercomputeClusterClient`. This allows users to inject custom + * behavior (e.g., with a Google Mock object) when writing tests that use + * objects of type `HypercomputeClusterClient`. + * + * To create a concrete instance, see `MakeHypercomputeClusterConnection()`. + * + * For mocking, see + * `hypercomputecluster_v1_mocks::MockHypercomputeClusterConnection`. + */ +class HypercomputeClusterConnection { + public: + virtual ~HypercomputeClusterConnection() = 0; + + virtual Options options() { return Options{}; } + + virtual StreamRange + ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request); + + virtual StatusOr GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request); + + virtual future> + CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request); + + virtual StatusOr CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request); + + virtual future> + CreateCluster(google::longrunning::Operation const& operation); + + virtual future> + UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request); + + virtual StatusOr UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request); + + virtual future> + UpdateCluster(google::longrunning::Operation const& operation); + + virtual future< + StatusOr> + DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request); + + virtual StatusOr DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request); + + virtual future< + StatusOr> + DeleteCluster(google::longrunning::Operation const& operation); + + virtual StreamRange ListLocations( + google::cloud::location::ListLocationsRequest request); + + virtual StatusOr GetLocation( + google::cloud::location::GetLocationRequest const& request); + + virtual StreamRange ListOperations( + google::longrunning::ListOperationsRequest request); + + virtual StatusOr GetOperation( + google::longrunning::GetOperationRequest const& request); + + virtual Status DeleteOperation( + google::longrunning::DeleteOperationRequest const& request); + + virtual Status CancelOperation( + google::longrunning::CancelOperationRequest const& request); +}; + +/** + * A factory function to construct an object of type + * `HypercomputeClusterConnection`. + * + * The returned connection object should not be used directly; instead it + * should be passed as an argument to the constructor of + * HypercomputeClusterClient. + * + * The optional @p options argument may be used to configure aspects of the + * returned `HypercomputeClusterConnection`. Expected options are any of the + * types in the following option lists: + * + * - `google::cloud::CommonOptionList` + * - `google::cloud::GrpcOptionList` + * - `google::cloud::UnifiedCredentialsOptionList` + * - + * `google::cloud::hypercomputecluster_v1::HypercomputeClusterPolicyOptionList` + * + * @note Unexpected options will be ignored. To log unexpected options instead, + * set `GOOGLE_CLOUD_CPP_ENABLE_CLOG=yes` in the environment. + * + * @param options (optional) Configure the `HypercomputeClusterConnection` + * created by this function. + */ +std::shared_ptr +MakeHypercomputeClusterConnection(Options options = {}); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CONNECTION_H diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.cc b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.cc new file mode 100644 index 0000000000000..81f4e17027000 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.cc @@ -0,0 +1,101 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +using ::google::cloud::Idempotency; + +HypercomputeClusterConnectionIdempotencyPolicy:: + ~HypercomputeClusterConnectionIdempotencyPolicy() = default; + +std::unique_ptr +HypercomputeClusterConnectionIdempotencyPolicy::clone() const { + return std::make_unique( + *this); +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::ListLocations( + google::cloud::location::ListLocationsRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::GetLocation( + google::cloud::location::GetLocationRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::ListOperations( + google::longrunning::ListOperationsRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::GetOperation( + google::longrunning::GetOperationRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::DeleteOperation( + google::longrunning::DeleteOperationRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency HypercomputeClusterConnectionIdempotencyPolicy::CancelOperation( + google::longrunning::CancelOperationRequest const&) { + return Idempotency::kNonIdempotent; +} + +std::unique_ptr +MakeDefaultHypercomputeClusterConnectionIdempotencyPolicy() { + return std::make_unique(); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h new file mode 100644 index 0000000000000..acdf74f19c15b --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h @@ -0,0 +1,87 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CONNECTION_IDEMPOTENCY_POLICY_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CONNECTION_IDEMPOTENCY_POLICY_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include "google/cloud/location/locations.grpc.pb.h" +#include "google/cloud/idempotency.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterConnectionIdempotencyPolicy { + public: + virtual ~HypercomputeClusterConnectionIdempotencyPolicy(); + + /// Create a new copy of this object. + virtual std::unique_ptr + clone() const; + + virtual google::cloud::Idempotency ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request); + + virtual google::cloud::Idempotency GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request); + + virtual google::cloud::Idempotency CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request); + + virtual google::cloud::Idempotency UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request); + + virtual google::cloud::Idempotency DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request); + + virtual google::cloud::Idempotency ListLocations( + google::cloud::location::ListLocationsRequest request); + + virtual google::cloud::Idempotency GetLocation( + google::cloud::location::GetLocationRequest const& request); + + virtual google::cloud::Idempotency ListOperations( + google::longrunning::ListOperationsRequest request); + + virtual google::cloud::Idempotency GetOperation( + google::longrunning::GetOperationRequest const& request); + + virtual google::cloud::Idempotency DeleteOperation( + google::longrunning::DeleteOperationRequest const& request); + + virtual google::cloud::Idempotency CancelOperation( + google::longrunning::CancelOperationRequest const& request); +}; + +std::unique_ptr +MakeDefaultHypercomputeClusterConnectionIdempotencyPolicy(); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_CONNECTION_IDEMPOTENCY_POLICY_H diff --git a/google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h new file mode 100644 index 0000000000000..6512e0feea063 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h @@ -0,0 +1,87 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_OPTIONS_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_OPTIONS_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h" +#include "google/cloud/backoff_policy.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/** + * Use with `google::cloud::Options` to configure the retry policy. + * + * @ingroup google-cloud-hypercomputecluster-options + */ +struct HypercomputeClusterRetryPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * Use with `google::cloud::Options` to configure the backoff policy. + * + * @ingroup google-cloud-hypercomputecluster-options + */ +struct HypercomputeClusterBackoffPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * Use with `google::cloud::Options` to configure which operations are retried. + * + * @ingroup google-cloud-hypercomputecluster-options + */ +struct HypercomputeClusterConnectionIdempotencyPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * Use with `google::cloud::Options` to configure the long-running operations + * polling policy. + * + * @ingroup google-cloud-hypercomputecluster-options + */ +struct HypercomputeClusterPollingPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * The options applicable to HypercomputeCluster. + * + * @ingroup google-cloud-hypercomputecluster-options + */ +using HypercomputeClusterPolicyOptionList = + OptionList; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_HYPERCOMPUTE_CLUSTER_OPTIONS_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.cc new file mode 100644 index 0000000000000..5544c153fccaa --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.cc @@ -0,0 +1,238 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterAuth::HypercomputeClusterAuth( + std::shared_ptr auth, + std::shared_ptr child) + : auth_(std::move(auth)), child_(std::move(child)) {} + +StatusOr +HypercomputeClusterAuth::ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->ListClusters(context, options, request); +} + +StatusOr +HypercomputeClusterAuth::GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GetCluster(context, options, request); +} + +future> +HypercomputeClusterAuth::AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + using ReturnType = StatusOr; + return auth_->AsyncConfigureContext(std::move(context)) + .then([cq, child = child_, options = std::move(options), + request](future>> + f) mutable { + auto context = f.get(); + if (!context) { + return make_ready_future(ReturnType(std::move(context).status())); + } + return child->AsyncCreateCluster(cq, *std::move(context), + std::move(options), request); + }); +} + +StatusOr HypercomputeClusterAuth::CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->CreateCluster(context, options, request); +} + +future> +HypercomputeClusterAuth::AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + using ReturnType = StatusOr; + return auth_->AsyncConfigureContext(std::move(context)) + .then([cq, child = child_, options = std::move(options), + request](future>> + f) mutable { + auto context = f.get(); + if (!context) { + return make_ready_future(ReturnType(std::move(context).status())); + } + return child->AsyncUpdateCluster(cq, *std::move(context), + std::move(options), request); + }); +} + +StatusOr HypercomputeClusterAuth::UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->UpdateCluster(context, options, request); +} + +future> +HypercomputeClusterAuth::AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + using ReturnType = StatusOr; + return auth_->AsyncConfigureContext(std::move(context)) + .then([cq, child = child_, options = std::move(options), + request](future>> + f) mutable { + auto context = f.get(); + if (!context) { + return make_ready_future(ReturnType(std::move(context).status())); + } + return child->AsyncDeleteCluster(cq, *std::move(context), + std::move(options), request); + }); +} + +StatusOr HypercomputeClusterAuth::DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->DeleteCluster(context, options, request); +} + +StatusOr +HypercomputeClusterAuth::ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->ListLocations(context, options, request); +} + +StatusOr +HypercomputeClusterAuth::GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GetLocation(context, options, request); +} + +StatusOr +HypercomputeClusterAuth::ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->ListOperations(context, options, request); +} + +StatusOr HypercomputeClusterAuth::GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GetOperation(context, options, request); +} + +Status HypercomputeClusterAuth::DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->DeleteOperation(context, options, request); +} + +Status HypercomputeClusterAuth::CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->CancelOperation(context, options, request); +} + +future> +HypercomputeClusterAuth::AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + using ReturnType = StatusOr; + return auth_->AsyncConfigureContext(std::move(context)) + .then([cq, child = child_, options = std::move(options), + request](future>> + f) mutable { + auto context = f.get(); + if (!context) { + return make_ready_future(ReturnType(std::move(context).status())); + } + return child->AsyncGetOperation(cq, *std::move(context), + std::move(options), request); + }); +} + +future HypercomputeClusterAuth::AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return auth_->AsyncConfigureContext(std::move(context)) + .then([cq, child = child_, options = std::move(options), + request](future>> + f) mutable { + auto context = f.get(); + if (!context) return make_ready_future(std::move(context).status()); + return child->AsyncCancelOperation(cq, *std::move(context), + std::move(options), request); + }); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.h new file mode 100644 index 0000000000000..7a156cf93509c --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.h @@ -0,0 +1,140 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_AUTH_DECORATOR_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_AUTH_DECORATOR_H + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/internal/unified_grpc_credentials.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterAuth : public HypercomputeClusterStub { + public: + ~HypercomputeClusterAuth() override = default; + HypercomputeClusterAuth( + std::shared_ptr auth, + std::shared_ptr child); + + StatusOr + ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) override; + + StatusOr GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) override; + + StatusOr GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) override; + + StatusOr ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) override; + + StatusOr GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) override; + + future> AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) override; + + future AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) override; + + private: + std::shared_ptr auth_; + std::shared_ptr child_; +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_AUTH_DECORATOR_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.cc new file mode 100644 index 0000000000000..1287ed569372c --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.cc @@ -0,0 +1,541 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.h" +#include "google/cloud/background_threads.h" +#include "google/cloud/common_options.h" +#include "google/cloud/grpc_options.h" +#include "google/cloud/internal/async_long_running_operation.h" +#include "google/cloud/internal/pagination_range.h" +#include "google/cloud/internal/retry_loop.h" +#include +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN +namespace { + +std::unique_ptr +retry_policy(Options const& options) { + return options + .get() + ->clone(); +} + +std::unique_ptr backoff_policy(Options const& options) { + return options + .get() + ->clone(); +} + +std::unique_ptr< + hypercomputecluster_v1::HypercomputeClusterConnectionIdempotencyPolicy> +idempotency_policy(Options const& options) { + return options + .get() + ->clone(); +} + +std::unique_ptr polling_policy(Options const& options) { + return options + .get() + ->clone(); +} + +} // namespace + +HypercomputeClusterConnectionImpl::HypercomputeClusterConnectionImpl( + std::unique_ptr background, + std::shared_ptr + stub, + Options options) + : background_(std::move(background)), + stub_(std::move(stub)), + options_(internal::MergeOptions( + std::move(options), HypercomputeClusterConnection::options())) {} + +StreamRange +HypercomputeClusterConnectionImpl::ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request) { + request.clear_page_token(); + auto current = google::cloud::internal::SaveCurrentOptions(); + auto idempotency = idempotency_policy(*current)->ListClusters(request); + char const* function_name = __func__; + return google::cloud::internal::MakePaginationRange< + StreamRange>( + current, std::move(request), + [idempotency, function_name, stub = stub_, + retry = std::shared_ptr< + hypercomputecluster_v1::HypercomputeClusterRetryPolicy>( + retry_policy(*current)), + backoff = std::shared_ptr(backoff_policy(*current))]( + Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + r) { + return google::cloud::internal::RetryLoop( + retry->clone(), backoff->clone(), idempotency, + [stub](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1:: + ListClustersRequest const& request) { + return stub->ListClusters(context, options, request); + }, + options, r, function_name); + }, + [](google::cloud::hypercomputecluster::v1::ListClustersResponse r) { + std::vector result( + r.clusters().size()); + auto& messages = *r.mutable_clusters(); + std::move(messages.begin(), messages.end(), result.begin()); + return result; + }); +} + +StatusOr +HypercomputeClusterConnectionImpl::GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GetCluster(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& + request) { + return stub_->GetCluster(context, options, request); + }, + *current, request, __func__); +} + +future> +HypercomputeClusterConnectionImpl::CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + auto request_copy = request; + auto const idempotent = + idempotency_policy(*current)->CreateCluster(request_copy); + return google::cloud::internal::AsyncLongRunningOperation< + google::cloud::hypercomputecluster::v1::Cluster>( + background_->cq(), current, std::move(request_copy), + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return stub->AsyncCreateCluster(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return stub->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return stub->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + &google::cloud::internal::ExtractLongRunningResultResponse< + google::cloud::hypercomputecluster::v1::Cluster>, + retry_policy(*current), backoff_policy(*current), idempotent, + polling_policy(*current), __func__); +} + +StatusOr +HypercomputeClusterConnectionImpl::CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->CreateCluster(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return stub_->CreateCluster(context, options, request); + }, + *current, request, __func__); +} + +future> +HypercomputeClusterConnectionImpl::CreateCluster( + google::longrunning::Operation const& operation) { + auto current = google::cloud::internal::SaveCurrentOptions(); + if (!operation.metadata() + .Is()) { + return make_ready_future< + StatusOr>( + internal::InvalidArgumentError( + "operation does not correspond to CreateCluster", + GCP_ERROR_INFO().WithMetadata("operation", + operation.metadata().DebugString()))); + } + + return google::cloud::internal::AsyncAwaitLongRunningOperation< + google::cloud::hypercomputecluster::v1::Cluster>( + background_->cq(), current, operation, + [stub = stub_](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return stub->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return stub->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + &google::cloud::internal::ExtractLongRunningResultResponse< + google::cloud::hypercomputecluster::v1::Cluster>, + polling_policy(*current), __func__); +} + +future> +HypercomputeClusterConnectionImpl::UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + auto request_copy = request; + auto const idempotent = + idempotency_policy(*current)->UpdateCluster(request_copy); + return google::cloud::internal::AsyncLongRunningOperation< + google::cloud::hypercomputecluster::v1::Cluster>( + background_->cq(), current, std::move(request_copy), + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return stub->AsyncUpdateCluster(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return stub->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return stub->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + &google::cloud::internal::ExtractLongRunningResultResponse< + google::cloud::hypercomputecluster::v1::Cluster>, + retry_policy(*current), backoff_policy(*current), idempotent, + polling_policy(*current), __func__); +} + +StatusOr +HypercomputeClusterConnectionImpl::UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->UpdateCluster(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return stub_->UpdateCluster(context, options, request); + }, + *current, request, __func__); +} + +future> +HypercomputeClusterConnectionImpl::UpdateCluster( + google::longrunning::Operation const& operation) { + auto current = google::cloud::internal::SaveCurrentOptions(); + if (!operation.metadata() + .Is()) { + return make_ready_future< + StatusOr>( + internal::InvalidArgumentError( + "operation does not correspond to UpdateCluster", + GCP_ERROR_INFO().WithMetadata("operation", + operation.metadata().DebugString()))); + } + + return google::cloud::internal::AsyncAwaitLongRunningOperation< + google::cloud::hypercomputecluster::v1::Cluster>( + background_->cq(), current, operation, + [stub = stub_](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return stub->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return stub->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + &google::cloud::internal::ExtractLongRunningResultResponse< + google::cloud::hypercomputecluster::v1::Cluster>, + polling_policy(*current), __func__); +} + +future> +HypercomputeClusterConnectionImpl::DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + auto request_copy = request; + auto const idempotent = + idempotency_policy(*current)->DeleteCluster(request_copy); + return google::cloud::internal::AsyncLongRunningOperation< + google::cloud::hypercomputecluster::v1::OperationMetadata>( + background_->cq(), current, std::move(request_copy), + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return stub->AsyncDeleteCluster(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return stub->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return stub->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + &google::cloud::internal::ExtractLongRunningResultMetadata< + google::cloud::hypercomputecluster::v1::OperationMetadata>, + retry_policy(*current), backoff_policy(*current), idempotent, + polling_policy(*current), __func__); +} + +StatusOr +HypercomputeClusterConnectionImpl::DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->DeleteCluster(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return stub_->DeleteCluster(context, options, request); + }, + *current, request, __func__); +} + +future> +HypercomputeClusterConnectionImpl::DeleteCluster( + google::longrunning::Operation const& operation) { + auto current = google::cloud::internal::SaveCurrentOptions(); + if (!operation.metadata() + .Is()) { + return make_ready_future< + StatusOr>( + internal::InvalidArgumentError( + "operation does not correspond to DeleteCluster", + GCP_ERROR_INFO().WithMetadata("operation", + operation.metadata().DebugString()))); + } + + return google::cloud::internal::AsyncAwaitLongRunningOperation< + google::cloud::hypercomputecluster::v1::OperationMetadata>( + background_->cq(), current, operation, + [stub = stub_](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return stub->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return stub->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + &google::cloud::internal::ExtractLongRunningResultMetadata< + google::cloud::hypercomputecluster::v1::OperationMetadata>, + polling_policy(*current), __func__); +} + +StreamRange +HypercomputeClusterConnectionImpl::ListLocations( + google::cloud::location::ListLocationsRequest request) { + request.clear_page_token(); + auto current = google::cloud::internal::SaveCurrentOptions(); + auto idempotency = idempotency_policy(*current)->ListLocations(request); + char const* function_name = __func__; + return google::cloud::internal::MakePaginationRange< + StreamRange>( + current, std::move(request), + [idempotency, function_name, stub = stub_, + retry = std::shared_ptr< + hypercomputecluster_v1::HypercomputeClusterRetryPolicy>( + retry_policy(*current)), + backoff = std::shared_ptr(backoff_policy(*current))]( + Options const& options, + google::cloud::location::ListLocationsRequest const& r) { + return google::cloud::internal::RetryLoop( + retry->clone(), backoff->clone(), idempotency, + [stub]( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + return stub->ListLocations(context, options, request); + }, + options, r, function_name); + }, + [](google::cloud::location::ListLocationsResponse r) { + std::vector result( + r.locations().size()); + auto& messages = *r.mutable_locations(); + std::move(messages.begin(), messages.end(), result.begin()); + return result; + }); +} + +StatusOr +HypercomputeClusterConnectionImpl::GetLocation( + google::cloud::location::GetLocationRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GetLocation(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + return stub_->GetLocation(context, options, request); + }, + *current, request, __func__); +} + +StreamRange +HypercomputeClusterConnectionImpl::ListOperations( + google::longrunning::ListOperationsRequest request) { + request.clear_page_token(); + auto current = google::cloud::internal::SaveCurrentOptions(); + auto idempotency = idempotency_policy(*current)->ListOperations(request); + char const* function_name = __func__; + return google::cloud::internal::MakePaginationRange< + StreamRange>( + current, std::move(request), + [idempotency, function_name, stub = stub_, + retry = std::shared_ptr< + hypercomputecluster_v1::HypercomputeClusterRetryPolicy>( + retry_policy(*current)), + backoff = std::shared_ptr(backoff_policy(*current))]( + Options const& options, + google::longrunning::ListOperationsRequest const& r) { + return google::cloud::internal::RetryLoop( + retry->clone(), backoff->clone(), idempotency, + [stub](grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + return stub->ListOperations(context, options, request); + }, + options, r, function_name); + }, + [](google::longrunning::ListOperationsResponse r) { + std::vector result( + r.operations().size()); + auto& messages = *r.mutable_operations(); + std::move(messages.begin(), messages.end(), result.begin()); + return result; + }); +} + +StatusOr +HypercomputeClusterConnectionImpl::GetOperation( + google::longrunning::GetOperationRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GetOperation(request), + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + return stub_->GetOperation(context, options, request); + }, + *current, request, __func__); +} + +Status HypercomputeClusterConnectionImpl::DeleteOperation( + google::longrunning::DeleteOperationRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->DeleteOperation(request), + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + return stub_->DeleteOperation(context, options, request); + }, + *current, request, __func__); +} + +Status HypercomputeClusterConnectionImpl::CancelOperation( + google::longrunning::CancelOperationRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->CancelOperation(request), + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + return stub_->CancelOperation(context, options, request); + }, + *current, request, __func__); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.h new file mode 100644 index 0000000000000..6c7950418147f --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.h @@ -0,0 +1,133 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_CONNECTION_IMPL_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_CONNECTION_IMPL_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_retry_traits.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/background_threads.h" +#include "google/cloud/backoff_policy.h" +#include "google/cloud/future.h" +#include "google/cloud/options.h" +#include "google/cloud/polling_policy.h" +#include "google/cloud/status_or.h" +#include "google/cloud/stream_range.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterConnectionImpl + : public hypercomputecluster_v1::HypercomputeClusterConnection { + public: + ~HypercomputeClusterConnectionImpl() override = default; + + HypercomputeClusterConnectionImpl( + std::unique_ptr background, + std::shared_ptr + stub, + Options options); + + Options options() override { return options_; } + + StreamRange ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request) + override; + + StatusOr GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> + CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> + CreateCluster(google::longrunning::Operation const& operation) override; + + future> + UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> + UpdateCluster(google::longrunning::Operation const& operation) override; + + future> + DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + future> + DeleteCluster(google::longrunning::Operation const& operation) override; + + StreamRange ListLocations( + google::cloud::location::ListLocationsRequest request) override; + + StatusOr GetLocation( + google::cloud::location::GetLocationRequest const& request) override; + + StreamRange ListOperations( + google::longrunning::ListOperationsRequest request) override; + + StatusOr GetOperation( + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + google::longrunning::CancelOperationRequest const& request) override; + + private: + std::unique_ptr background_; + std::shared_ptr + stub_; + Options options_; +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_CONNECTION_IMPL_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.cc new file mode 100644 index 0000000000000..927aa64515952 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.cc @@ -0,0 +1,280 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include "google/cloud/internal/log_wrapper.h" +#include "google/cloud/status_or.h" +#include +#include +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterLogging::HypercomputeClusterLogging( + std::shared_ptr child, + TracingOptions tracing_options, std::set const&) + : child_(std::move(child)), tracing_options_(std::move(tracing_options)) {} + +StatusOr +HypercomputeClusterLogging::ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) { + return child_->ListClusters(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& + request) { + return child_->GetCluster(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +future> +HypercomputeClusterLogging::AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return child_->AsyncCreateCluster(cq, std::move(context), + std::move(options), request); + }, + cq, std::move(context), std::move(options), request, __func__, + tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return child_->CreateCluster(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +future> +HypercomputeClusterLogging::AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return child_->AsyncUpdateCluster(cq, std::move(context), + std::move(options), request); + }, + cq, std::move(context), std::move(options), request, __func__, + tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return child_->UpdateCluster(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +future> +HypercomputeClusterLogging::AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return child_->AsyncDeleteCluster(cq, std::move(context), + std::move(options), request); + }, + cq, std::move(context), std::move(options), request, __func__, + tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return child_->DeleteCluster(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + return child_->ListLocations(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + return child_->GetLocation(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + return child_->ListOperations(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +HypercomputeClusterLogging::GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + return child_->GetOperation(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +Status HypercomputeClusterLogging::DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + return child_->DeleteOperation(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +Status HypercomputeClusterLogging::CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + return child_->CancelOperation(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +future> +HypercomputeClusterLogging::AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + return child_->AsyncGetOperation(cq, std::move(context), + std::move(options), request); + }, + cq, std::move(context), std::move(options), request, __func__, + tracing_options_); +} + +future HypercomputeClusterLogging::AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + return child_->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); + }, + cq, std::move(context), std::move(options), request, __func__, + tracing_options_); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.h new file mode 100644 index 0000000000000..b6da58db7d760 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.h @@ -0,0 +1,140 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_LOGGING_DECORATOR_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_LOGGING_DECORATOR_H + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/tracing_options.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterLogging : public HypercomputeClusterStub { + public: + ~HypercomputeClusterLogging() override = default; + HypercomputeClusterLogging(std::shared_ptr child, + TracingOptions tracing_options, + std::set const& components); + + StatusOr + ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) override; + + StatusOr GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) override; + + StatusOr GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) override; + + StatusOr ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) override; + + StatusOr GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) override; + + future> AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) override; + + future AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) override; + + private: + std::shared_ptr child_; + TracingOptions tracing_options_; +}; // HypercomputeClusterLogging + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_LOGGING_DECORATOR_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.cc new file mode 100644 index 0000000000000..ed7c18784e541 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.cc @@ -0,0 +1,234 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include "google/cloud/grpc_options.h" +#include "google/cloud/internal/api_client_header.h" +#include "google/cloud/internal/url_encode.h" +#include "google/cloud/status_or.h" +#include "absl/strings/str_cat.h" +#include "absl/strings/str_join.h" +#include +#include +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterMetadata::HypercomputeClusterMetadata( + std::shared_ptr child, + std::multimap fixed_metadata, + std::string api_client_header) + : child_(std::move(child)), + fixed_metadata_(std::move(fixed_metadata)), + api_client_header_( + api_client_header.empty() + ? google::cloud::internal::GeneratedLibClientHeader() + : std::move(api_client_header)) {} + +StatusOr +HypercomputeClusterMetadata::ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("parent=", internal::UrlEncode(request.parent()))); + return child_->ListClusters(context, options, request); +} + +StatusOr +HypercomputeClusterMetadata::GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->GetCluster(context, options, request); +} + +future> +HypercomputeClusterMetadata::AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + SetMetadata(*context, *options, + absl::StrCat("parent=", internal::UrlEncode(request.parent()))); + return child_->AsyncCreateCluster(cq, std::move(context), std::move(options), + request); +} + +StatusOr +HypercomputeClusterMetadata::CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("parent=", internal::UrlEncode(request.parent()))); + return child_->CreateCluster(context, options, request); +} + +future> +HypercomputeClusterMetadata::AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + SetMetadata(*context, *options, + absl::StrCat("cluster.name=", + internal::UrlEncode(request.cluster().name()))); + return child_->AsyncUpdateCluster(cq, std::move(context), std::move(options), + request); +} + +StatusOr +HypercomputeClusterMetadata::UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("cluster.name=", + internal::UrlEncode(request.cluster().name()))); + return child_->UpdateCluster(context, options, request); +} + +future> +HypercomputeClusterMetadata::AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + SetMetadata(*context, *options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->AsyncDeleteCluster(cq, std::move(context), std::move(options), + request); +} + +StatusOr +HypercomputeClusterMetadata::DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->DeleteCluster(context, options, request); +} + +StatusOr +HypercomputeClusterMetadata::ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->ListLocations(context, options, request); +} + +StatusOr +HypercomputeClusterMetadata::GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->GetLocation(context, options, request); +} + +StatusOr +HypercomputeClusterMetadata::ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->ListOperations(context, options, request); +} + +StatusOr +HypercomputeClusterMetadata::GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->GetOperation(context, options, request); +} + +Status HypercomputeClusterMetadata::DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->DeleteOperation(context, options, request); +} + +Status HypercomputeClusterMetadata::CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->CancelOperation(context, options, request); +} + +future> +HypercomputeClusterMetadata::AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + SetMetadata(*context, *options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->AsyncGetOperation(cq, std::move(context), std::move(options), + request); +} + +future HypercomputeClusterMetadata::AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + SetMetadata(*context, *options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->AsyncCancelOperation(cq, std::move(context), + std::move(options), request); +} + +void HypercomputeClusterMetadata::SetMetadata( + grpc::ClientContext& context, Options const& options, + std::string const& request_params) { + context.AddMetadata("x-goog-request-params", request_params); + SetMetadata(context, options); +} + +void HypercomputeClusterMetadata::SetMetadata(grpc::ClientContext& context, + Options const& options) { + google::cloud::internal::SetMetadata(context, options, fixed_metadata_, + api_client_header_); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.h new file mode 100644 index 0000000000000..808b301488836 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.h @@ -0,0 +1,146 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_METADATA_DECORATOR_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_METADATA_DECORATOR_H + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterMetadata : public HypercomputeClusterStub { + public: + ~HypercomputeClusterMetadata() override = default; + HypercomputeClusterMetadata( + std::shared_ptr child, + std::multimap fixed_metadata, + std::string api_client_header = ""); + + StatusOr + ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) override; + + StatusOr GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) override; + + StatusOr GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) override; + + StatusOr ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) override; + + StatusOr GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) override; + + future> AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) override; + + future AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) override; + + private: + void SetMetadata(grpc::ClientContext& context, Options const& options, + std::string const& request_params); + void SetMetadata(grpc::ClientContext& context, Options const& options); + + std::shared_ptr child_; + std::multimap fixed_metadata_; + std::string api_client_header_; +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_METADATA_DECORATOR_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.cc new file mode 100644 index 0000000000000..57815e74fa576 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.cc @@ -0,0 +1,88 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h" +#include "google/cloud/internal/populate_common_options.h" +#include "google/cloud/internal/populate_grpc_options.h" +#include +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +namespace { +auto constexpr kBackoffScaling = 2.0; +} // namespace + +Options HypercomputeClusterDefaultOptions(Options options) { + options = internal::PopulateCommonOptions( + std::move(options), "GOOGLE_CLOUD_CPP_HYPERCOMPUTE_CLUSTER_ENDPOINT", "", + "GOOGLE_CLOUD_CPP_HYPERCOMPUTE_CLUSTER_AUTHORITY", + "hypercomputecluster.googleapis.com"); + options = internal::PopulateGrpcOptions(std::move(options)); + if (!options.has< + hypercomputecluster_v1::HypercomputeClusterRetryPolicyOption>()) { + options.set( + hypercomputecluster_v1::HypercomputeClusterLimitedTimeRetryPolicy( + std::chrono::minutes(10)) + .clone()); + } + if (!options.has< + hypercomputecluster_v1::HypercomputeClusterBackoffPolicyOption>()) { + options.set( + ExponentialBackoffPolicy( + std::chrono::seconds(0), std::chrono::seconds(1), + std::chrono::minutes(5), kBackoffScaling, kBackoffScaling) + .clone()); + } + if (!options.has< + hypercomputecluster_v1::HypercomputeClusterPollingPolicyOption>()) { + options.set( + GenericPollingPolicy< + hypercomputecluster_v1::HypercomputeClusterRetryPolicyOption::Type, + hypercomputecluster_v1::HypercomputeClusterBackoffPolicyOption:: + Type>( + options + .get() + ->clone(), + ExponentialBackoffPolicy(std::chrono::seconds(1), + std::chrono::minutes(5), kBackoffScaling) + .clone()) + .clone()); + } + if (!options + .has()) { + options.set( + hypercomputecluster_v1:: + MakeDefaultHypercomputeClusterConnectionIdempotencyPolicy()); + } + + return options; +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.h new file mode 100644 index 0000000000000..c98ef311e3e9b --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.h @@ -0,0 +1,37 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_OPTION_DEFAULTS_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_OPTION_DEFAULTS_H + +#include "google/cloud/options.h" +#include "google/cloud/version.h" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +Options HypercomputeClusterDefaultOptions(Options options); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_OPTION_DEFAULTS_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_retry_traits.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_retry_traits.h new file mode 100644 index 0000000000000..b1a2b757491bc --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_retry_traits.h @@ -0,0 +1,43 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_RETRY_TRAITS_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_RETRY_TRAITS_H + +#include "google/cloud/status.h" +#include "google/cloud/version.h" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/// Define the gRPC status code semantics for retrying requests. +struct HypercomputeClusterRetryTraits { + static bool IsPermanentFailure(google::cloud::Status const& status) { + return status.code() != StatusCode::kOk && + status.code() != StatusCode::kUnavailable; + } +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_RETRY_TRAITS_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_sources.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_sources.cc new file mode 100644 index 0000000000000..5f4694fecc6b3 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_sources.cc @@ -0,0 +1,32 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +// NOLINTBEGIN(bugprone-suspicious-include) +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.cc" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.cc" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_connection_impl.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_option_defaults.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.cc" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.cc" +// NOLINTEND(bugprone-suspicious-include) diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.cc new file mode 100644 index 0000000000000..2c1da107f07e2 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.cc @@ -0,0 +1,275 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include "google/cloud/grpc_error_delegate.h" +#include "google/cloud/status_or.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterStub::~HypercomputeClusterStub() = default; + +StatusOr +DefaultHypercomputeClusterStub::ListClusters( + grpc::ClientContext& context, Options const&, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) { + google::cloud::hypercomputecluster::v1::ListClustersResponse response; + auto status = grpc_stub_->ListClusters(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultHypercomputeClusterStub::GetCluster( + grpc::ClientContext& context, Options const&, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + google::cloud::hypercomputecluster::v1::Cluster response; + auto status = grpc_stub_->GetCluster(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +future> +DefaultHypercomputeClusterStub::AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + return internal::MakeUnaryRpcImpl< + google::cloud::hypercomputecluster::v1::CreateClusterRequest, + google::longrunning::Operation>( + cq, + [this](grpc::ClientContext* context, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request, + grpc::CompletionQueue* cq) { + return grpc_stub_->AsyncCreateCluster(context, request, cq); + }, + request, std::move(context)); +} + +StatusOr +DefaultHypercomputeClusterStub::CreateCluster( + grpc::ClientContext& context, Options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + google::longrunning::Operation response; + auto status = grpc_stub_->CreateCluster(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +future> +DefaultHypercomputeClusterStub::AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + return internal::MakeUnaryRpcImpl< + google::cloud::hypercomputecluster::v1::UpdateClusterRequest, + google::longrunning::Operation>( + cq, + [this](grpc::ClientContext* context, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request, + grpc::CompletionQueue* cq) { + return grpc_stub_->AsyncUpdateCluster(context, request, cq); + }, + request, std::move(context)); +} + +StatusOr +DefaultHypercomputeClusterStub::UpdateCluster( + grpc::ClientContext& context, Options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + google::longrunning::Operation response; + auto status = grpc_stub_->UpdateCluster(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +future> +DefaultHypercomputeClusterStub::AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + return internal::MakeUnaryRpcImpl< + google::cloud::hypercomputecluster::v1::DeleteClusterRequest, + google::longrunning::Operation>( + cq, + [this](grpc::ClientContext* context, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request, + grpc::CompletionQueue* cq) { + return grpc_stub_->AsyncDeleteCluster(context, request, cq); + }, + request, std::move(context)); +} + +StatusOr +DefaultHypercomputeClusterStub::DeleteCluster( + grpc::ClientContext& context, Options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + google::longrunning::Operation response; + auto status = grpc_stub_->DeleteCluster(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultHypercomputeClusterStub::ListLocations( + grpc::ClientContext& context, Options const&, + google::cloud::location::ListLocationsRequest const& request) { + google::cloud::location::ListLocationsResponse response; + auto status = locations_stub_->ListLocations(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultHypercomputeClusterStub::GetLocation( + grpc::ClientContext& context, Options const&, + google::cloud::location::GetLocationRequest const& request) { + google::cloud::location::Location response; + auto status = locations_stub_->GetLocation(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultHypercomputeClusterStub::ListOperations( + grpc::ClientContext& context, Options const&, + google::longrunning::ListOperationsRequest const& request) { + google::longrunning::ListOperationsResponse response; + auto status = operations_stub_->ListOperations(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultHypercomputeClusterStub::GetOperation( + grpc::ClientContext& context, Options const&, + google::longrunning::GetOperationRequest const& request) { + google::longrunning::Operation response; + auto status = operations_stub_->GetOperation(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +Status DefaultHypercomputeClusterStub::DeleteOperation( + grpc::ClientContext& context, Options const&, + google::longrunning::DeleteOperationRequest const& request) { + google::protobuf::Empty response; + auto status = operations_stub_->DeleteOperation(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return google::cloud::Status(); +} + +Status DefaultHypercomputeClusterStub::CancelOperation( + grpc::ClientContext& context, Options const&, + google::longrunning::CancelOperationRequest const& request) { + google::protobuf::Empty response; + auto status = operations_stub_->CancelOperation(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return google::cloud::Status(); +} + +future> +DefaultHypercomputeClusterStub::AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + // NOLINTNEXTLINE(performance-unnecessary-value-param) + google::cloud::internal::ImmutableOptions, + google::longrunning::GetOperationRequest const& request) { + return internal::MakeUnaryRpcImpl( + cq, + [this](grpc::ClientContext* context, + google::longrunning::GetOperationRequest const& request, + grpc::CompletionQueue* cq) { + return operations_stub_->AsyncGetOperation(context, request, cq); + }, + request, std::move(context)); +} + +future DefaultHypercomputeClusterStub::AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + // NOLINTNEXTLINE(performance-unnecessary-value-param) + google::cloud::internal::ImmutableOptions, + google::longrunning::CancelOperationRequest const& request) { + return internal::MakeUnaryRpcImpl( + cq, + [this](grpc::ClientContext* context, + google::longrunning::CancelOperationRequest const& request, + grpc::CompletionQueue* cq) { + return operations_stub_->AsyncCancelOperation(context, request, + cq); + }, + request, std::move(context)) + .then([](future> f) { + return f.get().status(); + }); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h new file mode 100644 index 0000000000000..11b067c16322f --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h @@ -0,0 +1,244 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_STUB_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_STUB_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include "google/cloud/location/locations.grpc.pb.h" +#include "google/cloud/completion_queue.h" +#include "google/cloud/future.h" +#include "google/cloud/options.h" +#include "google/cloud/status_or.h" +#include "google/cloud/version.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterStub { + public: + virtual ~HypercomputeClusterStub() = 0; + + virtual StatusOr + ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) = 0; + + virtual StatusOr GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& + request) = 0; + + virtual future> AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) = 0; + + virtual StatusOr CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) = 0; + + virtual future> AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) = 0; + + virtual StatusOr UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) = 0; + + virtual future> AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) = 0; + + virtual StatusOr DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) = 0; + + virtual StatusOr + ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) = 0; + + virtual StatusOr GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) = 0; + + virtual StatusOr ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) = 0; + + virtual StatusOr GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) = 0; + + virtual Status DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) = 0; + + virtual Status CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) = 0; + + virtual future> AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) = 0; + + virtual future AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) = 0; +}; + +class DefaultHypercomputeClusterStub : public HypercomputeClusterStub { + public: + DefaultHypercomputeClusterStub( + std::unique_ptr + grpc_stub, + std::unique_ptr + locations_stub, + std::unique_ptr + operations_stub) + : grpc_stub_(std::move(grpc_stub)), + locations_stub_(std::move(locations_stub)), + operations_stub_(std::move(operations_stub)) {} + + StatusOr + ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) override; + + StatusOr GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) override; + + StatusOr GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) override; + + StatusOr ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) override; + + StatusOr GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) override; + + future> AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) override; + + future AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) override; + + private: + std::unique_ptr + grpc_stub_; + std::unique_ptr + locations_stub_; + std::unique_ptr + operations_stub_; +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_STUB_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.cc new file mode 100644 index 0000000000000..86ae1d0196c71 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.cc @@ -0,0 +1,83 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster.grpc.pb.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_auth_decorator.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_logging_decorator.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_metadata_decorator.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.h" +#include "google/cloud/location/locations.grpc.pb.h" +#include "google/cloud/common_options.h" +#include "google/cloud/grpc_options.h" +#include "google/cloud/internal/algorithm.h" +#include "google/cloud/internal/opentelemetry.h" +#include "google/cloud/log.h" +#include "google/cloud/options.h" +#include "google/longrunning/operations.grpc.pb.h" +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +std::shared_ptr CreateDefaultHypercomputeClusterStub( + std::shared_ptr auth, + Options const& options) { + auto channel = auth->CreateChannel(options.get(), + internal::MakeChannelArguments(options)); + auto service_grpc_stub = + google::cloud::hypercomputecluster::v1::HypercomputeCluster::NewStub( + channel); + auto service_locations_stub = + google::cloud::location::Locations::NewStub(channel); + std::shared_ptr stub = + std::make_shared( + std::move(service_grpc_stub), std::move(service_locations_stub), + google::longrunning::Operations::NewStub(channel)); + + if (auth->RequiresConfigureContext()) { + stub = std::make_shared(std::move(auth), + std::move(stub)); + } + stub = std::make_shared( + std::move(stub), std::multimap{}); + if (internal::Contains(options.get(), "rpc")) { + GCP_LOG(INFO) << "Enabled logging for gRPC calls"; + stub = std::make_shared( + std::move(stub), options.get(), + options.get()); + } + if (internal::TracingEnabled(options)) { + stub = MakeHypercomputeClusterTracingStub(std::move(stub)); + } + return stub; +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.h new file mode 100644 index 0000000000000..91ac1a37d436f --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub_factory.h @@ -0,0 +1,47 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_STUB_FACTORY_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_STUB_FACTORY_H + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/internal/unified_grpc_credentials.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +std::shared_ptr CreateDefaultHypercomputeClusterStub( + std::shared_ptr auth, + Options const& options); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_STUB_FACTORY_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.cc new file mode 100644 index 0000000000000..9232530e1face --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.cc @@ -0,0 +1,216 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.h" +#include "google/cloud/internal/opentelemetry.h" +#include "google/cloud/internal/traced_stream_range.h" +#include +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterTracingConnection::HypercomputeClusterTracingConnection( + std::shared_ptr + child) + : child_(std::move(child)) {} + +StreamRange +HypercomputeClusterTracingConnection::ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::ListClusters"); + internal::OTelScope scope(span); + auto sr = child_->ListClusters(std::move(request)); + return internal::MakeTracedStreamRange< + google::cloud::hypercomputecluster::v1::Cluster>(std::move(span), + std::move(sr)); +} + +StatusOr +HypercomputeClusterTracingConnection::GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::GetCluster"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetCluster(request)); +} + +future> +HypercomputeClusterTracingConnection::CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::CreateCluster"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), child_->CreateCluster(request)); +} + +StatusOr +HypercomputeClusterTracingConnection::CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::CreateCluster"); + opentelemetry::trace::Scope scope(span); + return internal::EndSpan(*span, child_->CreateCluster(NoAwaitTag{}, request)); +} + +future> +HypercomputeClusterTracingConnection::CreateCluster( + google::longrunning::Operation const& operation) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::CreateCluster"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), child_->CreateCluster(operation)); +} + +future> +HypercomputeClusterTracingConnection::UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::UpdateCluster"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), child_->UpdateCluster(request)); +} + +StatusOr +HypercomputeClusterTracingConnection::UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::UpdateCluster"); + opentelemetry::trace::Scope scope(span); + return internal::EndSpan(*span, child_->UpdateCluster(NoAwaitTag{}, request)); +} + +future> +HypercomputeClusterTracingConnection::UpdateCluster( + google::longrunning::Operation const& operation) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::UpdateCluster"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), child_->UpdateCluster(operation)); +} + +future> +HypercomputeClusterTracingConnection::DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::DeleteCluster"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), child_->DeleteCluster(request)); +} + +StatusOr +HypercomputeClusterTracingConnection::DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::DeleteCluster"); + opentelemetry::trace::Scope scope(span); + return internal::EndSpan(*span, child_->DeleteCluster(NoAwaitTag{}, request)); +} + +future> +HypercomputeClusterTracingConnection::DeleteCluster( + google::longrunning::Operation const& operation) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::DeleteCluster"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), child_->DeleteCluster(operation)); +} + +StreamRange +HypercomputeClusterTracingConnection::ListLocations( + google::cloud::location::ListLocationsRequest request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::ListLocations"); + internal::OTelScope scope(span); + auto sr = child_->ListLocations(std::move(request)); + return internal::MakeTracedStreamRange( + std::move(span), std::move(sr)); +} + +StatusOr +HypercomputeClusterTracingConnection::GetLocation( + google::cloud::location::GetLocationRequest const& request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::GetLocation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetLocation(request)); +} + +StreamRange +HypercomputeClusterTracingConnection::ListOperations( + google::longrunning::ListOperationsRequest request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::ListOperations"); + internal::OTelScope scope(span); + auto sr = child_->ListOperations(std::move(request)); + return internal::MakeTracedStreamRange( + std::move(span), std::move(sr)); +} + +StatusOr +HypercomputeClusterTracingConnection::GetOperation( + google::longrunning::GetOperationRequest const& request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::GetOperation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetOperation(request)); +} + +Status HypercomputeClusterTracingConnection::DeleteOperation( + google::longrunning::DeleteOperationRequest const& request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::DeleteOperation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->DeleteOperation(request)); +} + +Status HypercomputeClusterTracingConnection::CancelOperation( + google::longrunning::CancelOperationRequest const& request) { + auto span = internal::MakeSpan( + "hypercomputecluster_v1::HypercomputeClusterConnection::CancelOperation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->CancelOperation(request)); +} + +std::shared_ptr +MakeHypercomputeClusterTracingConnection( + std::shared_ptr + conn) { + if (internal::TracingEnabled(conn->options())) { + conn = + std::make_shared(std::move(conn)); + } + return conn; +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.h new file mode 100644 index 0000000000000..4b74464d97ba6 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_connection.h @@ -0,0 +1,127 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_TRACING_CONNECTION_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_TRACING_CONNECTION_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include "google/cloud/version.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterTracingConnection + : public hypercomputecluster_v1::HypercomputeClusterConnection { + public: + ~HypercomputeClusterTracingConnection() override = default; + + explicit HypercomputeClusterTracingConnection( + std::shared_ptr + child); + + Options options() override { return child_->options(); } + + StreamRange ListClusters( + google::cloud::hypercomputecluster::v1::ListClustersRequest request) + override; + + StatusOr GetCluster( + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> + CreateCluster( + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> + CreateCluster(google::longrunning::Operation const& operation) override; + + future> + UpdateCluster( + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> + UpdateCluster(google::longrunning::Operation const& operation) override; + + future> + DeleteCluster( + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + future> + DeleteCluster(google::longrunning::Operation const& operation) override; + + StreamRange ListLocations( + google::cloud::location::ListLocationsRequest request) override; + + StatusOr GetLocation( + google::cloud::location::GetLocationRequest const& request) override; + + StreamRange ListOperations( + google::longrunning::ListOperationsRequest request) override; + + StatusOr GetOperation( + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + google::longrunning::CancelOperationRequest const& request) override; + + private: + std::shared_ptr child_; +}; + +/** + * Conditionally applies the tracing decorator to the given connection. + * + * The connection is only decorated if tracing is enabled (as determined by the + * connection's options). + */ +std::shared_ptr +MakeHypercomputeClusterTracingConnection( + std::shared_ptr + conn); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_TRACING_CONNECTION_H diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.cc b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.cc new file mode 100644 index 0000000000000..044ea34db6075 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.cc @@ -0,0 +1,265 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.h" +#include "google/cloud/internal/grpc_opentelemetry.h" +#include +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +HypercomputeClusterTracingStub::HypercomputeClusterTracingStub( + std::shared_ptr child) + : child_(std::move(child)), propagator_(internal::MakePropagator()) {} + +StatusOr +HypercomputeClusterTracingStub::ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "ListClusters"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListClusters(context, options, request)); +} + +StatusOr +HypercomputeClusterTracingStub::GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", "GetCluster"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->GetCluster(context, options, request)); +} + +future> +HypercomputeClusterTracingStub::AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "CreateCluster"); + internal::OTelScope scope(span); + internal::InjectTraceContext(*context, *propagator_); + auto f = child_->AsyncCreateCluster(cq, context, std::move(options), request); + return internal::EndSpan(std::move(context), std::move(span), std::move(f)); +} + +StatusOr +HypercomputeClusterTracingStub::CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "CreateCluster"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->CreateCluster(context, options, request)); +} + +future> +HypercomputeClusterTracingStub::AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "UpdateCluster"); + internal::OTelScope scope(span); + internal::InjectTraceContext(*context, *propagator_); + auto f = child_->AsyncUpdateCluster(cq, context, std::move(options), request); + return internal::EndSpan(std::move(context), std::move(span), std::move(f)); +} + +StatusOr +HypercomputeClusterTracingStub::UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "UpdateCluster"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->UpdateCluster(context, options, request)); +} + +future> +HypercomputeClusterTracingStub::AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "DeleteCluster"); + internal::OTelScope scope(span); + internal::InjectTraceContext(*context, *propagator_); + auto f = child_->AsyncDeleteCluster(cq, context, std::move(options), request); + return internal::EndSpan(std::move(context), std::move(span), std::move(f)); +} + +StatusOr +HypercomputeClusterTracingStub::DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "DeleteCluster"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->DeleteCluster(context, options, request)); +} + +StatusOr +HypercomputeClusterTracingStub::ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "ListLocations"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListLocations(context, options, request)); +} + +StatusOr +HypercomputeClusterTracingStub::GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", "GetLocation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->GetLocation(context, options, request)); +} + +StatusOr +HypercomputeClusterTracingStub::ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "ListOperations"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListOperations(context, options, request)); +} + +StatusOr +HypercomputeClusterTracingStub::GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "GetOperation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->GetOperation(context, options, request)); +} + +Status HypercomputeClusterTracingStub::DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "DeleteOperation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->DeleteOperation(context, options, request)); +} + +Status HypercomputeClusterTracingStub::CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.hypercomputecluster.v1.HypercomputeCluster", + "CancelOperation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->CancelOperation(context, options, request)); +} + +future> +HypercomputeClusterTracingStub::AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) { + auto span = + internal::MakeSpanGrpc("google.longrunning.Operations", "GetOperation"); + internal::OTelScope scope(span); + internal::InjectTraceContext(*context, *propagator_); + auto f = child_->AsyncGetOperation(cq, context, std::move(options), request); + return internal::EndSpan(std::move(context), std::move(span), std::move(f)); +} + +future HypercomputeClusterTracingStub::AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) { + auto span = internal::MakeSpanGrpc("google.longrunning.Operations", + "CancelOperation"); + internal::OTelScope scope(span); + internal::InjectTraceContext(*context, *propagator_); + auto f = + child_->AsyncCancelOperation(cq, context, std::move(options), request); + return internal::EndSpan(std::move(context), std::move(span), std::move(f)); +} + +std::shared_ptr MakeHypercomputeClusterTracingStub( + std::shared_ptr stub) { + return std::make_shared(std::move(stub)); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" diff --git a/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.h b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.h new file mode 100644 index 0000000000000..5b5d33ef585d9 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_tracing_stub.h @@ -0,0 +1,148 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_TRACING_STUB_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_TRACING_STUB_H + +#include "google/cloud/hypercomputecluster/v1/internal/hypercompute_cluster_stub.h" +#include "google/cloud/internal/trace_propagator.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include + +// Must be included last. +#include "google/cloud/ports_def.inc" + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class HypercomputeClusterTracingStub : public HypercomputeClusterStub { + public: + ~HypercomputeClusterTracingStub() override = default; + + explicit HypercomputeClusterTracingStub( + std::shared_ptr child); + + StatusOr + ListClusters( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::ListClustersRequest const& + request) override; + + StatusOr GetCluster( + grpc::ClientContext& context, Options const& options, + google::cloud::hypercomputecluster::v1::GetClusterRequest const& request) + override; + + future> AsyncCreateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + StatusOr CreateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request) override; + + future> AsyncUpdateCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + StatusOr UpdateCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request) override; + + future> AsyncDeleteCluster( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr DeleteCluster( + grpc::ClientContext& context, Options options, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request) override; + + StatusOr ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) override; + + StatusOr GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) override; + + StatusOr ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) override; + + StatusOr GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) override; + + Status DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) override; + + Status CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) override; + + future> AsyncGetOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::GetOperationRequest const& request) override; + + future AsyncCancelOperation( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::longrunning::CancelOperationRequest const& request) override; + + private: + std::shared_ptr child_; + std::shared_ptr + propagator_; +}; + +/** + * Applies the tracing decorator to the given stub. + * + * The stub is only decorated if the library has been compiled with + * OpenTelemetry. + */ +std::shared_ptr MakeHypercomputeClusterTracingStub( + std::shared_ptr stub); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_internal +} // namespace cloud +} // namespace google + +#include "google/cloud/ports_undef.inc" + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_INTERNAL_HYPERCOMPUTE_CLUSTER_TRACING_STUB_H diff --git a/google/cloud/hypercomputecluster/v1/mocks/mock_hypercompute_cluster_connection.h b/google/cloud/hypercomputecluster/v1/mocks/mock_hypercompute_cluster_connection.h new file mode 100644 index 0000000000000..05274f6b34775 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/mocks/mock_hypercompute_cluster_connection.h @@ -0,0 +1,217 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_MOCKS_MOCK_HYPERCOMPUTE_CLUSTER_CONNECTION_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_MOCKS_MOCK_HYPERCOMPUTE_CLUSTER_CONNECTION_H + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection.h" +#include + +namespace google { +namespace cloud { +namespace hypercomputecluster_v1_mocks { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/** + * A class to mock `HypercomputeClusterConnection`. + * + * Application developers may want to test their code with simulated responses, + * including errors, from an object of type `HypercomputeClusterClient`. To do + * so, construct an object of type `HypercomputeClusterClient` with an instance + * of this class. Then use the Google Test framework functions to program the + * behavior of this mock. + * + * @see [This example][bq-mock] for how to test your application with GoogleTest. + * While the example showcases types from the BigQuery library, the underlying + * principles apply for any pair of `*Client` and `*Connection`. + * + * [bq-mock]: @cloud_cpp_docs_link{bigquery,bigquery-read-mock} + */ +class MockHypercomputeClusterConnection + : public hypercomputecluster_v1::HypercomputeClusterConnection { + public: + MOCK_METHOD(Options, options, (), (override)); + + MOCK_METHOD( + (StreamRange), + ListClusters, + (google::cloud::hypercomputecluster::v1::ListClustersRequest request), + (override)); + + MOCK_METHOD(StatusOr, + GetCluster, + (google::cloud::hypercomputecluster::v1::GetClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, + /// CreateCluster(Matcher(_))) + /// @endcode + MOCK_METHOD( + future>, + CreateCluster, + (google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// EXPECT_CALL(*mock, CreateCluster(_, _)) + /// @endcode + MOCK_METHOD( + StatusOr, CreateCluster, + (NoAwaitTag, + google::cloud::hypercomputecluster::v1::CreateClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, CreateCluster(Matcher(_))) + /// @endcode + MOCK_METHOD(future>, + CreateCluster, (google::longrunning::Operation const& operation), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, + /// UpdateCluster(Matcher(_))) + /// @endcode + MOCK_METHOD( + future>, + UpdateCluster, + (google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// EXPECT_CALL(*mock, UpdateCluster(_, _)) + /// @endcode + MOCK_METHOD( + StatusOr, UpdateCluster, + (NoAwaitTag, + google::cloud::hypercomputecluster::v1::UpdateClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, UpdateCluster(Matcher(_))) + /// @endcode + MOCK_METHOD(future>, + UpdateCluster, (google::longrunning::Operation const& operation), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, + /// DeleteCluster(Matcher(_))) + /// @endcode + MOCK_METHOD( + future< + StatusOr>, + DeleteCluster, + (google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// EXPECT_CALL(*mock, DeleteCluster(_, _)) + /// @endcode + MOCK_METHOD( + StatusOr, DeleteCluster, + (NoAwaitTag, + google::cloud::hypercomputecluster::v1::DeleteClusterRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, DeleteCluster(Matcher(_))) + /// @endcode + MOCK_METHOD( + future< + StatusOr>, + DeleteCluster, (google::longrunning::Operation const& operation), + (override)); + + MOCK_METHOD((StreamRange), ListLocations, + (google::cloud::location::ListLocationsRequest request), + (override)); + + MOCK_METHOD(StatusOr, GetLocation, + (google::cloud::location::GetLocationRequest const& request), + (override)); + + MOCK_METHOD((StreamRange), ListOperations, + (google::longrunning::ListOperationsRequest request), (override)); + + MOCK_METHOD(StatusOr, GetOperation, + (google::longrunning::GetOperationRequest const& request), + (override)); + + MOCK_METHOD(Status, DeleteOperation, + (google::longrunning::DeleteOperationRequest const& request), + (override)); + + MOCK_METHOD(Status, CancelOperation, + (google::longrunning::CancelOperationRequest const& request), + (override)); +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace hypercomputecluster_v1_mocks +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_HYPERCOMPUTECLUSTER_V1_MOCKS_MOCK_HYPERCOMPUTE_CLUSTER_CONNECTION_H diff --git a/google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc b/google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc new file mode 100644 index 0000000000000..8cb77d2aea551 --- /dev/null +++ b/google/cloud/hypercomputecluster/v1/samples/hypercompute_cluster_client_samples.cc @@ -0,0 +1,242 @@ +// Copyright 2026 Google LLC +// +// 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 +// +// https://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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/hypercomputecluster/v1/hypercompute_cluster.proto + +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_client.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_connection_idempotency_policy.h" +#include "google/cloud/hypercomputecluster/v1/hypercompute_cluster_options.h" +#include "google/cloud/common_options.h" +#include "google/cloud/credentials.h" +#include "google/cloud/internal/getenv.h" +#include "google/cloud/polling_policy.h" +#include "google/cloud/testing_util/example_driver.h" +#include "google/cloud/universe_domain.h" +#include +#include +#include +#include + +// clang-format off +// main-dox-marker: hypercomputecluster_v1::HypercomputeClusterClient +// lro-marker: true +// clang-format on +namespace { + +void SetClientEndpoint(std::vector const& argv) { + if (!argv.empty()) { + throw google::cloud::testing_util::Usage{"set-client-endpoint"}; + } + //! [set-client-endpoint] + // This configuration is common with Private Google Access: + // https://cloud.google.com/vpc/docs/private-google-access + auto options = google::cloud::Options{}.set( + "private.googleapis.com"); + auto vpc_client = + google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + google::cloud::hypercomputecluster_v1:: + MakeHypercomputeClusterConnection(options)); + //! [set-client-endpoint] +} + +void SetClientUniverseDomain(std::vector const& argv) { + if (!argv.empty()) { + throw google::cloud::testing_util::Usage{"set-client-universe-domain"}; + } + //! [set-client-universe-domain] + google::cloud::Options options; + + // AddUniverseDomainOption interrogates the UnifiedCredentialsOption, if set, + // in the provided Options for the Universe Domain associated with the + // credentials and adds it to the set of Options. + // If no UnifiedCredentialsOption is set, GoogleDefaultCredentials are used. + auto ud_options = google::cloud::AddUniverseDomainOption(std::move(options)); + + if (!ud_options.ok()) throw std::move(ud_options).status(); + auto ud_client = + google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + google::cloud::hypercomputecluster_v1:: + MakeHypercomputeClusterConnection(*ud_options)); + //! [set-client-universe-domain] +} + +//! [custom-idempotency-policy] +class CustomIdempotencyPolicy + : public google::cloud::hypercomputecluster_v1:: + HypercomputeClusterConnectionIdempotencyPolicy { + public: + ~CustomIdempotencyPolicy() override = default; + std::unique_ptr + clone() const override { + return std::make_unique(*this); + } + // Override inherited functions to define as needed. +}; +//! [custom-idempotency-policy] + +void SetRetryPolicy(std::vector const& argv) { + if (!argv.empty()) { + throw google::cloud::testing_util::Usage{"set-client-retry-policy"}; + } + //! [set-retry-policy] + auto options = + google::cloud::Options{} + .set( + CustomIdempotencyPolicy().clone()) + .set( + google::cloud::hypercomputecluster_v1:: + HypercomputeClusterLimitedErrorCountRetryPolicy(3) + .clone()) + .set( + google::cloud::ExponentialBackoffPolicy( + /*initial_delay=*/std::chrono::milliseconds(200), + /*maximum_delay=*/std::chrono::seconds(45), + /*scaling=*/2.0) + .clone()); + auto connection = + google::cloud::hypercomputecluster_v1::MakeHypercomputeClusterConnection( + options); + + // c1 and c2 share the same retry policies + auto c1 = google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + connection); + auto c2 = google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + connection); + + // You can override any of the policies in a new client. This new client + // will share the policies from c1 (or c2) *except* for the retry policy. + auto c3 = google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + connection, google::cloud::Options{} + .set( + google::cloud::hypercomputecluster_v1:: + HypercomputeClusterLimitedTimeRetryPolicy( + std::chrono::minutes(5)) + .clone())); + + // You can also override the policies in a single call: + // c3.SomeRpc(..., google::cloud::Options{} + // .set( + // google::cloud::hypercomputecluster_v1::HypercomputeClusterLimitedErrorCountRetryPolicy(10).clone())); + //! [set-retry-policy] +} + +void SetPollingPolicy(std::vector const& argv) { + if (!argv.empty()) { + throw google::cloud::testing_util::Usage{"set-client-policy-policy"}; + } + //! [set-polling-policy] + + // The polling policy controls how the client waits for long-running + // operations. `GenericPollingPolicy<>` combines existing policies. + // In this case, keep polling until the operation completes (with success + // or error) or 45 minutes, whichever happens first. Initially pause for + // 10 seconds between polling requests, increasing the pause by a factor + // of 4 until it becomes 2 minutes. + auto options = + google::cloud::Options{} + .set( + google::cloud::GenericPollingPolicy< + google::cloud::hypercomputecluster_v1:: + HypercomputeClusterRetryPolicyOption::Type, + google::cloud::hypercomputecluster_v1:: + HypercomputeClusterBackoffPolicyOption::Type>( + google::cloud::hypercomputecluster_v1:: + HypercomputeClusterLimitedTimeRetryPolicy( + /*maximum_duration=*/std::chrono::minutes(45)) + .clone(), + google::cloud::ExponentialBackoffPolicy( + /*initial_delay=*/std::chrono::seconds(10), + /*maximum_delay=*/std::chrono::minutes(2), + /*scaling=*/4.0) + .clone()) + .clone()); + + auto connection = + google::cloud::hypercomputecluster_v1::MakeHypercomputeClusterConnection( + options); + + // c1 and c2 share the same polling policies. + auto c1 = google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + connection); + auto c2 = google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + connection); + //! [set-polling-policy] +} + +void WithServiceAccount(std::vector const& argv) { + if (argv.size() != 1 || argv[0] == "--help") { + throw google::cloud::testing_util::Usage{"with-service-account "}; + } + //! [with-service-account] + [](std::string const& keyfile) { + auto is = std::ifstream(keyfile); + is.exceptions(std::ios::badbit); // Minimal error handling in examples + auto contents = std::string(std::istreambuf_iterator(is.rdbuf()), {}); + auto options = + google::cloud::Options{}.set( + google::cloud::MakeServiceAccountCredentials(contents)); + return google::cloud::hypercomputecluster_v1::HypercomputeClusterClient( + google::cloud::hypercomputecluster_v1:: + MakeHypercomputeClusterConnection(options)); + } + //! [with-service-account] + (argv.at(0)); +} + +void AutoRun(std::vector const& argv) { + namespace examples = ::google::cloud::testing_util; + using ::google::cloud::internal::GetEnv; + if (!argv.empty()) throw examples::Usage{"auto"}; + examples::CheckEnvironmentVariablesAreSet( + {"GOOGLE_CLOUD_CPP_TEST_SERVICE_ACCOUNT_KEYFILE"}); + auto const keyfile = + GetEnv("GOOGLE_CLOUD_CPP_TEST_SERVICE_ACCOUNT_KEYFILE").value(); + + std::cout << "\nRunning SetClientEndpoint() example" << std::endl; + SetClientEndpoint({}); + + std::cout << "\nRunning SetRetryPolicy() example" << std::endl; + SetRetryPolicy({}); + + std::cout << "\nRunning SetPollingPolicy() example" << std::endl; + SetPollingPolicy({}); + + std::cout << "\nRunning WithServiceAccount() example" << std::endl; + WithServiceAccount({keyfile}); + + std::cout << "\nRunning SetClientUniverseDomain() example" << std::endl; + SetClientUniverseDomain({}); +} + +} // namespace + +int main(int argc, char* argv[]) { // NOLINT(bugprone-exception-escape) + google::cloud::testing_util::Example example({ + {"set-client-endpoint", SetClientEndpoint}, + {"set-retry-policy", SetRetryPolicy}, + {"set-polling-policy", SetPollingPolicy}, + {"with-service-account", WithServiceAccount}, + {"set-client-universe-domain", SetClientUniverseDomain}, + {"auto", AutoRun}, + }); + return example.Run(argc, argv); +} diff --git a/libraries.bzl b/libraries.bzl index 9b2056800800f..1a895a0f78464 100644 --- a/libraries.bzl +++ b/libraries.bzl @@ -174,6 +174,7 @@ GOOGLE_CLOUD_CPP_GA_LIBRARIES = [ "gkehub", "gkemulticloud", "gkerecommender", + "hypercomputecluster", "iam", "iap", "ids",