#aws-access #aws-credentials #amazon-iam #aws #s3 #wasabi #r2

femlol-aws-creds

Tiny Rust library for working with Amazon IAM credential,s, supports s3 crate

5 releases

0.39.0 Mar 27, 2024
0.37.3 Feb 11, 2024
0.37.2 Feb 11, 2024
0.37.1 Feb 11, 2024
0.37.0 Feb 11, 2024

#5 in #wasabi

Download history 17/week @ 2024-02-11 3/week @ 2024-02-18 43/week @ 2024-02-25 5/week @ 2024-03-03 7/week @ 2024-03-10 5/week @ 2024-03-17 95/week @ 2024-03-24 46/week @ 2024-03-31 31/week @ 2024-04-07 10/week @ 2024-04-14

183 downloads per month
Used in s3-tokio

MIT license

22KB
376 lines

Example

// AWS access credentials: access key, secret key, and optional token.
# Example
// Loads from the standard AWS credentials file with the given profile name,
// defaults to "default".
use awscreds::Credentials;

// Load credentials from `[default]` profile
let credentials = Credentials::default();
// Also loads credentials from `[default]` profile
let credentials = Credentials::new(None, None, None, None);
// Load credentials from `[my-profile]` profile
let credentials = Credentials::new(None, None, None, Some("my-profile".into()));
// Credentials may also be initialized directly or by the following environment variables:
//   - `AWS_ACCESS_KEY_ID`,
//   - `AWS_SECRET_ACCESS_KEY`
//   - `AWS_SESSION_TOKEN`
// The order of preference is arguments, then environment, and finally AWS
// credentials file.

use s3::credentials::Credentials;
// Load credentials directly
let access_key = String::from("AKIAIOSFODNN7EXAMPLE");
let secret_key = String::from("wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY");
let credentials = Credentials::new(Some(access_key), Some(secret_key), None, None);
// Load credentials from the environment
use std::env;
env::set_var("AWS_ACCESS_KEY_ID", "AKIAIOSFODNN7EXAMPLE");
env::set_var("AWS_SECRET_ACCESS_KEY", "wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY");
let credentials = Credentials::new(None, None, None, None);

Dependencies

~5–15MB
~186K SLoC