App-Glacier
view release on metacpan or search on metacpan
lib/App/Glacier/Bre.pm view on Meta::CPAN
my $istore_base_url = "http://169.254.169.254/latest/";
my $istore_document_path = "dynamic/instance-identity/document";
my $istore_credentials_path = "meta-data/iam/security-credentials/";
sub _get_instore_region {
my $ua = LWP::UserAgent->new(timeout => 10);
my $response = $ua->get($istore_base_url . $istore_document_path);
unless ($response->is_success) {
return undef;
}
my $doc = JSON->new->decode($response->decoded_content);
return $doc->{region};
}
sub _get_instore_creds {
my $ua = LWP::UserAgent->new(timeout => 10);
my $url = $istore_base_url . $istore_credentials_path;
my $response = $ua->get($url);
unless ($response->is_success) {
return undef;
}
chomp(my $name = $response->decoded_content);
$url .= $name;
$response = $ua->get($url);
unless ($response->is_success) {
return undef;
}
my $doc = JSON->new->decode($response->decoded_content);
return ($doc->{AccessKeyId}, $doc->{SecretAccessKey}, $doc->{Token});
}
# Fix bugs in Net::Amazon::Glacier 0.15
if (version->parse($Net::Amazon::Glacier::VERSION) <= version->parse('0.15')) {
no strict 'refs';
*{__PACKAGE__.'::list_vaults'} = \&list_vaults_fixed;
*{__PACKAGE__.'::get_vault_notifications'} = \&get_vault_notifications_fixed;
}
lib/App/Glacier/Bre.pm view on Meta::CPAN
# print "using fixed list_vaults\n";
my $marker;
do {
#10 is the default limit, send a marker if needed
my $res = $self->_send_receive(
GET => "/-/vaults?limit=10" . ($marker ? '&marker='.$marker : '')
);
# updated error severity
croak 'list_vaults failed with error ' . $res->status_line unless $res->is_success;
my $decoded = $self->_decode_and_handle_response( $res );
push @vaults, @{$decoded->{VaultList}};
$marker = $decoded->{Marker};
} while ( $marker );
return ( \@vaults );
}
# get_vault_notifications_fixed
# A fixed version of Net::Amazon::Glacier::get_vault_notifications.
# Fixes the use of HTTP method[1].
#
# The bug (along with the fix) was reported on December 15, 2018[2].
( run in 0.291 second using v1.01-cache-2.11-cpan-26ccb49234f )