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 The following example shows how to explicitly load a service account key file:
[](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<char>(is.rdbuf()), {});
auto options =
google::cloud::Options{}.set<google::cloud::UnifiedCredentialsOption>(
google::cloud::MakeServiceAccountCredentials(contents));
return google::cloud::datastore_admin_v1::DatastoreAdminClient(
google::cloud::datastore_admin_v1::MakeDatastoreAdminConnection(
options));
}
Follow these links to find examples for other *Client classes:
[[["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-03-05 UTC."],[[["This page details how to override the default Application Default Credentials (ADC) for authenticating with Google Cloud Services using the `UnifiedCredentialsOption`."],["The latest release candidate version is 2.37.0-rc, and a range of previous versions from 2.36.0 down to 2.15.1 are documented here."],["An example is given on how to load a service account key file using `MakeServiceAccountCredentials`, which is recommended to be used with the `UnifiedCredentialsOption` for overriding default credentials."],["Links are provided to examples for other client classes, including `datastore_admin_v1::DatastoreAdminClient` and `datastore_v1::DatastoreClient`, that show how to make use of service accounts."],["For best practices on managing service account keys and other authentication component information, there are links to external guides."]]],[]]