Amazon-SecretsManager

 view release on metacpan or  search on metacpan

lib/Amazon/SecretsManager.pm  view on Meta::CPAN

  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(
        { Name               => 'my-secret',
          SecretString       => '$ecur1ty is not a secure!',
          ClientRequestToken => $secrets_mgr->CreateClientRequestToken
        }
      );

    } ## end if ( !grep {/my-secret/...})
    
    my $new_secret = encode_json({ a => 'b', b => 'a'});

    $secrets_mgr->UpdateSecret(
        { SecretId           => 'my-secret',
          SecretString       => $new_secret,
          ClientRequestToken => $secrets_mgr->CreateClientRequestToken
        }
      );
    
   print Dumper($secrets_mgr->GetSecretValue({ SecretId => 'my-secret' })->{SecretString});
  }
}

=pod

=head1 NAME

C<Amazon::SecretsManager>

=head1 SYNOPSIS


  my $secrets_mgr = Amazon::SecretsManager->new;
  
  my $secret_list = $secrets_mgr->ListSecrets->{SecretList};
      
  $secrets_mgr->CreateSecret(
      { Name               => 'my-secret',
        SecretString       => '$ecur1ty is not a secure!',
        ClientRequestToken => $secrets_mgr->CreateClientRequestToken
      }
    );
    
  $secrets_mgr->UpdateSecret(
      { SecretId           => 'my-secret',
        SecretString       => $new_secret,
        ClientRequestToken => $secrets_mgr->CreateClientRequestToken
      }
    );



( run in 1.462 second using v1.01-cache-2.11-cpan-39bf76dae61 )