GCP auth provides authentication using service accounts Google Cloud Platform (GCP)
GCP auth is a simple, minimal authentication library for Google Cloud Platform (GCP) providing authentication using service accounts. Once authenticated, the service account can be used to acquire bearer tokens for use in authenticating against GCP services.
The library supports the following methods of retrieving tokens in the listed priority order:
GOOGLE_APPLICATION_CREDENTIALS
environment variable. Alternatively, custom service
account credentials can be read from a JSON file or string.gcloud
CLI tool, if it is available on the PATH
..config/gcloud/application_default_credentials.json
;
if found, use these credentials to request refresh tokens.For more detailed information and examples, see the docs.
This crate does not currently support Windows.
The default way to use this library is to get instantiate an AuthenticationManager
. It will
find the appropriate authentication method and use it to retrieve tokens.
```rust,norun use gcpauth::AuthenticationManager;
let authenticationmanager = AuthenticationManager::new().await?; let scopes = &["https://www.googleapis.com/auth/cloud-platform"]; let token = authenticationmanager.get_token(scopes).await?; ```
Parts of the implementation have been sourced from yup-oauth2.
Licensed under MIT license.