NAME
MooseX::Types::CreditCard - Moose Types related to Credit Cards
VERSION
version 0.002003
SYNOPSIS
{
package My::CreditCard;
use Moose;
use MooseX::Types::CreditCard qw(
CardNumber
CardSecurityCode
CardExpiration
);
has credit_card => (
isa => CardNumber,
is => 'ro',
coerce => 1,
);
has cvv2 => (
isa => CardSecurityCode,
is => 'ro',
);
has expiration => (
isa => CardExpiration,
is => 'ro',
coerce => 1,
);
__PACKAGE__->meta->make_immutable;
}
my $obj = My::CreditCard->new({
credit_card => '4111111111111111',
cvv2 => '123',
expiration => { month => 10, year => 2013 },
});
DESCRIPTION
This module provides types related to Credit Cards for weak validation.
TYPES
CardNumber
Base Type: Str
It will validate that the number passed to it appears to be a valid credit card number. Please note that this does not mean that the Credit Card is actually valid, only that it appears to be by algorithms defined in Business::CreditCard.
Enabling coerce will strip out any non 0-9
characters from a string allowing for numbers like "4111-1111-1111-1111" to be passed.
CardSecurityCode
Base Type: Str
A Credit Card Security Code is a 3 or 4 digit number. This is also called CSC, CVV, CVC, and CID, depending on the issuing vendor.
head2 CardExpiration
Base Type: DateTime
A Credit Card Expiration Date. It's a DateTime Object and checks to see if the object is equal to the last day of the month, using the month and year stored in the object.
Coerce allows you to create the DateTime object from a HashRef
by passing the keys month
and year
.
ACKNOWLEDGEMENTS
-
For funding initial development
SEE ALSO
BUGS
Please report any bugs or feature requests on the bugtracker website https://github.com/xenoterracide/moosex-types-creditcard/issues
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
AUTHOR
Caleb Cushing <xenoterracide@gmail.com>
COPYRIGHT AND LICENSE
This software is Copyright (c) 2014 by Caleb Cushing.
This is free software, licensed under:
The Artistic License 2.0 (GPL Compatible)