build MIT licensed

rust-goauth [[docs](https://docs.rs/goauth)]

Crate for using OAuth 2.0 with Server to Server Applications for Google Cloud Engine, with tentative support for all supported Scopes. Supports sync or async requests via Futures.

Provides a serialisable Token struct for use in other applications that require authenticated interactions with Google Cloud.

Usage

```rust,no_run

[macro_use]

extern crate log;

use goauth::auth::JwtClaims; use goauth::scopes::Scope; use goauth::{gettoken, gettokenblocking, GoErr}; use goauth::credentials::Credentials; use goauth::fetcher::TokenFetcher; use smpljwt::{RSAKey, Jwt}; use time::Duration;

fn main() -> Result<(), GoErr>{ let token_url = "https://www.googleapis.com/oauth2/v4/token"; let iss = ""; // https://developers.google.com/identity/protocols/OAuth2ServiceAccount

let credentials = Credentials::fromfile("dummycredentialsfilefortests.json").unwrap(); let claims = JwtClaims::new(String::from(iss), &Scope::DevStorageReadWrite, String::from(tokenurl), None, None); let jwt = Jwt::new(claims, credentials.rsa_key().unwrap(), None);

// Use async let token = async { match get_token(&jwt, &credentials).await { Ok(token) => token, Err(e) => panic!(e) } };

// Or sync let token = gettokenblocking(&jwt, &credentials)?;

// Token provides access_token method that outputs a value that should be placed in the Authorization header

// Or use the TokenFetcher abstraction which will automatically refresh tokens let fetcher = TokenFetcher::new(jwt, credentials, Duration::new(1, 0));

let token = async { match fetcher.fetch_token().await { Ok(token) => token, Err(e) => panic!(e) } };

// Now a couple seconds later we want the token again - the initial token is cached so it will re-use // the same token, saving a network trip to fetch another token let newtoken = async { match fetcher.fetchtoken().await { Ok(token) => token, Err(e) => panic!(e) } };

asserteq!(token, newtoken);

// Now say the token has expired or is close to expiring ("close" defined by the configurable // refresh_buffer parameter) at this point "later in the program." The next call to // fetch_token will notice this and automatically fetch a new token, cache it, and return it. let newtoken = async { match fetcher.fetchtoken().await { Ok(token) => token, Err(e) => panic!(e) } };

assertne!(token, newtoken);

Ok(()) } ```