NAME
Net::API::Stripe::Generic - A Stripe Generic Module
VERSION
v0.101.0
DESCRIPTION
This is a module inherited by all other Net::API::Stripe modules. Its purpose is to provide some shared methods and special object instantiation procedure with some key properties set such as _parent and _field.
CONSTRUCTOR
new( %ARG )
Creates a new Net::API::Stripe::Fraud object. It may also take an hash like arguments, that also are method of the same name.
Possible parameters are:
- _parent The parent calling object
- _field The field or property name this object is associated with
- _error
- debug Integer. A debug level.
- _dbh A Database handler, if any
- _init_strict_use_sub Boolean set for method init in Module::Generic. When set to true, only parameters that have a corresponding method will be accepted.
METHODS
field
Set/get the field to which this object is associated
parent
Set/get the parent (caller) of this object.
TO_JSON
Returns a stringified version of this object if the method as_string exists or is inherited, otherwise it just returns the object itself.
_address_populate
Provided with an Net::API::Stripe::Address object, and this will set the fields line, line2, city, postal_code, state and country to address_line, address_line2, address_city, address_zip, address_state and address_country.
This is used in Net::API::Stripe::Payment::Source and Net::API::Stripe::Connect::ExternalAccount::Card
_get_base_class
Get the base class of the object
_instantiate_object( field, class )
Provided with a field aka property name and a class name and this method creates an object.
If the object is already instantiated, it returns it.
Otherwise, it will attempt to load the given class using _load_class from Module::Generic or return undef and set an error if an error occurred.
_object_type_to_class( type )
Provided with a Stripe object type such as charge or invoice or customer, this method will return the equivalent Net::API::Stripe module package name.
_set_get_hash( field, hash )
Provided with a field (aka property) name and a hash reference, and this method will call method _set_get_hash_as_object from Module::Generic to create an hash whose properties can be accessed as methods of an object. So:
$o->name
instead of:
$o->{name}
_set_get_number( field, number )
Provided with a field (aka property) and a number, this will create a new Module::Generic::Number object for the associated field field
_set_get_object_array( field, class, array reference )
Provided with a field (aka property) name, a class (package name) and an array reference, and this method will instantiate an object for each array entry.
It returns an array reference for this field
_set_get_object_variant( field, hash or array reference )
Provided with a field (aka property) name and an hash or array reference and this method will instantiate an object if the data provided is an hash reference or it will instantiate an array of objects if the data provided is an array reference.
_set_get_scalar_or_object_variant( field, scalar, hash or array reference )
Provided with a scalar, an hash reference or an array reference and this will set the value for this field accordingly.
If this is just a scalar, the scalar value will be set for the field. If the data is an hash reference or an array reference, the same operation is done as in method _set_get_object_variant
_set_get_uri( field, uri )
Provided with a field (aka a property) and an uri and this will create an URI object for this field
_will
Calls will from the module Module::Generic
HISTORY
v0.100.0
Initial version
AUTHOR
Jacques Deguest <jack@deguest.jp>
SEE ALSO
Net::API::Stripe, Module::Generic, Module::Generic::Number, JSON, URI
COPYRIGHT & LICENSE
Copyright (c) 2019-2020 DEGUEST Pte. Ltd.
You can use, copy, modify and redistribute this package and associated files under the same terms as Perl itself.