Stay organized with collections Save and categorize content based on your preferences.
An idiomatic C++ client library for the Service Control API. This service provides admission control and telemetry reporting for services integrated with Service Infrastructure.
While this library is GA, please note Google Cloud C++ client libraries do not follow Semantic Versioning.
QuickstartThe following shows the code that you'll run in the google/cloud/servicecontrol/quickstart/
directory, which should give you a taste of the Service Control API C++ client library API.
#include "google/cloud/servicecontrol/v1/service_controller_client.h"
#include "google/cloud/project.h"
#include <google/protobuf/util/time_util.h>
#include <iostream>
int main(int argc, char* argv[]) try {
if (argc != 2) {
std::cerr << "Usage: " << argv[0] << " project-id\n";
return 1;
}
namespace servicecontrol = ::google::cloud::servicecontrol_v1;
auto client = servicecontrol::ServiceControllerClient(
servicecontrol::MakeServiceControllerConnection());
auto const project = google::cloud::Project(argv[1]);
google::api::servicecontrol::v1::CheckRequest request;
request.set_service_name("pubsub.googleapis.com");
*request.mutable_operation() = [&] {
using ::google::protobuf::util::TimeUtil;
google::api::servicecontrol::v1::Operation op;
op.set_operation_id("TODO-use-UUID-4-or-UUID-5");
op.set_operation_name("google.pubsub.v1.Publisher.Publish");
op.set_consumer_id(project.FullName());
*op.mutable_start_time() = (TimeUtil::GetCurrentTime)();
return op;
}();
auto response = client.Check(request);
if (!response) throw std::move(response).status();
std::cout << response->DebugString() << "\n";
return 0;
} catch (google::cloud::Status const& status) {
std::cerr << "google::cloud::Status thrown: " << status << "\n";
return 1;
}
Main classes
This library offers multiple *Client
classes, which are listed below. Each one of these classes exposes all the RPCs for a service as member functions of the class. This library groups multiple services because they are part of the same product or are often used together. A typical example may be the administrative and data plane operations for a single product.
The library also has other classes that provide helpers, configuration parameters, and infrastructure to mock the *Client
classes when testing your application.
servicecontrol_v1::QuotaControllerClient
servicecontrol_v1::ServiceControllerClient
servicecontrol_v2::ServiceControllerClient
Except as otherwise noted, the content of this page is licensed under the Creative Commons Attribution 4.0 License, and code samples are licensed under the Apache 2.0 License. For details, see the Google Developers Site Policies. Java is a registered trademark of Oracle and/or its affiliates.
Last updated 2025-08-14 UTC.
[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Hard to understand","hardToUnderstand","thumb-down"],["Incorrect information or sample code","incorrectInformationOrSampleCode","thumb-down"],["Missing the information/samples I need","missingTheInformationSamplesINeed","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-08-14 UTC."],[[["This webpage details the C++ client library for the Service Control API, which is used for admission control and telemetry reporting for services integrated with Service Infrastructure."],["The latest release candidate is version 2.37.0-rc, with multiple previous versions available, all the way back to version 2.11.0, showing the library's development history."],["The library does not follow Semantic Versioning, even though it is currently marked as GA (Generally Available), which is an important consideration for developers."],["The client library provides multiple `*Client` classes, including `QuotaControllerClient`, `ServiceControllerClient` (v1 and v2), each offering RPCs as member functions, as well as classes for helpers, configuration, and testing."],["The page provides information on error handling, overriding the default endpoint and authentication credentials, overriding retry policies, and environment variables that help to configure library behavior."]]],[]]
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4