NAME

Net::Stripe::Simple::Data - collection of methods to augment a JSON hash

VERSION

version 0.001

SYNOPSIS

my $subscription = $stripe->subscriptions(  # API methods give us data objects
    update => {
        customer => $customer,              # a data object as a parameter value
        id       => $subscription,          # and another
        plan     => $spare_plan,            # and another
    }
);

DESCRIPTION

Net::Stripe::Simple::Data is simply a JSON hash with a little magic added to it. Principally, it will autoload any attribute name into an accessor method. So you can say

$data->id

instead of

$data->{id}

This magic is applied recursively, so instead of

$data->{metadata}{foo}

you can type

$data->metadata->foo

This hardly saves any keystrokes but it is arguably easier to read.

The second bit of magic is that the stringification operator is overloaded so that data objects with an id attribute are stringified as their id rather than as

Net::Stripe::Simple::Data=HASH(0xfeefaaf00)

This is useful because Stripe expects to see lots of different ids in its various methods, so you can type

$stripe->subscriptions(
    update => {
        customer => $customer,
        id       => $subscription,
        plan     => $spare_plan,
    }
);

instead of

$stripe->subscriptions(
    update => {
        customer => $customer->id,
        id       => $subscription->id,
        plan     => $spare_plan->id,
    }
);

or worse yet

$stripe->subscriptions(
    update => {
        customer => $customer->{id},
        id       => $subscription->{id},
        plan     => $spare_plan->{id},
    }
);

The 'cmp' operator is overloaded as well so the stringification works mostly as you expect. I.e.,

$data eq $string;

is equivalent to

$string eq $data;

METHODS

$self->unbless

Returns a copy of the data with all the magic stripped away. JSON objects are converted to their stringified form. The intended use of this is prettier debugging dumps.

AUTHORS

  • Grant Street Group <developers@grantstreet.com>

  • David F. Houghton <dfhoughton@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Grant Street Group.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.