NAME

Net::Amazon::SNS::Signature

DESCRIPTION

For the verification of Amazon SNS messages

USAGE

# Will download the signature certificate from SigningCertURL attribute of $message_ref
# use LWP::UserAgent
my $sns_signature = Net::Amazon::SNS::Signature->new();
if ( $sns_signature->verify( $message_ref ) ){ ... }

# Will automatically download the certificate using your own user_agent ( supports ->get returns HTTP::Response )
my $sns_signature = Net::Amazon::SNS::Signature->new( user_agent => $my_user_agent );
if ( $sns_signature->verify( $message_ref ) ){ ... }

# Provide the certificate yourself
my $sns_signature = Net::Amazon::SNS::Signature->new()
if ( $sns_signature->verify({ message => $message_ref, certificate => $x509_cert }) ) { ... }

verify

Call to verify the message, $message is required as first parameter, $cert is optional and should be a raw x509 certificate as downloaded from Amazon.

build_sign_string

Given a $message_ref will return a formatted string ready to be signed.

Usage:

my $sign_string = $this->build_sign_string({
    Message     => 'Hello',
    MessageId   => '12345',
    Subject     => 'I am a message',
    Timestamp   => '2016-01-20T14:37:01Z',
    TopicArn    => 'xyz123',
    Type        => 'Notification'
});