NAME
Amazon::S3::Thin::Credentials - AWS credentials data container
SYNOPSIS
my $credentials = Amazon::S3::Thin::Credentials->new(
$aws_access_key_id, $aws_secret_access_key,
# optional:
$aws_session_token
);
my $key = $credentials->access_key_id();
my $secret = $credentials->secret_access_key();
my $session_token = $credentials->session_token();
1;
DESCRIPTION
This module contains AWS credentials and provide getters to the data.
# Load from arguments
my $creds = Amazon::S3::Thin::Credentials->new($access_key, $secret_key, $session_token);
# Load from environment
my $creds = Amazon::S3::Thin::Credentials->from_env;
# Load from instance profile
my $creds = Amazon::S3::Thin::Credentials->from_instance(role => 'foo', version => 2);
from_env()
Instantiate Amazon::S3::Thin::Credentials
and attempts to populate the credentials from current environment.
Croaks if either AWS_ACCESS_KEY_ID or AWS_SECRET_ACCESS_KEY are not set but supports the optional AWS_SESSION_TOKEN variable.
my $creds = Amazon::S3::Thin::Credentials->from_env;
from_metadata()
Instantiate Amazon::S3::Thin::Credentials
and attempts to populate the credentials from the EC2 metadata service. An instance can have multiple IAM roles applied so you may optionally specify a role, otherwise the first one will be used.
In November 2019 AWS released version 2 of the instance metadata service which is more secure against Server Side Request Forgery attacks. Using v2 is highly recommended thus it is the default here.
my $creds = Amazon::S3::Thin::Credentials->from_instance(
role => 'foo', # The name of the IAM role on the instance
version => 2 # Metadata service version - either 1 or 2
);
access_key_id()
Returns access_key_id
secret_access_key()
Returns secret_access_key
session_token()
Returns session_token