diff --git a/CHANGELOG.md b/CHANGELOG.md index 3211acc33aa39..439bd6ae9f79f 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -6,6 +6,13 @@ breaking changes in the upcoming 3.x release. This release is scheduled for ## v2.47.0 - TBD +### New Libraries + +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. + +- [Audit Manager](/google/cloud/auditmanager/README.md) + ## v2.46.0 - 2026-01 ### [Spanner](/google/cloud/spanner/README.md) diff --git a/README.md b/README.md index 9914634f5fcb0..ea1c3306c7adb 100644 --- a/README.md +++ b/README.md @@ -134,6 +134,9 @@ See each library's `README.md` file for more information about: - [Assured Workloads API](google/cloud/assuredworkloads/README.md) [[quickstart]](google/cloud/assuredworkloads/quickstart/README.md) [[reference]](https://cloud.google.com/cpp/docs/reference/assuredworkloads/latest) +- [Audit Manager API](google/cloud/auditmanager/README.md) + [[quickstart]](google/cloud/auditmanager/quickstart/README.md) + [[reference]](https://cloud.google.com/cpp/docs/reference/auditmanager/latest) - [Cloud AutoML API](google/cloud/automl/README.md) [[quickstart]](google/cloud/automl/quickstart/README.md) [[reference]](https://cloud.google.com/cpp/docs/reference/automl/latest) diff --git a/ci/abi-dumps/google_cloud_cpp_auditmanager.expected.abi.dump.gz b/ci/abi-dumps/google_cloud_cpp_auditmanager.expected.abi.dump.gz new file mode 100644 index 0000000000000..983229c836c22 Binary files /dev/null and b/ci/abi-dumps/google_cloud_cpp_auditmanager.expected.abi.dump.gz differ diff --git a/ci/etc/expected_install_directories b/ci/etc/expected_install_directories index 7fa97fa28ce97..db0af4607fbd5 100644 --- a/ci/etc/expected_install_directories +++ b/ci/etc/expected_install_directories @@ -81,6 +81,10 @@ ./include/google/cloud/assuredworkloads/v1 ./include/google/cloud/assuredworkloads/v1/internal ./include/google/cloud/assuredworkloads/v1/mocks +./include/google/cloud/auditmanager +./include/google/cloud/auditmanager/v1 +./include/google/cloud/auditmanager/v1/internal +./include/google/cloud/auditmanager/v1/mocks ./include/google/cloud/automl ./include/google/cloud/automl/mocks ./include/google/cloud/automl/v1 @@ -1369,6 +1373,8 @@ ./lib64/cmake/google_cloud_cpp_asset_mocks ./lib64/cmake/google_cloud_cpp_assuredworkloads ./lib64/cmake/google_cloud_cpp_assuredworkloads_mocks +./lib64/cmake/google_cloud_cpp_auditmanager +./lib64/cmake/google_cloud_cpp_auditmanager_mocks ./lib64/cmake/google_cloud_cpp_automl ./lib64/cmake/google_cloud_cpp_automl_mocks ./lib64/cmake/google_cloud_cpp_backupdr diff --git a/cmake/GoogleCloudCppFeatures.cmake b/cmake/GoogleCloudCppFeatures.cmake index c674626b65a70..af722274e0592 100644 --- a/cmake/GoogleCloudCppFeatures.cmake +++ b/cmake/GoogleCloudCppFeatures.cmake @@ -54,6 +54,7 @@ set(GOOGLE_CLOUD_CPP_GA_LIBRARIES "artifactregistry" "asset" "assuredworkloads" + "auditmanager" "automl" "backupdr" "baremetalsolution" diff --git a/external/googleapis/protodeps/auditmanager.deps b/external/googleapis/protodeps/auditmanager.deps new file mode 100644 index 0000000000000..6ef8f9ccdeb73 --- /dev/null +++ b/external/googleapis/protodeps/auditmanager.deps @@ -0,0 +1,8 @@ +@com_google_googleapis//google/api:annotations_proto +@com_google_googleapis//google/api:client_proto +@com_google_googleapis//google/api:field_behavior_proto +@com_google_googleapis//google/api:http_proto +@com_google_googleapis//google/api:launch_stage_proto +@com_google_googleapis//google/api:resource_proto +@com_google_googleapis//google/longrunning:operations_proto +@com_google_googleapis//google/rpc:status_proto diff --git a/external/googleapis/protolists/auditmanager.list b/external/googleapis/protolists/auditmanager.list new file mode 100644 index 0000000000000..b3b99d045599d --- /dev/null +++ b/external/googleapis/protolists/auditmanager.list @@ -0,0 +1 @@ +@com_google_googleapis//google/cloud/auditmanager/v1:auditmanager.proto diff --git a/external/googleapis/update_libraries.sh b/external/googleapis/update_libraries.sh index 7efb27865b864..7019a0b6006d6 100755 --- a/external/googleapis/update_libraries.sh +++ b/external/googleapis/update_libraries.sh @@ -46,6 +46,7 @@ declare -A -r LIBRARIES=( ["artifactregistry"]="@com_google_googleapis//google/devtools/artifactregistry/v1:artifactregistry_cc_grpc" ["asset"]="@com_google_googleapis//google/cloud/asset/v1:asset_cc_grpc" ["assuredworkloads"]="@com_google_googleapis//google/cloud/assuredworkloads/v1:assuredworkloads_cc_grpc" + ["auditmanager"]="@com_google_googleapis//google/cloud/auditmanager/v1:auditmanager_cc_grpc" ["automl"]="@com_google_googleapis//google/cloud/automl/v1:automl_cc_grpc" ["backupdr"]="$( printf ",%s" \ diff --git a/generator/generator_config.textproto b/generator/generator_config.textproto index bbbbfb69b3161..c4ec62136ff3e 100644 --- a/generator/generator_config.textproto +++ b/generator/generator_config.textproto @@ -340,6 +340,14 @@ service { retryable_status_codes: ["kUnavailable"] } +# Audit Manager +service { + service_proto_path: "google/cloud/auditmanager/v1/auditmanager.proto" + product_path: "google/cloud/auditmanager/v1" + initial_copyright_year: "2026" + retryable_status_codes: ["kUnavailable"] +} + # Auto ML service { service_proto_path: "google/cloud/automl/v1/service.proto" diff --git a/google/cloud/auditmanager/BUILD.bazel b/google/cloud/auditmanager/BUILD.bazel new file mode 100644 index 0000000000000..63115f5c8cc93 --- /dev/null +++ b/google/cloud/auditmanager/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 = [ + "@com_google_googleapis//google/cloud/auditmanager/v1:auditmanager_cc_grpc", +] + +cc_gapic_library( + name = "auditmanager", + googleapis_deps = googleapis_deps, + service_dirs = service_dirs, +) diff --git a/google/cloud/auditmanager/CMakeLists.txt b/google/cloud/auditmanager/CMakeLists.txt new file mode 100644 index 0000000000000..271b71935e099 --- /dev/null +++ b/google/cloud/auditmanager/CMakeLists.txt @@ -0,0 +1,38 @@ +# ~~~ +# 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(auditmanager "Audit Manager API" + SERVICE_DIRS "v1/") + +if (BUILD_TESTING AND GOOGLE_CLOUD_CPP_ENABLE_CXX_EXCEPTIONS) + add_executable(auditmanager_quickstart "quickstart/quickstart.cc") + target_link_libraries(auditmanager_quickstart + PRIVATE google-cloud-cpp::auditmanager) + google_cloud_cpp_add_common_options(auditmanager_quickstart) + add_test( + NAME auditmanager_quickstart + COMMAND + cmake -P "${PROJECT_SOURCE_DIR}/cmake/quickstart-runner.cmake" + $ GOOGLE_CLOUD_PROJECT + GOOGLE_CLOUD_CPP_TEST_REGION) + set_tests_properties( + auditmanager_quickstart + PROPERTIES LABELS "integration-test;quickstart" PASS_REGULAR_EXPRESSION + "Permanent error.*gcloud-cpp.retry.function=ListAuditReports" + ) +endif () diff --git a/google/cloud/auditmanager/README.md b/google/cloud/auditmanager/README.md new file mode 100644 index 0000000000000..0c6b63625d35a --- /dev/null +++ b/google/cloud/auditmanager/README.md @@ -0,0 +1,59 @@ +# Audit Manager API C++ Client Library + +This directory contains an idiomatic C++ client library for the +[Audit Manager API][cloud-service-docs]. + +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/auditmanager/v1/audit_manager_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 auditmanager = ::google::cloud::auditmanager_v1; + auto client = auditmanager::AuditManagerClient( + auditmanager::MakeAuditManagerConnection()); + + for (auto r : client.ListAuditReports(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 [Audit Manager 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/audit-manager/docs +[doxygen-link]: https://cloud.google.com/cpp/docs/reference/auditmanager/latest/ +[source-link]: https://github.com/googleapis/google-cloud-cpp/tree/main/google/cloud/auditmanager diff --git a/google/cloud/auditmanager/doc/environment-variables.dox b/google/cloud/auditmanager/doc/environment-variables.dox new file mode 100644 index 0000000000000..6f2d70a765d4a --- /dev/null +++ b/google/cloud/auditmanager/doc/environment-variables.dox @@ -0,0 +1,49 @@ +/*! +@page auditmanager-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 auditmanager-env-endpoint Endpoint Overrides + + + +- `GOOGLE_CLOUD_CPP_AUDIT_MANAGER_ENDPOINT=...` overrides the + `EndpointOption` (which defaults to "auditmanager.googleapis.com") + used by `MakeAuditManagerConnection()`. + + + +@see google::cloud::EndpointOption + +@section auditmanager-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 auditmanager-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/auditmanager/doc/main.dox b/google/cloud/auditmanager/doc/main.dox new file mode 100644 index 0000000000000..1c27a34625268 --- /dev/null +++ b/google/cloud/auditmanager/doc/main.dox @@ -0,0 +1,48 @@ +/*! + +@mainpage Audit Manager API C++ Client Library + +An idiomatic C++ client library for the [Audit Manager API][cloud-service-docs]. + + + +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/auditmanager/quickstart/` directory, +which should give you a taste of the Audit Manager API C++ client library API. + +@snippet quickstart.cc all + +## Main classes + + +The main class in this library is +[`auditmanager_v1::AuditManagerClient`](@ref google::cloud::auditmanager_v1::AuditManagerClient). All RPCs are exposed +as member functions of this class. Other classes provide helpers, configuration +parameters, and infrastructure to mock +[`auditmanager_v1::AuditManagerClient`](@ref google::cloud::auditmanager_v1::AuditManagerClient) when testing your +application. + + +## More Information + +- @ref common-error-handling - describes how the library reports errors. +- @ref auditmanager-override-endpoint - describes how to override the default + endpoint. +- @ref auditmanager-override-authentication - describes how to change the + authentication credentials used by the library. +- @ref auditmanager-override-retry - describes how to change the default retry + policies. +- @ref auditmanager-env - describes environment variables that can configure the + behavior of the library. +- @ref auditmanager-override-universe-domain - describes how to override the default universe domain. + +[cloud-service-docs]: https://cloud.google.com/audit-manager/docs + +*/ diff --git a/google/cloud/auditmanager/doc/options.dox b/google/cloud/auditmanager/doc/options.dox new file mode 100644 index 0000000000000..8ede0dd7d4208 --- /dev/null +++ b/google/cloud/auditmanager/doc/options.dox @@ -0,0 +1,10 @@ +/*! +@defgroup google-cloud-auditmanager-options Audit Manager 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/auditmanager/doc/override-authentication.dox b/google/cloud/auditmanager/doc/override-authentication.dox new file mode 100644 index 0000000000000..43caf1ffa6f35 --- /dev/null +++ b/google/cloud/auditmanager/doc/override-authentication.dox @@ -0,0 +1,35 @@ +/*! +@page auditmanager-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 audit_manager_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 auditmanager_v1::AuditManagerClient-service-account-snippet Override auditmanager_v1::AuditManagerClient Authentication Defaults + +@snippet google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc with-service-account + +*/ +// diff --git a/google/cloud/auditmanager/doc/override-endpoint.dox b/google/cloud/auditmanager/doc/override-endpoint.dox new file mode 100644 index 0000000000000..ba3081291c711 --- /dev/null +++ b/google/cloud/auditmanager/doc/override-endpoint.dox @@ -0,0 +1,25 @@ +/*! +@page auditmanager-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 `auditmanager_v1::AuditManagerClient`: + +@snippet audit_manager_client_samples.cc set-client-endpoint + + + +*/ + +// + +/*! @page auditmanager_v1::AuditManagerClient-endpoint-snippet Override auditmanager_v1::AuditManagerClient Endpoint Configuration + +@snippet google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc set-client-endpoint + +*/ +// diff --git a/google/cloud/auditmanager/doc/override-retry-policies.dox b/google/cloud/auditmanager/doc/override-retry-policies.dox new file mode 100644 index 0000000000000..a94711d387932 --- /dev/null +++ b/google/cloud/auditmanager/doc/override-retry-policies.dox @@ -0,0 +1,108 @@ +/*! +@page auditmanager-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 auditmanager-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 auditmanager-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 auditmanager-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 auditmanager-override-retry-example Example + + +For example, this will override the retry policies for `auditmanager_v1::AuditManagerClient`: + +@snippet audit_manager_client_samples.cc set-retry-policy + +This assumes you have created a custom idempotency policy. Such as: + +@snippet audit_manager_client_samples.cc custom-idempotency-policy + +This will override the polling policies for `auditmanager_v1::AuditManagerClient` + +@snippet audit_manager_client_samples.cc set-polling-policy + + + + +@section auditmanager-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 auditmanager_v1::AuditManagerClient-retry-snippet Override auditmanager_v1::AuditManagerClient Retry Policies + +This shows how to override the retry policies for auditmanager_v1::AuditManagerClient: + +@snippet google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc set-retry-policy + +Assuming you have created a custom idempotency policy. Such as: + +@snippet google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc custom-idempotency-policy + +*/ +// diff --git a/google/cloud/auditmanager/doc/override-universe-domain.dox b/google/cloud/auditmanager/doc/override-universe-domain.dox new file mode 100644 index 0000000000000..478bdd40b237b --- /dev/null +++ b/google/cloud/auditmanager/doc/override-universe-domain.dox @@ -0,0 +1,24 @@ +/*! +@page auditmanager-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 `auditmanager_v1::AuditManagerClient`: + +@snippet audit_manager_client_samples.cc set-client-universe-domain + + + +*/ + +// + +/*! @page auditmanager_v1::AuditManagerClient-universe-domain-snippet Override auditmanager_v1::AuditManagerClient Universe Domain + +@snippet google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc set-client-universe-domain + +*/ +// diff --git a/google/cloud/auditmanager/quickstart/.bazelrc b/google/cloud/auditmanager/quickstart/.bazelrc new file mode 100644 index 0000000000000..c884db46c2b4d --- /dev/null +++ b/google/cloud/auditmanager/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/auditmanager/quickstart/BUILD.bazel b/google/cloud/auditmanager/quickstart/BUILD.bazel new file mode 100644 index 0000000000000..fa783bddf477e --- /dev/null +++ b/google/cloud/auditmanager/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//:auditmanager", + ], +) diff --git a/google/cloud/auditmanager/quickstart/CMakeLists.txt b/google/cloud/auditmanager/quickstart/CMakeLists.txt new file mode 100644 index 0000000000000..bf27dc65fedc1 --- /dev/null +++ b/google/cloud/auditmanager/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 Audit Manager API C++ client library from a +# larger CMake project. + +cmake_minimum_required(VERSION 3.10...3.24) +project(google-cloud-cpp-auditmanager-quickstart CXX) + +find_package(google_cloud_cpp_auditmanager 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::auditmanager) diff --git a/google/cloud/auditmanager/quickstart/Makefile b/google/cloud/auditmanager/quickstart/Makefile new file mode 100644 index 0000000000000..2e9118ba54408 --- /dev/null +++ b/google/cloud/auditmanager/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 Audit Manager 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 Audit Manager API C++ +# client library. +CLIENT_MODULE := google_cloud_cpp_auditmanager +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/auditmanager/quickstart/README.md b/google/cloud/auditmanager/quickstart/README.md new file mode 100644 index 0000000000000..bce25d901d715 --- /dev/null +++ b/google/cloud/auditmanager/quickstart/README.md @@ -0,0 +1,135 @@ +# HOWTO: using the Audit Manager API C++ client in your project + +This directory contains small examples showing how to use the Audit Manager 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, Audit Manager 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/auditmanager/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,auditmanager] + ``` + + 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/auditmanager/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/auditmanager/quickstart/WORKSPACE.bazel b/google/cloud/auditmanager/quickstart/WORKSPACE.bazel new file mode 100644 index 0000000000000..98926f7ab16a7 --- /dev/null +++ b/google/cloud/auditmanager/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 Audit Manager 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/auditmanager/quickstart/quickstart.cc b/google/cloud/auditmanager/quickstart/quickstart.cc new file mode 100644 index 0000000000000..f370c15ce9d8d --- /dev/null +++ b/google/cloud/auditmanager/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/auditmanager/v1/audit_manager_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 auditmanager = ::google::cloud::auditmanager_v1; + auto client = auditmanager::AuditManagerClient( + auditmanager::MakeAuditManagerConnection()); + + for (auto r : client.ListAuditReports(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/auditmanager/v1/.repo-metadata.json b/google/cloud/auditmanager/v1/.repo-metadata.json new file mode 100644 index 0000000000000..6e1467ae83cb2 --- /dev/null +++ b/google/cloud/auditmanager/v1/.repo-metadata.json @@ -0,0 +1,14 @@ +{ + "api_id": "auditmanager.googleapis.com", + "api_shortname": "auditmanager", + "client_documentation": "https://cloud.google.com/cpp/docs/reference/auditmanager/latest", + "distribution_name": "google-cloud-cpp", + "issue_tracker": "https://issuetracker.google.com/issues?q=componentid:1335397%20status=open", + "language": "cpp", + "library_type": "GAPIC_AUTO", + "name_pretty": "Audit Manager API", + "product_documentation": "https://cloud.google.com/audit-manager/docs", + "release_level": "stable", + "repo": "googleapis/google-cloud-cpp", + "requires_billing": true +} diff --git a/google/cloud/auditmanager/v1/audit_manager_client.cc b/google/cloud/auditmanager/v1/audit_manager_client.cc new file mode 100644 index 0000000000000..9e689beb6e391 --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_client.cc @@ -0,0 +1,293 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/audit_manager_client.h" +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +AuditManagerClient::AuditManagerClient( + std::shared_ptr connection, Options opts) + : connection_(std::move(connection)), + options_( + internal::MergeOptions(std::move(opts), connection_->options())) {} +AuditManagerClient::~AuditManagerClient() = default; + +StatusOr +AuditManagerClient::EnrollResource( + std::string const& scope, + std::vector const& destinations, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::EnrollResourceRequest request; + request.set_scope(scope); + *request.mutable_destinations() = {destinations.begin(), destinations.end()}; + return connection_->EnrollResource(request); +} + +StatusOr +AuditManagerClient::EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->EnrollResource(request); +} + +StatusOr +AuditManagerClient::GenerateAuditScopeReport( + std::string const& scope, std::string const& compliance_standard, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest:: + AuditScopeReportFormat report_format, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest request; + request.set_scope(scope); + request.set_compliance_standard(compliance_standard); + request.set_report_format(report_format); + return connection_->GenerateAuditScopeReport(request); +} + +StatusOr +AuditManagerClient::GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GenerateAuditScopeReport(request); +} + +future> +AuditManagerClient::GenerateAuditReport( + std::string const& scope, std::string const& gcs_uri, + std::string const& compliance_standard, + google::cloud::auditmanager::v1::GenerateAuditReportRequest:: + AuditReportFormat report_format, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::GenerateAuditReportRequest request; + request.set_scope(scope); + request.set_gcs_uri(gcs_uri); + request.set_compliance_standard(compliance_standard); + request.set_report_format(report_format); + return connection_->GenerateAuditReport(request); +} + +StatusOr +AuditManagerClient::GenerateAuditReport( + NoAwaitTag, std::string const& scope, std::string const& gcs_uri, + std::string const& compliance_standard, + google::cloud::auditmanager::v1::GenerateAuditReportRequest:: + AuditReportFormat report_format, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::GenerateAuditReportRequest request; + request.set_scope(scope); + request.set_gcs_uri(gcs_uri); + request.set_compliance_standard(compliance_standard); + request.set_report_format(report_format); + return connection_->GenerateAuditReport(NoAwaitTag{}, request); +} + +future> +AuditManagerClient::GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GenerateAuditReport(request); +} + +StatusOr +AuditManagerClient::GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GenerateAuditReport(NoAwaitTag{}, request); +} + +future> +AuditManagerClient::GenerateAuditReport( + google::longrunning::Operation const& operation, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GenerateAuditReport(operation); +} + +StreamRange +AuditManagerClient::ListAuditReports(std::string const& parent, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::ListAuditReportsRequest request; + request.set_parent(parent); + return connection_->ListAuditReports(request); +} + +StreamRange +AuditManagerClient::ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListAuditReports(std::move(request)); +} + +StatusOr +AuditManagerClient::GetAuditReport(std::string const& name, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::GetAuditReportRequest request; + request.set_name(name); + return connection_->GetAuditReport(request); +} + +StatusOr +AuditManagerClient::GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetAuditReport(request); +} + +StatusOr +AuditManagerClient::GetResourceEnrollmentStatus(std::string const& name, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest request; + request.set_name(name); + return connection_->GetResourceEnrollmentStatus(request); +} + +StatusOr +AuditManagerClient::GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetResourceEnrollmentStatus(request); +} + +StreamRange +AuditManagerClient::ListResourceEnrollmentStatuses(std::string const& parent, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request; + request.set_parent(parent); + return connection_->ListResourceEnrollmentStatuses(request); +} + +StreamRange +AuditManagerClient::ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListResourceEnrollmentStatuses(std::move(request)); +} + +StreamRange +AuditManagerClient::ListControls(std::string const& parent, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + google::cloud::auditmanager::v1::ListControlsRequest request; + request.set_parent(parent); + return connection_->ListControls(request); +} + +StreamRange +AuditManagerClient::ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request, + Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListControls(std::move(request)); +} + +StreamRange +AuditManagerClient::ListLocations( + google::cloud::location::ListLocationsRequest request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListLocations(std::move(request)); +} + +StatusOr AuditManagerClient::GetLocation( + google::cloud::location::GetLocationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetLocation(request); +} + +StreamRange AuditManagerClient::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 AuditManagerClient::ListOperations( + google::longrunning::ListOperationsRequest request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->ListOperations(std::move(request)); +} + +StatusOr AuditManagerClient::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 AuditManagerClient::GetOperation( + google::longrunning::GetOperationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->GetOperation(request); +} + +Status AuditManagerClient::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 AuditManagerClient::DeleteOperation( + google::longrunning::DeleteOperationRequest const& request, Options opts) { + internal::OptionsSpan span(internal::MergeOptions(std::move(opts), options_)); + return connection_->DeleteOperation(request); +} + +Status AuditManagerClient::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 AuditManagerClient::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 auditmanager_v1 +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/audit_manager_client.h b/google/cloud/auditmanager/v1/audit_manager_client.h new file mode 100644 index 0000000000000..90ae8e707b4b1 --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_client.h @@ -0,0 +1,1069 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CLIENT_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CLIENT_H + +#include "google/cloud/auditmanager/v1/audit_manager_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 +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_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 AuditManagerClient { + public: + explicit AuditManagerClient( + std::shared_ptr connection, Options opts = {}); + ~AuditManagerClient(); + + ///@{ + /// @name Copy and move support + AuditManagerClient(AuditManagerClient const&) = default; + AuditManagerClient& operator=(AuditManagerClient const&) = default; + AuditManagerClient(AuditManagerClient&&) = default; + AuditManagerClient& operator=(AuditManagerClient&&) = default; + ///@} + + ///@{ + /// @name Equality + friend bool operator==(AuditManagerClient const& a, + AuditManagerClient const& b) { + return a.connection_ == b.connection_; + } + friend bool operator!=(AuditManagerClient const& a, + AuditManagerClient const& b) { + return !(a == b); + } + ///@} + + // clang-format off + /// + /// Enrolls the customer resource(folder/project/organization) to the audit + /// manager service by creating the audit managers Service Agent in customers + /// workload and granting required permissions to the Service Agent. Please + /// note that if enrollment request is made on the already enrolled workload + /// then enrollment is executed overriding the existing set of destinations. + /// + /// @param scope Required. The resource to be enrolled to the audit manager. Scope format + /// should be resource_type/resource_identifier Eg: + /// projects/{project}/locations/{location}, + /// folders/{folder}/locations/{location} + /// organizations/{organization}/locations/{location} + /// @param destinations Required. List of destination among which customer can choose to upload + /// their reports during the audit process. While enrolling at a + /// organization/folder level, customer can choose Cloud storage bucket in any + /// project. If the audit is triggered at project level using the service agent + /// at organization/folder level, all the destination options associated with + /// respective organization/folder level service agent will be available to + /// auditing projects. + /// @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.auditmanager.v1.Enrollment]) + /// 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.auditmanager.v1.EnrollResourceRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L239} + /// [google.cloud.auditmanager.v1.Enrollment]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L492} + /// + // clang-format on + StatusOr EnrollResource( + std::string const& scope, + std::vector const& destinations, + Options opts = {}); + + // clang-format off + /// + /// Enrolls the customer resource(folder/project/organization) to the audit + /// manager service by creating the audit managers Service Agent in customers + /// workload and granting required permissions to the Service Agent. Please + /// note that if enrollment request is made on the already enrolled workload + /// then enrollment is executed overriding the existing set of destinations. + /// + /// @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.auditmanager.v1.EnrollResourceRequest]. + /// 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.auditmanager.v1.Enrollment]) + /// 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.auditmanager.v1.EnrollResourceRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L239} + /// [google.cloud.auditmanager.v1.Enrollment]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L492} + /// + // clang-format on + StatusOr EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request, + Options opts = {}); + + // clang-format off + /// + /// Generates a demo report highlighting different responsibilities + /// (Google/Customer/ shared) required to be fulfilled for the customer's + /// workload to be compliant with the given standard. + /// + /// @param scope Required. Scope for which the AuditScopeReport is required. Must be of + /// format resource_type/resource_identifier Eg: + /// projects/{project}/locations/{location}, + /// folders/{folder}/locations/{location} + /// @param compliance_standard Required. Compliance Standard against which the Scope Report must be + /// generated. Eg: FEDRAMP_MODERATE + /// @param report_format Required. The format in which the Scope report bytes should be returned. + /// @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.auditmanager.v1.AuditScopeReport]) + /// 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.auditmanager.v1.AuditScopeReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L512} + /// [google.cloud.auditmanager.v1.GenerateAuditScopeReportRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L269} + /// + // clang-format on + StatusOr + GenerateAuditScopeReport( + std::string const& scope, std::string const& compliance_standard, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest:: + AuditScopeReportFormat report_format, + Options opts = {}); + + // clang-format off + /// + /// Generates a demo report highlighting different responsibilities + /// (Google/Customer/ shared) required to be fulfilled for the customer's + /// workload to be compliant with the given standard. + /// + /// @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.auditmanager.v1.GenerateAuditScopeReportRequest]. + /// 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.auditmanager.v1.AuditScopeReport]) + /// 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.auditmanager.v1.AuditScopeReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L512} + /// [google.cloud.auditmanager.v1.GenerateAuditScopeReportRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L269} + /// + // clang-format on + StatusOr + GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// Register the Audit Report generation requests and returns the OperationId + /// using which the customer can track the report generation progress. + /// + /// @param scope Required. Scope for which the AuditScopeReport is required. Must be of + /// format resource_type/resource_identifier Eg: + /// projects/{project}/locations/{location}, + /// folders/{folder}/locations/{location} + /// @param gcs_uri Destination Cloud storage bucket where report and evidence must be + /// uploaded. The Cloud storage bucket provided here must be selected among + /// the buckets entered during the enrollment process. + /// @param compliance_standard Required. Compliance Standard against which the Scope Report must be + /// generated. Eg: FEDRAMP_MODERATE + /// @param report_format Required. The format in which the audit report should be created. + /// @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.auditmanager.v1.AuditReport] 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.auditmanager.v1.AuditReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L608} + /// [google.cloud.auditmanager.v1.GenerateAuditReportRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L299} + /// + // clang-format on + future> + GenerateAuditReport( + std::string const& scope, std::string const& gcs_uri, + std::string const& compliance_standard, + google::cloud::auditmanager::v1::GenerateAuditReportRequest:: + AuditReportFormat report_format, + Options opts = {}); + + // clang-format off + /// + /// @copybrief GenerateAuditReport + /// + /// 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 GenerateAuditReport( + NoAwaitTag, std::string const& scope, std::string const& gcs_uri, + std::string const& compliance_standard, + google::cloud::auditmanager::v1::GenerateAuditReportRequest:: + AuditReportFormat report_format, + Options opts = {}); + + // clang-format off + /// + /// Register the Audit Report generation requests and returns the OperationId + /// using which the customer can track the report generation progress. + /// + /// @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.auditmanager.v1.GenerateAuditReportRequest]. + /// 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.auditmanager.v1.AuditReport] 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.auditmanager.v1.AuditReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L608} + /// [google.cloud.auditmanager.v1.GenerateAuditReportRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L299} + /// + // clang-format on + future> + GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief GenerateAuditReport + /// + /// 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 GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// @copybrief GenerateAuditReport + /// + /// 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> + GenerateAuditReport(google::longrunning::Operation const& operation, + Options opts = {}); + + // clang-format off + /// + /// Lists audit reports in the selected parent scope + /// + /// @param parent Required. The parent scope for which to list the reports. + /// @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.auditmanager.v1.AuditReport], 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.auditmanager.v1.AuditReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L608} + /// [google.cloud.auditmanager.v1.ListAuditReportsRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L378} + /// + // clang-format on + StreamRange ListAuditReports( + std::string const& parent, Options opts = {}); + + // clang-format off + /// + /// Lists audit reports in the selected parent scope + /// + /// @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.auditmanager.v1.ListAuditReportsRequest]. + /// 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.auditmanager.v1.AuditReport], 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.auditmanager.v1.AuditReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L608} + /// [google.cloud.auditmanager.v1.ListAuditReportsRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L378} + /// + // clang-format on + StreamRange ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request, + Options opts = {}); + + // clang-format off + /// + /// Get the overall audit report + /// + /// @param name Required. Format + /// projects/{project}/locations/{location}/auditReports/{audit_report}, + /// folders/{folder}/locations/{location}/auditReports/{audit_report} + /// @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.auditmanager.v1.AuditReport]) + /// 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.auditmanager.v1.AuditReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L608} + /// [google.cloud.auditmanager.v1.GetAuditReportRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L406} + /// + // clang-format on + StatusOr GetAuditReport( + std::string const& name, Options opts = {}); + + // clang-format off + /// + /// Get the overall audit report + /// + /// @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.auditmanager.v1.GetAuditReportRequest]. + /// 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.auditmanager.v1.AuditReport]) + /// 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.auditmanager.v1.AuditReport]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L608} + /// [google.cloud.auditmanager.v1.GetAuditReportRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L406} + /// + // clang-format on + StatusOr GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request, + Options opts = {}); + + // clang-format off + /// + /// Get a resource along with its enrollment status. + /// + /// @param name Required. Format + /// folders/{folder}/locations/{location}/resourceEnrollmentStatuses/{resource_enrollment_status}, + /// projects/{project}/locations/{location}/resourceEnrollmentStatuses/{resource_enrollment_status}, + /// organizations/{organization}/locations/{location}/resourceEnrollmentStatuses/{resource_enrollment_status} + /// @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.auditmanager.v1.ResourceEnrollmentStatus]) + /// 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.auditmanager.v1.GetResourceEnrollmentStatusRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L335} + /// [google.cloud.auditmanager.v1.ResourceEnrollmentStatus]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L563} + /// + // clang-format on + StatusOr + GetResourceEnrollmentStatus(std::string const& name, Options opts = {}); + + // clang-format off + /// + /// Get a resource along with its enrollment status. + /// + /// @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.auditmanager.v1.GetResourceEnrollmentStatusRequest]. + /// 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.auditmanager.v1.ResourceEnrollmentStatus]) + /// 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.auditmanager.v1.GetResourceEnrollmentStatusRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L335} + /// [google.cloud.auditmanager.v1.ResourceEnrollmentStatus]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L563} + /// + // clang-format on + StatusOr + GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request, + Options opts = {}); + + // clang-format off + /// + /// Fetches all resources under the parent along with their enrollment. + /// + /// @param parent Required. The parent scope for which the list of resources with enrollments + /// are required. + /// @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.auditmanager.v1.ResourceEnrollmentStatus], 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.auditmanager.v1.ListResourceEnrollmentStatusesRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L350} + /// [google.cloud.auditmanager.v1.ResourceEnrollmentStatus]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L563} + /// + // clang-format on + StreamRange + ListResourceEnrollmentStatuses(std::string const& parent, Options opts = {}); + + // clang-format off + /// + /// Fetches all resources under the parent along with their enrollment. + /// + /// @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.auditmanager.v1.ListResourceEnrollmentStatusesRequest]. + /// 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.auditmanager.v1.ResourceEnrollmentStatus], 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.auditmanager.v1.ListResourceEnrollmentStatusesRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L350} + /// [google.cloud.auditmanager.v1.ResourceEnrollmentStatus]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L563} + /// + // clang-format on + StreamRange + ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request, + Options opts = {}); + + // clang-format off + /// + /// Gets controls needed to be implemented to be compliant to a standard. + /// + /// @param parent Required. Format + /// projects/{project}/locations/{location}/standards/{standard}, + /// folders/{folder}/locations/{location}/standards/{standard} + /// @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.auditmanager.v1.Control], 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.auditmanager.v1.Control]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L689} + /// [google.cloud.auditmanager.v1.ListControlsRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L419} + /// + // clang-format on + StreamRange ListControls( + std::string const& parent, Options opts = {}); + + // clang-format off + /// + /// Gets controls needed to be implemented to be compliant to a standard. + /// + /// @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.auditmanager.v1.ListControlsRequest]. + /// 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.auditmanager.v1.Control], 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.auditmanager.v1.Control]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L689} + /// [google.cloud.auditmanager.v1.ListControlsRequest]: @googleapis_reference_link{google/cloud/auditmanager/v1/auditmanager.proto#L419} + /// + // clang-format on + StreamRange ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request, + 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 auditmanager_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CLIENT_H diff --git a/google/cloud/auditmanager/v1/audit_manager_connection.cc b/google/cloud/auditmanager/v1/audit_manager_connection.cc new file mode 100644 index 0000000000000..73b6601be0e20 --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_connection.cc @@ -0,0 +1,170 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/audit_manager_connection.h" +#include "google/cloud/auditmanager/v1/audit_manager_options.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_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 auditmanager_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +AuditManagerConnection::~AuditManagerConnection() = default; + +StatusOr +AuditManagerConnection::EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +StatusOr +AuditManagerConnection::GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +future> +AuditManagerConnection::GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +StatusOr +AuditManagerConnection::GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const&) { + return StatusOr( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +future> +AuditManagerConnection::GenerateAuditReport( + google::longrunning::Operation const&) { + return google::cloud::make_ready_future< + StatusOr>( + Status(StatusCode::kUnimplemented, "not implemented")); +} + +StreamRange +AuditManagerConnection::ListAuditReports( + google::cloud::auditmanager::v1:: + ListAuditReportsRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StatusOr +AuditManagerConnection::GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +StatusOr +AuditManagerConnection::GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1:: + GetResourceEnrollmentStatusRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +StreamRange +AuditManagerConnection::ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StreamRange +AuditManagerConnection::ListControls( + google::cloud::auditmanager::v1:: + ListControlsRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StreamRange +AuditManagerConnection::ListLocations( + google::cloud::location:: + ListLocationsRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StatusOr AuditManagerConnection::GetLocation( + google::cloud::location::GetLocationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +StreamRange +AuditManagerConnection::ListOperations( + google::longrunning:: + ListOperationsRequest) { // NOLINT(performance-unnecessary-value-param) + return google::cloud::internal::MakeUnimplementedPaginationRange< + StreamRange>(); +} + +StatusOr AuditManagerConnection::GetOperation( + google::longrunning::GetOperationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +Status AuditManagerConnection::DeleteOperation( + google::longrunning::DeleteOperationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +Status AuditManagerConnection::CancelOperation( + google::longrunning::CancelOperationRequest const&) { + return Status(StatusCode::kUnimplemented, "not implemented"); +} + +std::shared_ptr MakeAuditManagerConnection( + Options options) { + internal::CheckExpectedOptions(options, + __func__); + options = + auditmanager_v1_internal::AuditManagerDefaultOptions(std::move(options)); + auto background = internal::MakeBackgroundThreadsFactory(options)(); + auto auth = internal::CreateAuthenticationStrategy(background->cq(), options); + auto stub = auditmanager_v1_internal::CreateDefaultAuditManagerStub( + std::move(auth), options); + return auditmanager_v1_internal::MakeAuditManagerTracingConnection( + std::make_shared( + std::move(background), std::move(stub), std::move(options))); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1 +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/audit_manager_connection.h b/google/cloud/auditmanager/v1/audit_manager_connection.h new file mode 100644 index 0000000000000..2fe7b1b90c6be --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_connection.h @@ -0,0 +1,278 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CONNECTION_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CONNECTION_H + +#include "google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_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 +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/// The retry policy for `AuditManagerConnection`. +class AuditManagerRetryPolicy : 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 `AuditManagerConnection` 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 AuditManagerLimitedErrorCountRetryPolicy + : public AuditManagerRetryPolicy { + 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 AuditManagerLimitedErrorCountRetryPolicy(int maximum_failures) + : impl_(maximum_failures) {} + + AuditManagerLimitedErrorCountRetryPolicy( + AuditManagerLimitedErrorCountRetryPolicy&& rhs) noexcept + : AuditManagerLimitedErrorCountRetryPolicy(rhs.maximum_failures()) {} + AuditManagerLimitedErrorCountRetryPolicy( + AuditManagerLimitedErrorCountRetryPolicy const& rhs) noexcept + : AuditManagerLimitedErrorCountRetryPolicy(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 = AuditManagerRetryPolicy; + + private: + google::cloud::internal::LimitedErrorCountRetryPolicy< + auditmanager_v1_internal::AuditManagerRetryTraits> + impl_; +}; + +/** + * A retry policy for `AuditManagerConnection` 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 AuditManagerLimitedTimeRetryPolicy : public AuditManagerRetryPolicy { + 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 AuditManagerLimitedTimeRetryPolicy( + std::chrono::duration maximum_duration) + : impl_(maximum_duration) {} + + AuditManagerLimitedTimeRetryPolicy( + AuditManagerLimitedTimeRetryPolicy&& rhs) noexcept + : AuditManagerLimitedTimeRetryPolicy(rhs.maximum_duration()) {} + AuditManagerLimitedTimeRetryPolicy( + AuditManagerLimitedTimeRetryPolicy const& rhs) noexcept + : AuditManagerLimitedTimeRetryPolicy(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 = AuditManagerRetryPolicy; + + private: + google::cloud::internal::LimitedTimeRetryPolicy< + auditmanager_v1_internal::AuditManagerRetryTraits> + impl_; +}; + +/** + * The `AuditManagerConnection` object for `AuditManagerClient`. + * + * This interface defines virtual methods for each of the user-facing overload + * sets in `AuditManagerClient`. This allows users to inject custom behavior + * (e.g., with a Google Mock object) when writing tests that use objects of type + * `AuditManagerClient`. + * + * To create a concrete instance, see `MakeAuditManagerConnection()`. + * + * For mocking, see `auditmanager_v1_mocks::MockAuditManagerConnection`. + */ +class AuditManagerConnection { + public: + virtual ~AuditManagerConnection() = 0; + + virtual Options options() { return Options{}; } + + virtual StatusOr EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request); + + virtual StatusOr + GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request); + + virtual future> + GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request); + + virtual StatusOr GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request); + + virtual future> + GenerateAuditReport(google::longrunning::Operation const& operation); + + virtual StreamRange + ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request); + + virtual StatusOr GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request); + + virtual StatusOr + GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request); + + virtual StreamRange + ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request); + + virtual StreamRange ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request); + + 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 `AuditManagerConnection`. + * + * The returned connection object should not be used directly; instead it + * should be passed as an argument to the constructor of AuditManagerClient. + * + * The optional @p options argument may be used to configure aspects of the + * returned `AuditManagerConnection`. Expected options are any of the types in + * the following option lists: + * + * - `google::cloud::CommonOptionList` + * - `google::cloud::GrpcOptionList` + * - `google::cloud::UnifiedCredentialsOptionList` + * - `google::cloud::auditmanager_v1::AuditManagerPolicyOptionList` + * + * @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 `AuditManagerConnection` created by + * this function. + */ +std::shared_ptr MakeAuditManagerConnection( + Options options = {}); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CONNECTION_H diff --git a/google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.cc b/google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.cc new file mode 100644 index 0000000000000..b5ba8209a8177 --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.cc @@ -0,0 +1,119 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h" +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +using ::google::cloud::Idempotency; + +AuditManagerConnectionIdempotencyPolicy:: + ~AuditManagerConnectionIdempotencyPolicy() = default; + +std::unique_ptr +AuditManagerConnectionIdempotencyPolicy::clone() const { + return std::make_unique(*this); +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency +AuditManagerConnectionIdempotencyPolicy::GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1:: + GetResourceEnrollmentStatusRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency +AuditManagerConnectionIdempotencyPolicy::ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::ListControls( + google::cloud::auditmanager::v1::ListControlsRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::ListLocations( + google::cloud::location::ListLocationsRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::GetLocation( + google::cloud::location::GetLocationRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::ListOperations( + google::longrunning::ListOperationsRequest) { // NOLINT + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::GetOperation( + google::longrunning::GetOperationRequest const&) { + return Idempotency::kIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::DeleteOperation( + google::longrunning::DeleteOperationRequest const&) { + return Idempotency::kNonIdempotent; +} + +Idempotency AuditManagerConnectionIdempotencyPolicy::CancelOperation( + google::longrunning::CancelOperationRequest const&) { + return Idempotency::kNonIdempotent; +} + +std::unique_ptr +MakeDefaultAuditManagerConnectionIdempotencyPolicy() { + return std::make_unique(); +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1 +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h b/google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h new file mode 100644 index 0000000000000..c593e9df57759 --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h @@ -0,0 +1,97 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CONNECTION_IDEMPOTENCY_POLICY_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CONNECTION_IDEMPOTENCY_POLICY_H + +#include "google/cloud/idempotency.h" +#include "google/cloud/version.h" +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class AuditManagerConnectionIdempotencyPolicy { + public: + virtual ~AuditManagerConnectionIdempotencyPolicy(); + + /// Create a new copy of this object. + virtual std::unique_ptr clone() + const; + + virtual google::cloud::Idempotency EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request); + + virtual google::cloud::Idempotency GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request); + + virtual google::cloud::Idempotency GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request); + + virtual google::cloud::Idempotency ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request); + + virtual google::cloud::Idempotency GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request); + + virtual google::cloud::Idempotency GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request); + + virtual google::cloud::Idempotency ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request); + + virtual google::cloud::Idempotency ListControls( + google::cloud::auditmanager::v1::ListControlsRequest 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 +MakeDefaultAuditManagerConnectionIdempotencyPolicy(); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_CONNECTION_IDEMPOTENCY_POLICY_H diff --git a/google/cloud/auditmanager/v1/audit_manager_options.h b/google/cloud/auditmanager/v1/audit_manager_options.h new file mode 100644 index 0000000000000..a1ca116703261 --- /dev/null +++ b/google/cloud/auditmanager/v1/audit_manager_options.h @@ -0,0 +1,86 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_OPTIONS_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_OPTIONS_H + +#include "google/cloud/auditmanager/v1/audit_manager_connection.h" +#include "google/cloud/auditmanager/v1/audit_manager_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 auditmanager_v1 { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/** + * Use with `google::cloud::Options` to configure the retry policy. + * + * @ingroup google-cloud-auditmanager-options + */ +struct AuditManagerRetryPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * Use with `google::cloud::Options` to configure the backoff policy. + * + * @ingroup google-cloud-auditmanager-options + */ +struct AuditManagerBackoffPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * Use with `google::cloud::Options` to configure which operations are retried. + * + * @ingroup google-cloud-auditmanager-options + */ +struct AuditManagerConnectionIdempotencyPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * Use with `google::cloud::Options` to configure the long-running operations + * polling policy. + * + * @ingroup google-cloud-auditmanager-options + */ +struct AuditManagerPollingPolicyOption { + using Type = std::shared_ptr; +}; + +/** + * The options applicable to AuditManager. + * + * @ingroup google-cloud-auditmanager-options + */ +using AuditManagerPolicyOptionList = + OptionList; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1 +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_AUDIT_MANAGER_OPTIONS_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.cc b/google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.cc new file mode 100644 index 0000000000000..f6fc8928981a9 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.cc @@ -0,0 +1,220 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.h" +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +AuditManagerAuth::AuditManagerAuth( + std::shared_ptr auth, + std::shared_ptr child) + : auth_(std::move(auth)), child_(std::move(child)) {} + +StatusOr +AuditManagerAuth::EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->EnrollResource(context, options, request); +} + +StatusOr +AuditManagerAuth::GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GenerateAuditScopeReport(context, options, request); +} + +future> +AuditManagerAuth::AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest 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->AsyncGenerateAuditReport(cq, *std::move(context), + std::move(options), request); + }); +} + +StatusOr AuditManagerAuth::GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GenerateAuditReport(context, options, request); +} + +StatusOr +AuditManagerAuth::ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->ListAuditReports(context, options, request); +} + +StatusOr +AuditManagerAuth::GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GetAuditReport(context, options, request); +} + +StatusOr +AuditManagerAuth::GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->GetResourceEnrollmentStatus(context, options, request); +} + +StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> +AuditManagerAuth::ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->ListResourceEnrollmentStatuses(context, options, request); +} + +StatusOr +AuditManagerAuth::ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& request) { + auto status = auth_->ConfigureContext(context); + if (!status.ok()) return status; + return child_->ListControls(context, options, request); +} + +StatusOr +AuditManagerAuth::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 AuditManagerAuth::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 +AuditManagerAuth::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 AuditManagerAuth::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 AuditManagerAuth::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 AuditManagerAuth::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> +AuditManagerAuth::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 AuditManagerAuth::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 auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.h b/google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.h new file mode 100644 index 0000000000000..031879b54f61f --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_AUTH_DECORATOR_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_AUTH_DECORATOR_H + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/internal/unified_grpc_credentials.h" +#include "google/cloud/version.h" +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class AuditManagerAuth : public AuditManagerStub { + public: + ~AuditManagerAuth() override = default; + AuditManagerAuth( + std::shared_ptr auth, + std::shared_ptr child); + + StatusOr EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr + ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) + override; + + StatusOr GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> + ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) override; + + StatusOr ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest 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 auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_AUTH_DECORATOR_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.cc b/google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.cc new file mode 100644 index 0000000000000..bb94a6a78051d --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.cc @@ -0,0 +1,458 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_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 auditmanager_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 +idempotency_policy(Options const& options) { + return options + .get() + ->clone(); +} + +std::unique_ptr polling_policy(Options const& options) { + return options.get() + ->clone(); +} + +} // namespace + +AuditManagerConnectionImpl::AuditManagerConnectionImpl( + std::unique_ptr background, + std::shared_ptr stub, + Options options) + : background_(std::move(background)), + stub_(std::move(stub)), + options_(internal::MergeOptions(std::move(options), + AuditManagerConnection::options())) {} + +StatusOr +AuditManagerConnectionImpl::EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->EnrollResource(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& + request) { + return stub_->EnrollResource(context, options, request); + }, + *current, request, __func__); +} + +StatusOr +AuditManagerConnectionImpl::GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GenerateAuditScopeReport(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + GenerateAuditScopeReportRequest const& request) { + return stub_->GenerateAuditScopeReport(context, options, request); + }, + *current, request, __func__); +} + +future> +AuditManagerConnectionImpl::GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + auto request_copy = request; + auto const idempotent = + idempotency_policy(*current)->GenerateAuditReport(request_copy); + return google::cloud::internal::AsyncLongRunningOperation< + google::cloud::auditmanager::v1::AuditReport>( + background_->cq(), current, std::move(request_copy), + [stub = stub_]( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return stub->AsyncGenerateAuditReport(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::auditmanager::v1::AuditReport>, + retry_policy(*current), backoff_policy(*current), idempotent, + polling_policy(*current), __func__); +} + +StatusOr +AuditManagerConnectionImpl::GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GenerateAuditReport(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return stub_->GenerateAuditReport(context, options, request); + }, + *current, request, __func__); +} + +future> +AuditManagerConnectionImpl::GenerateAuditReport( + 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 GenerateAuditReport", + GCP_ERROR_INFO().WithMetadata("operation", + operation.metadata().DebugString()))); + } + + return google::cloud::internal::AsyncAwaitLongRunningOperation< + google::cloud::auditmanager::v1::AuditReport>( + 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::auditmanager::v1::AuditReport>, + polling_policy(*current), __func__); +} + +StreamRange +AuditManagerConnectionImpl::ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request) { + request.clear_page_token(); + auto current = google::cloud::internal::SaveCurrentOptions(); + auto idempotency = idempotency_policy(*current)->ListAuditReports(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( + retry_policy(*current)), + backoff = std::shared_ptr(backoff_policy(*current))]( + Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& r) { + return google::cloud::internal::RetryLoop( + retry->clone(), backoff->clone(), idempotency, + [stub]( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& + request) { + return stub->ListAuditReports(context, options, request); + }, + options, r, function_name); + }, + [](google::cloud::auditmanager::v1::ListAuditReportsResponse r) { + std::vector result( + r.audit_reports().size()); + auto& messages = *r.mutable_audit_reports(); + std::move(messages.begin(), messages.end(), result.begin()); + return result; + }); +} + +StatusOr +AuditManagerConnectionImpl::GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GetAuditReport(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& + request) { + return stub_->GetAuditReport(context, options, request); + }, + *current, request, __func__); +} + +StatusOr +AuditManagerConnectionImpl::GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + auto current = google::cloud::internal::SaveCurrentOptions(); + return google::cloud::internal::RetryLoop( + retry_policy(*current), backoff_policy(*current), + idempotency_policy(*current)->GetResourceEnrollmentStatus(request), + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + GetResourceEnrollmentStatusRequest const& request) { + return stub_->GetResourceEnrollmentStatus(context, options, request); + }, + *current, request, __func__); +} + +StreamRange +AuditManagerConnectionImpl::ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request) { + request.clear_page_token(); + auto current = google::cloud::internal::SaveCurrentOptions(); + auto idempotency = + idempotency_policy(*current)->ListResourceEnrollmentStatuses(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( + retry_policy(*current)), + backoff = std::shared_ptr(backoff_policy(*current))]( + Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& r) { + return google::cloud::internal::RetryLoop( + retry->clone(), backoff->clone(), idempotency, + [stub](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + return stub->ListResourceEnrollmentStatuses(context, options, + request); + }, + options, r, function_name); + }, + [](google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse + r) { + std::vector + result(r.resource_enrollment_statuses().size()); + auto& messages = *r.mutable_resource_enrollment_statuses(); + std::move(messages.begin(), messages.end(), result.begin()); + return result; + }); +} + +StreamRange +AuditManagerConnectionImpl::ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request) { + request.clear_page_token(); + auto current = google::cloud::internal::SaveCurrentOptions(); + auto idempotency = idempotency_policy(*current)->ListControls(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( + retry_policy(*current)), + backoff = std::shared_ptr(backoff_policy(*current))]( + Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& r) { + return google::cloud::internal::RetryLoop( + retry->clone(), backoff->clone(), idempotency, + [stub](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& + request) { + return stub->ListControls(context, options, request); + }, + options, r, function_name); + }, + [](google::cloud::auditmanager::v1::ListControlsResponse r) { + std::vector result( + r.controls().size()); + auto& messages = *r.mutable_controls(); + std::move(messages.begin(), messages.end(), result.begin()); + return result; + }); +} + +StreamRange +AuditManagerConnectionImpl::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( + 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 +AuditManagerConnectionImpl::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 +AuditManagerConnectionImpl::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( + 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 +AuditManagerConnectionImpl::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 AuditManagerConnectionImpl::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 AuditManagerConnectionImpl::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 auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.h b/google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.h new file mode 100644 index 0000000000000..96198e64e0541 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_CONNECTION_IMPL_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_CONNECTION_IMPL_H + +#include "google/cloud/auditmanager/v1/audit_manager_connection.h" +#include "google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h" +#include "google/cloud/auditmanager/v1/audit_manager_options.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_retry_traits.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_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 +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class AuditManagerConnectionImpl + : public auditmanager_v1::AuditManagerConnection { + public: + ~AuditManagerConnectionImpl() override = default; + + AuditManagerConnectionImpl( + std::unique_ptr background, + std::shared_ptr stub, + Options options); + + Options options() override { return options_; } + + StatusOr EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> + GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + future> + GenerateAuditReport(google::longrunning::Operation const& operation) override; + + StreamRange ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request) + override; + + StatusOr GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StreamRange + ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request) override; + + StreamRange ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request) 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 auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_CONNECTION_IMPL_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.cc b/google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.cc new file mode 100644 index 0000000000000..5bcff8e69f004 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.cc @@ -0,0 +1,274 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.h" +#include "google/cloud/internal/log_wrapper.h" +#include "google/cloud/status_or.h" +#include +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +AuditManagerLogging::AuditManagerLogging( + std::shared_ptr child, TracingOptions tracing_options, + std::set const&) + : child_(std::move(child)), tracing_options_(std::move(tracing_options)) {} + +StatusOr +AuditManagerLogging::EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& + request) { + return child_->EnrollResource(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +AuditManagerLogging::GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + GenerateAuditScopeReportRequest const& request) { + return child_->GenerateAuditScopeReport(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +future> +AuditManagerLogging::AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return child_->AsyncGenerateAuditReport(cq, std::move(context), + std::move(options), request); + }, + cq, std::move(context), std::move(options), request, __func__, + tracing_options_); +} + +StatusOr +AuditManagerLogging::GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return child_->GenerateAuditReport(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +AuditManagerLogging::ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& + request) { + return child_->ListAuditReports(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +AuditManagerLogging::GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& + request) { + return child_->GetAuditReport(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +AuditManagerLogging::GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + GetResourceEnrollmentStatusRequest const& request) { + return child_->GetResourceEnrollmentStatus(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> +AuditManagerLogging::ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + return google::cloud::internal::LogWrapper( + [this](grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + return child_->ListResourceEnrollmentStatuses(context, options, + request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +AuditManagerLogging::ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& request) { + return google::cloud::internal::LogWrapper( + [this]( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& request) { + return child_->ListControls(context, options, request); + }, + context, options, request, __func__, tracing_options_); +} + +StatusOr +AuditManagerLogging::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 AuditManagerLogging::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 +AuditManagerLogging::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 AuditManagerLogging::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 AuditManagerLogging::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 AuditManagerLogging::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> +AuditManagerLogging::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 AuditManagerLogging::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 auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.h b/google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.h new file mode 100644 index 0000000000000..f749738ac420d --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_LOGGING_DECORATOR_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_LOGGING_DECORATOR_H + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/tracing_options.h" +#include "google/cloud/version.h" +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class AuditManagerLogging : public AuditManagerStub { + public: + ~AuditManagerLogging() override = default; + AuditManagerLogging(std::shared_ptr child, + TracingOptions tracing_options, + std::set const& components); + + StatusOr EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr + ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) + override; + + StatusOr GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> + ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) override; + + StatusOr ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest 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_; +}; // AuditManagerLogging + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_LOGGING_DECORATOR_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.cc b/google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.cc new file mode 100644 index 0000000000000..89f29697b949c --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.cc @@ -0,0 +1,226 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.h" +#include "google/cloud/grpc_options.h" +#include "google/cloud/internal/absl_str_cat_quiet.h" +#include "google/cloud/internal/api_client_header.h" +#include "google/cloud/internal/url_encode.h" +#include "google/cloud/status_or.h" +#include +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +AuditManagerMetadata::AuditManagerMetadata( + 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 +AuditManagerMetadata::EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + SetMetadata(context, options, + absl::StrCat("scope=", internal::UrlEncode(request.scope()))); + return child_->EnrollResource(context, options, request); +} + +StatusOr +AuditManagerMetadata::GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("scope=", internal::UrlEncode(request.scope()))); + return child_->GenerateAuditScopeReport(context, options, request); +} + +future> +AuditManagerMetadata::AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + SetMetadata(*context, *options, + absl::StrCat("scope=", internal::UrlEncode(request.scope()))); + return child_->AsyncGenerateAuditReport(cq, std::move(context), + std::move(options), request); +} + +StatusOr +AuditManagerMetadata::GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("scope=", internal::UrlEncode(request.scope()))); + return child_->GenerateAuditReport(context, options, request); +} + +StatusOr +AuditManagerMetadata::ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) { + SetMetadata(context, options, + absl::StrCat("parent=", internal::UrlEncode(request.parent()))); + return child_->ListAuditReports(context, options, request); +} + +StatusOr +AuditManagerMetadata::GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->GetAuditReport(context, options, request); +} + +StatusOr +AuditManagerMetadata::GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + SetMetadata(context, options, + absl::StrCat("name=", internal::UrlEncode(request.name()))); + return child_->GetResourceEnrollmentStatus(context, options, request); +} + +StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> +AuditManagerMetadata::ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + SetMetadata(context, options, + absl::StrCat("parent=", internal::UrlEncode(request.parent()))); + return child_->ListResourceEnrollmentStatuses(context, options, request); +} + +StatusOr +AuditManagerMetadata::ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& request) { + SetMetadata(context, options, + absl::StrCat("parent=", internal::UrlEncode(request.parent()))); + return child_->ListControls(context, options, request); +} + +StatusOr +AuditManagerMetadata::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 AuditManagerMetadata::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 +AuditManagerMetadata::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 AuditManagerMetadata::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 AuditManagerMetadata::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 AuditManagerMetadata::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> +AuditManagerMetadata::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 AuditManagerMetadata::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 AuditManagerMetadata::SetMetadata(grpc::ClientContext& context, + Options const& options, + std::string const& request_params) { + context.AddMetadata("x-goog-request-params", request_params); + SetMetadata(context, options); +} + +void AuditManagerMetadata::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 auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.h b/google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.h new file mode 100644 index 0000000000000..f275f38596bd8 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.h @@ -0,0 +1,145 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_METADATA_DECORATOR_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_METADATA_DECORATOR_H + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class AuditManagerMetadata : public AuditManagerStub { + public: + ~AuditManagerMetadata() override = default; + AuditManagerMetadata(std::shared_ptr child, + std::multimap fixed_metadata, + std::string api_client_header = ""); + + StatusOr EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr + ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) + override; + + StatusOr GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> + ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) override; + + StatusOr ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest 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 auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_METADATA_DECORATOR_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.cc b/google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.cc new file mode 100644 index 0000000000000..b803e024ef737 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.cc @@ -0,0 +1,79 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.h" +#include "google/cloud/auditmanager/v1/audit_manager_connection.h" +#include "google/cloud/auditmanager/v1/audit_manager_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 auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +namespace { +auto constexpr kBackoffScaling = 2.0; +} // namespace + +Options AuditManagerDefaultOptions(Options options) { + options = internal::PopulateCommonOptions( + std::move(options), "GOOGLE_CLOUD_CPP_AUDIT_MANAGER_ENDPOINT", "", + "GOOGLE_CLOUD_CPP_AUDIT_MANAGER_AUTHORITY", + "auditmanager.googleapis.com"); + options = internal::PopulateGrpcOptions(std::move(options)); + if (!options.has()) { + options.set( + auditmanager_v1::AuditManagerLimitedTimeRetryPolicy( + std::chrono::minutes(30)) + .clone()); + } + if (!options.has()) { + options.set( + ExponentialBackoffPolicy( + std::chrono::seconds(0), std::chrono::seconds(1), + std::chrono::minutes(5), kBackoffScaling, kBackoffScaling) + .clone()); + } + if (!options.has()) { + options.set( + GenericPollingPolicy< + auditmanager_v1::AuditManagerRetryPolicyOption::Type, + auditmanager_v1::AuditManagerBackoffPolicyOption::Type>( + options.get() + ->clone(), + ExponentialBackoffPolicy(std::chrono::seconds(1), + std::chrono::minutes(5), kBackoffScaling) + .clone()) + .clone()); + } + if (!options.has< + auditmanager_v1::AuditManagerConnectionIdempotencyPolicyOption>()) { + options.set( + auditmanager_v1::MakeDefaultAuditManagerConnectionIdempotencyPolicy()); + } + + return options; +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.h b/google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.h new file mode 100644 index 0000000000000..fa991caf8d588 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_OPTION_DEFAULTS_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_OPTION_DEFAULTS_H + +#include "google/cloud/options.h" +#include "google/cloud/version.h" + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +Options AuditManagerDefaultOptions(Options options); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_OPTION_DEFAULTS_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_retry_traits.h b/google/cloud/auditmanager/v1/internal/audit_manager_retry_traits.h new file mode 100644 index 0000000000000..34aa92e720289 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_RETRY_TRAITS_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_RETRY_TRAITS_H + +#include "google/cloud/status.h" +#include "google/cloud/version.h" + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/// Define the gRPC status code semantics for retrying requests. +struct AuditManagerRetryTraits { + static bool IsPermanentFailure(google::cloud::Status const& status) { + return status.code() != StatusCode::kOk && + status.code() != StatusCode::kUnavailable; + } +}; + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_RETRY_TRAITS_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_sources.cc b/google/cloud/auditmanager/v1/internal/audit_manager_sources.cc new file mode 100644 index 0000000000000..e4ed967b58c16 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_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/auditmanager/v1/auditmanager.proto + +// NOLINTBEGIN(bugprone-suspicious-include) +#include "google/cloud/auditmanager/v1/audit_manager_client.cc" +#include "google/cloud/auditmanager/v1/audit_manager_connection.cc" +#include "google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_connection_impl.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_option_defaults.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.cc" +#include "google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.cc" +// NOLINTEND(bugprone-suspicious-include) diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_stub.cc b/google/cloud/auditmanager/v1/internal/audit_manager_stub.cc new file mode 100644 index 0000000000000..f61896bd78a7d --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_stub.cc @@ -0,0 +1,270 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/grpc_error_delegate.h" +#include "google/cloud/status_or.h" +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +AuditManagerStub::~AuditManagerStub() = default; + +StatusOr +DefaultAuditManagerStub::EnrollResource( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + google::cloud::auditmanager::v1::Enrollment response; + auto status = grpc_stub_->EnrollResource(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultAuditManagerStub::GenerateAuditScopeReport( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + google::cloud::auditmanager::v1::AuditScopeReport response; + auto status = + grpc_stub_->GenerateAuditScopeReport(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +future> +DefaultAuditManagerStub::AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + return internal::MakeUnaryRpcImpl< + google::cloud::auditmanager::v1::GenerateAuditReportRequest, + google::longrunning::Operation>( + cq, + [this](grpc::ClientContext* context, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request, + grpc::CompletionQueue* cq) { + return grpc_stub_->AsyncGenerateAuditReport(context, request, cq); + }, + request, std::move(context)); +} + +StatusOr +DefaultAuditManagerStub::GenerateAuditReport( + grpc::ClientContext& context, Options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + google::longrunning::Operation response; + auto status = grpc_stub_->GenerateAuditReport(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultAuditManagerStub::ListAuditReports( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) { + google::cloud::auditmanager::v1::ListAuditReportsResponse response; + auto status = grpc_stub_->ListAuditReports(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultAuditManagerStub::GetAuditReport( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + google::cloud::auditmanager::v1::AuditReport response; + auto status = grpc_stub_->GetAuditReport(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultAuditManagerStub::GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + google::cloud::auditmanager::v1::ResourceEnrollmentStatus response; + auto status = + grpc_stub_->GetResourceEnrollmentStatus(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> +DefaultAuditManagerStub::ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse + response; + auto status = + grpc_stub_->ListResourceEnrollmentStatuses(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultAuditManagerStub::ListControls( + grpc::ClientContext& context, Options const&, + google::cloud::auditmanager::v1::ListControlsRequest const& request) { + google::cloud::auditmanager::v1::ListControlsResponse response; + auto status = grpc_stub_->ListControls(&context, request, &response); + if (!status.ok()) { + return google::cloud::MakeStatusFromRpcError(status); + } + return response; +} + +StatusOr +DefaultAuditManagerStub::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 +DefaultAuditManagerStub::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 +DefaultAuditManagerStub::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 DefaultAuditManagerStub::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 DefaultAuditManagerStub::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 DefaultAuditManagerStub::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> +DefaultAuditManagerStub::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 DefaultAuditManagerStub::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 auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_stub.h b/google/cloud/auditmanager/v1/internal/audit_manager_stub.h new file mode 100644 index 0000000000000..c42a7d6f93ee3 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_stub.h @@ -0,0 +1,249 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_STUB_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_STUB_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 +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +class AuditManagerStub { + public: + virtual ~AuditManagerStub() = 0; + + virtual StatusOr EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& + request) = 0; + + virtual StatusOr + GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) = 0; + + virtual future> + AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) = 0; + + virtual StatusOr GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) = 0; + + virtual StatusOr + ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& + request) = 0; + + virtual StatusOr GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& + request) = 0; + + virtual StatusOr + GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) = 0; + + virtual StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> + ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) = 0; + + virtual StatusOr + ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest 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 DefaultAuditManagerStub : public AuditManagerStub { + public: + DefaultAuditManagerStub( + std::unique_ptr< + google::cloud::auditmanager::v1::AuditManager::StubInterface> + 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 EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr + ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) + override; + + StatusOr GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> + ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) override; + + StatusOr ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest 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 auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_STUB_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.cc b/google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.cc new file mode 100644 index 0000000000000..1a8a7fd1da8f9 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.cc @@ -0,0 +1,76 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_auth_decorator.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_logging_decorator.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_metadata_decorator.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.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 +#include +#include +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +std::shared_ptr CreateDefaultAuditManagerStub( + std::shared_ptr auth, + Options const& options) { + auto channel = auth->CreateChannel(options.get(), + internal::MakeChannelArguments(options)); + auto service_grpc_stub = + google::cloud::auditmanager::v1::AuditManager::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 = MakeAuditManagerTracingStub(std::move(stub)); + } + return stub; +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.h b/google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.h new file mode 100644 index 0000000000000..04b92b7e1d4c5 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_stub_factory.h @@ -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. + +// Generated by the Codegen C++ plugin. +// If you make any local changes, they will be lost. +// source: google/cloud/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_STUB_FACTORY_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_STUB_FACTORY_H + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/internal/unified_grpc_credentials.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +std::shared_ptr CreateDefaultAuditManagerStub( + std::shared_ptr auth, + Options const& options); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_STUB_FACTORY_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.cc b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.cc new file mode 100644 index 0000000000000..6c1e5bc8f877c --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.h" +#include "google/cloud/internal/opentelemetry.h" +#include "google/cloud/internal/traced_stream_range.h" +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +#ifdef GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +AuditManagerTracingConnection::AuditManagerTracingConnection( + std::shared_ptr child) + : child_(std::move(child)) {} + +StatusOr +AuditManagerTracingConnection::EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::EnrollResource"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->EnrollResource(request)); +} + +StatusOr +AuditManagerTracingConnection::GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GenerateAuditScopeReport"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GenerateAuditScopeReport(request)); +} + +future> +AuditManagerTracingConnection::GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GenerateAuditReport"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), + child_->GenerateAuditReport(request)); +} + +StatusOr +AuditManagerTracingConnection::GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GenerateAuditReport"); + opentelemetry::trace::Scope scope(span); + return internal::EndSpan(*span, + child_->GenerateAuditReport(NoAwaitTag{}, request)); +} + +future> +AuditManagerTracingConnection::GenerateAuditReport( + google::longrunning::Operation const& operation) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GenerateAuditReport"); + internal::OTelScope scope(span); + return internal::EndSpan(std::move(span), + child_->GenerateAuditReport(operation)); +} + +StreamRange +AuditManagerTracingConnection::ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::ListAuditReports"); + internal::OTelScope scope(span); + auto sr = child_->ListAuditReports(std::move(request)); + return internal::MakeTracedStreamRange< + google::cloud::auditmanager::v1::AuditReport>(std::move(span), + std::move(sr)); +} + +StatusOr +AuditManagerTracingConnection::GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GetAuditReport"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetAuditReport(request)); +} + +StatusOr +AuditManagerTracingConnection::GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GetResourceEnrollmentStatus"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetResourceEnrollmentStatus(request)); +} + +StreamRange +AuditManagerTracingConnection::ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::" + "ListResourceEnrollmentStatuses"); + internal::OTelScope scope(span); + auto sr = child_->ListResourceEnrollmentStatuses(std::move(request)); + return internal::MakeTracedStreamRange< + google::cloud::auditmanager::v1::ResourceEnrollmentStatus>( + std::move(span), std::move(sr)); +} + +StreamRange +AuditManagerTracingConnection::ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::ListControls"); + internal::OTelScope scope(span); + auto sr = child_->ListControls(std::move(request)); + return internal::MakeTracedStreamRange< + google::cloud::auditmanager::v1::Control>(std::move(span), std::move(sr)); +} + +StreamRange +AuditManagerTracingConnection::ListLocations( + google::cloud::location::ListLocationsRequest request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::ListLocations"); + internal::OTelScope scope(span); + auto sr = child_->ListLocations(std::move(request)); + return internal::MakeTracedStreamRange( + std::move(span), std::move(sr)); +} + +StatusOr +AuditManagerTracingConnection::GetLocation( + google::cloud::location::GetLocationRequest const& request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GetLocation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetLocation(request)); +} + +StreamRange +AuditManagerTracingConnection::ListOperations( + google::longrunning::ListOperationsRequest request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::ListOperations"); + internal::OTelScope scope(span); + auto sr = child_->ListOperations(std::move(request)); + return internal::MakeTracedStreamRange( + std::move(span), std::move(sr)); +} + +StatusOr +AuditManagerTracingConnection::GetOperation( + google::longrunning::GetOperationRequest const& request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::GetOperation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->GetOperation(request)); +} + +Status AuditManagerTracingConnection::DeleteOperation( + google::longrunning::DeleteOperationRequest const& request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::DeleteOperation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->DeleteOperation(request)); +} + +Status AuditManagerTracingConnection::CancelOperation( + google::longrunning::CancelOperationRequest const& request) { + auto span = internal::MakeSpan( + "auditmanager_v1::AuditManagerConnection::CancelOperation"); + auto scope = opentelemetry::trace::Scope(span); + return internal::EndSpan(*span, child_->CancelOperation(request)); +} + +#endif // GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +std::shared_ptr +MakeAuditManagerTracingConnection( + std::shared_ptr conn) { +#ifdef GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + if (internal::TracingEnabled(conn->options())) { + conn = std::make_shared(std::move(conn)); + } +#endif // GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + return conn; +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.h b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.h new file mode 100644 index 0000000000000..830e6cfcf0733 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_connection.h @@ -0,0 +1,125 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_TRACING_CONNECTION_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_TRACING_CONNECTION_H + +#include "google/cloud/auditmanager/v1/audit_manager_connection.h" +#include "google/cloud/version.h" +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +#ifdef GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +class AuditManagerTracingConnection + : public auditmanager_v1::AuditManagerConnection { + public: + ~AuditManagerTracingConnection() override = default; + + explicit AuditManagerTracingConnection( + std::shared_ptr child); + + Options options() override { return child_->options(); } + + StatusOr EnrollResource( + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> + GenerateAuditReport( + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + future> + GenerateAuditReport(google::longrunning::Operation const& operation) override; + + StreamRange ListAuditReports( + google::cloud::auditmanager::v1::ListAuditReportsRequest request) + override; + + StatusOr GetAuditReport( + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StreamRange + ListResourceEnrollmentStatuses( + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request) override; + + StreamRange ListControls( + google::cloud::auditmanager::v1::ListControlsRequest request) 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_; +}; + +#endif // GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +/** + * 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 +MakeAuditManagerTracingConnection( + std::shared_ptr conn); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_TRACING_CONNECTION_H diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.cc b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.cc new file mode 100644 index 0000000000000..21766ace47208 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.cc @@ -0,0 +1,268 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.h" +#include "google/cloud/internal/grpc_opentelemetry.h" +#include +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +#ifdef GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +AuditManagerTracingStub::AuditManagerTracingStub( + std::shared_ptr child) + : child_(std::move(child)), propagator_(internal::MakePropagator()) {} + +StatusOr +AuditManagerTracingStub::EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "EnrollResource"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->EnrollResource(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "GenerateAuditScopeReport"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan( + context, *span, + child_->GenerateAuditScopeReport(context, options, request)); +} + +future> +AuditManagerTracingStub::AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "GenerateAuditReport"); + internal::OTelScope scope(span); + internal::InjectTraceContext(*context, *propagator_); + auto f = child_->AsyncGenerateAuditReport(cq, context, std::move(options), + request); + return internal::EndSpan(std::move(context), std::move(span), std::move(f)); +} + +StatusOr +AuditManagerTracingStub::GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "GenerateAuditReport"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan( + context, *span, child_->GenerateAuditReport(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "ListAuditReports"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListAuditReports(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "GetAuditReport"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->GetAuditReport(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) { + auto span = + internal::MakeSpanGrpc("google.cloud.auditmanager.v1.AuditManager", + "GetResourceEnrollmentStatus"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan( + context, *span, + child_->GetResourceEnrollmentStatus(context, options, request)); +} + +StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> +AuditManagerTracingStub::ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) { + auto span = + internal::MakeSpanGrpc("google.cloud.auditmanager.v1.AuditManager", + "ListResourceEnrollmentStatuses"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan( + context, *span, + child_->ListResourceEnrollmentStatuses(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "ListControls"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListControls(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::ListLocations( + grpc::ClientContext& context, Options const& options, + google::cloud::location::ListLocationsRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "ListLocations"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListLocations(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::GetLocation( + grpc::ClientContext& context, Options const& options, + google::cloud::location::GetLocationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "GetLocation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->GetLocation(context, options, request)); +} + +StatusOr +AuditManagerTracingStub::ListOperations( + grpc::ClientContext& context, Options const& options, + google::longrunning::ListOperationsRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "ListOperations"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->ListOperations(context, options, request)); +} + +StatusOr AuditManagerTracingStub::GetOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::GetOperationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "GetOperation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->GetOperation(context, options, request)); +} + +Status AuditManagerTracingStub::DeleteOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::DeleteOperationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "DeleteOperation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->DeleteOperation(context, options, request)); +} + +Status AuditManagerTracingStub::CancelOperation( + grpc::ClientContext& context, Options const& options, + google::longrunning::CancelOperationRequest const& request) { + auto span = internal::MakeSpanGrpc( + "google.cloud.auditmanager.v1.AuditManager", "CancelOperation"); + auto scope = opentelemetry::trace::Scope(span); + internal::InjectTraceContext(context, *propagator_); + return internal::EndSpan(context, *span, + child_->CancelOperation(context, options, request)); +} + +future> +AuditManagerTracingStub::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 AuditManagerTracingStub::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)); +} + +#endif // GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +std::shared_ptr MakeAuditManagerTracingStub( + std::shared_ptr stub) { +#ifdef GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + return std::make_shared(std::move(stub)); +#else + return stub; +#endif // GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY +} + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google diff --git a/google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.h b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.h new file mode 100644 index 0000000000000..7a57b28457ea4 --- /dev/null +++ b/google/cloud/auditmanager/v1/internal/audit_manager_tracing_stub.h @@ -0,0 +1,151 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_TRACING_STUB_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_TRACING_STUB_H + +#include "google/cloud/auditmanager/v1/internal/audit_manager_stub.h" +#include "google/cloud/internal/trace_propagator.h" +#include "google/cloud/options.h" +#include "google/cloud/version.h" +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_internal { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +#ifdef GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +class AuditManagerTracingStub : public AuditManagerStub { + public: + ~AuditManagerTracingStub() override = default; + + explicit AuditManagerTracingStub(std::shared_ptr child); + + StatusOr EnrollResource( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::EnrollResourceRequest const& request) + override; + + StatusOr + GenerateAuditScopeReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request) override; + + future> AsyncGenerateAuditReport( + google::cloud::CompletionQueue& cq, + std::shared_ptr context, + google::cloud::internal::ImmutableOptions options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr GenerateAuditReport( + grpc::ClientContext& context, Options options, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request) override; + + StatusOr + ListAuditReports( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListAuditReportsRequest const& request) + override; + + StatusOr GetAuditReport( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetAuditReportRequest const& request) + override; + + StatusOr + GetResourceEnrollmentStatus( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::GetResourceEnrollmentStatusRequest const& + request) override; + + StatusOr< + google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesResponse> + ListResourceEnrollmentStatuses( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1:: + ListResourceEnrollmentStatusesRequest const& request) override; + + StatusOr ListControls( + grpc::ClientContext& context, Options const& options, + google::cloud::auditmanager::v1::ListControlsRequest 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_; +}; + +#endif // GOOGLE_CLOUD_CPP_HAVE_OPENTELEMETRY + +/** + * Applies the tracing decorator to the given stub. + * + * The stub is only decorated if the library has been compiled with + * OpenTelemetry. + */ +std::shared_ptr MakeAuditManagerTracingStub( + std::shared_ptr stub); + +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_END +} // namespace auditmanager_v1_internal +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_INTERNAL_AUDIT_MANAGER_TRACING_STUB_H diff --git a/google/cloud/auditmanager/v1/mocks/mock_audit_manager_connection.h b/google/cloud/auditmanager/v1/mocks/mock_audit_manager_connection.h new file mode 100644 index 0000000000000..9b8347cbae5d2 --- /dev/null +++ b/google/cloud/auditmanager/v1/mocks/mock_audit_manager_connection.h @@ -0,0 +1,162 @@ +// 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/auditmanager/v1/auditmanager.proto + +#ifndef GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_MOCKS_MOCK_AUDIT_MANAGER_CONNECTION_H +#define GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_MOCKS_MOCK_AUDIT_MANAGER_CONNECTION_H + +#include "google/cloud/auditmanager/v1/audit_manager_connection.h" +#include + +namespace google { +namespace cloud { +namespace auditmanager_v1_mocks { +GOOGLE_CLOUD_CPP_INLINE_NAMESPACE_BEGIN + +/** + * A class to mock `AuditManagerConnection`. + * + * Application developers may want to test their code with simulated responses, + * including errors, from an object of type `AuditManagerClient`. To do so, + * construct an object of type `AuditManagerClient` 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 MockAuditManagerConnection + : public auditmanager_v1::AuditManagerConnection { + public: + MOCK_METHOD(Options, options, (), (override)); + + MOCK_METHOD( + StatusOr, EnrollResource, + (google::cloud::auditmanager::v1::EnrollResourceRequest const& request), + (override)); + + MOCK_METHOD( + StatusOr, + GenerateAuditScopeReport, + (google::cloud::auditmanager::v1::GenerateAuditScopeReportRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, + /// GenerateAuditReport(Matcher(_))) + /// @endcode + MOCK_METHOD( + future>, + GenerateAuditReport, + (google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// EXPECT_CALL(*mock, GenerateAuditReport(_, _)) + /// @endcode + MOCK_METHOD( + StatusOr, GenerateAuditReport, + (NoAwaitTag, + google::cloud::auditmanager::v1::GenerateAuditReportRequest const& + request), + (override)); + + /// To disambiguate calls, use: + /// + /// @code + /// using ::testing::_; + /// using ::testing::Matcher; + /// EXPECT_CALL(*mock, + /// GenerateAuditReport(Matcher(_))) + /// @endcode + MOCK_METHOD(future>, + GenerateAuditReport, + (google::longrunning::Operation const& operation), (override)); + + MOCK_METHOD( + (StreamRange), + ListAuditReports, + (google::cloud::auditmanager::v1::ListAuditReportsRequest request), + (override)); + + MOCK_METHOD( + StatusOr, GetAuditReport, + (google::cloud::auditmanager::v1::GetAuditReportRequest const& request), + (override)); + + MOCK_METHOD( + StatusOr, + GetResourceEnrollmentStatus, + (google::cloud::auditmanager::v1:: + GetResourceEnrollmentStatusRequest const& request), + (override)); + + MOCK_METHOD( + (StreamRange), + ListResourceEnrollmentStatuses, + (google::cloud::auditmanager::v1::ListResourceEnrollmentStatusesRequest + request), + (override)); + + MOCK_METHOD((StreamRange), + ListControls, + (google::cloud::auditmanager::v1::ListControlsRequest request), + (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 auditmanager_v1_mocks +} // namespace cloud +} // namespace google + +#endif // GOOGLE_CLOUD_CPP_GOOGLE_CLOUD_AUDITMANAGER_V1_MOCKS_MOCK_AUDIT_MANAGER_CONNECTION_H diff --git a/google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc b/google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc new file mode 100644 index 0000000000000..5931f207d6520 --- /dev/null +++ b/google/cloud/auditmanager/v1/samples/audit_manager_client_samples.cc @@ -0,0 +1,226 @@ +// 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/auditmanager/v1/auditmanager.proto + +#include "google/cloud/auditmanager/v1/audit_manager_client.h" +#include "google/cloud/auditmanager/v1/audit_manager_connection_idempotency_policy.h" +#include "google/cloud/auditmanager/v1/audit_manager_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: auditmanager_v1::AuditManagerClient +// 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::auditmanager_v1::AuditManagerClient( + google::cloud::auditmanager_v1::MakeAuditManagerConnection(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::auditmanager_v1::AuditManagerClient( + google::cloud::auditmanager_v1::MakeAuditManagerConnection(*ud_options)); + //! [set-client-universe-domain] +} + +//! [custom-idempotency-policy] +class CustomIdempotencyPolicy : public google::cloud::auditmanager_v1:: + AuditManagerConnectionIdempotencyPolicy { + public: + ~CustomIdempotencyPolicy() override = default; + std::unique_ptr< + google::cloud::auditmanager_v1::AuditManagerConnectionIdempotencyPolicy> + 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::auditmanager_v1:: + AuditManagerLimitedErrorCountRetryPolicy(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::auditmanager_v1::MakeAuditManagerConnection(options); + + // c1 and c2 share the same retry policies + auto c1 = google::cloud::auditmanager_v1::AuditManagerClient(connection); + auto c2 = google::cloud::auditmanager_v1::AuditManagerClient(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::auditmanager_v1::AuditManagerClient( + connection, + google::cloud::Options{} + .set( + google::cloud::auditmanager_v1:: + AuditManagerLimitedTimeRetryPolicy(std::chrono::minutes(5)) + .clone())); + + // You can also override the policies in a single call: + // c3.SomeRpc(..., google::cloud::Options{} + // .set( + // google::cloud::auditmanager_v1::AuditManagerLimitedErrorCountRetryPolicy(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::auditmanager_v1:: + AuditManagerRetryPolicyOption::Type, + google::cloud::auditmanager_v1:: + AuditManagerBackoffPolicyOption::Type>( + google::cloud::auditmanager_v1:: + AuditManagerLimitedTimeRetryPolicy( + /*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::auditmanager_v1::MakeAuditManagerConnection(options); + + // c1 and c2 share the same polling policies. + auto c1 = google::cloud::auditmanager_v1::AuditManagerClient(connection); + auto c2 = google::cloud::auditmanager_v1::AuditManagerClient(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::auditmanager_v1::AuditManagerClient( + google::cloud::auditmanager_v1::MakeAuditManagerConnection(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 63c02c89234a6..24fefa5e8d7a7 100644 --- a/libraries.bzl +++ b/libraries.bzl @@ -38,6 +38,7 @@ GOOGLE_CLOUD_CPP_GA_LIBRARIES = [ "artifactregistry", "asset", "assuredworkloads", + "auditmanager", "automl", "backupdr", "baremetalsolution",