Amazon-SecretsManager
view release on metacpan or search on metacpan
lib/Amazon/SecretsManager.pm view on Meta::CPAN
package Amazon::SecretsManager;
use strict;
use warnings;
use parent qw/Amazon::API/;
use Data::UUID;
# https://docs.aws.amazon.com/secretsmanager/latest/apireference/Welcome.html
my @API_METHODS = qw{
CancelRotateSecret
CreateSecret
DeleteResourcePolicy
DeleteSecret
DescribeSecret
GetRandomPassword
GetResourcePolicy
GetSecretValue
ListSecrets
ListSecretVersionIds
PutResourcePolicy
PutSecretValue
RemoveRegionsFromReplication
ReplicateSecretToRegions
RestoreSecret
RotateSecret
StopReplicationToReplica
TagResource
UntagResource
UpdateSecret
UpdateSecretVersionStage
ValidateResourcePolicy
};
use vars qw/$VERSION @EXPORT/;
$VERSION = '1.0.0'; $VERSION=~s/\-.*$//;
@EXPORT = qw/$VERSION/;
use constant
{ AWS_API => 'secretsmanager',
AWS_API_VERSION => undef,
AWS_SERVICE_URL_BASE => 'secretsmanager',
TRUE => 1,
FALSE => 0
};
__PACKAGE__->main() if ! caller();
sub new {
my $class = shift;
$class = ref($class) || $class;
my %options;
if ( @_ > 1) {
%options = @_;
}
elsif ( @_ ) {
%options = %{$_[0]};
}
$class->SUPER::new(
{ decode_always => TRUE,
service_url_base => AWS_SERVICE_URL_BASE,
version => AWS_API_VERSION,
api => AWS_API,
api_methods => \@API_METHODS,
content_type => 'application/x-amz-json-1.1',
debug => $ENV{DEBUG} // FALSE,
%options
}
);
}
sub CreateClientRequestToken {
goto &create_client_request_token;
}
sub create_client_request_token {
my ($self) = @_;
return Data::UUID->new->create_str;
}
sub main {
require Data::Dumper;
require JSON::PP;
JSON::PP->import(qw{ encode_json });
Data::Dumper->import('Dumper');
$Data::Dumper::Pair = ':';
$Data::Dumper::Terse = 1;
my $secrets_mgr = Amazon::SecretsManager->new;
my $secret_list = $secrets_mgr->ListSecrets->{SecretList};
print Dumper($secret_list);
if ($secret_list) {
my @names = map { $_->{Name} } @{$secret_list};
if ( !grep {/my-secret/} @names ) {
$secrets_mgr->CreateSecret(
( run in 0.912 second using v1.01-cache-2.11-cpan-39bf76dae61 )