MooseX::Storage::Util - A MooseX::Storage swiss-army chainsaw


MooseX-Storage documentation Contained in the MooseX-Storage distribution.

Index


Code Index:

NAME

Top

MooseX::Storage::Util - A MooseX::Storage swiss-army chainsaw

DESCRIPTION

Top

This module provides a set of tools, some sharp and focused, others more blunt and crude. But no matter what, they are useful bits to have around when dealing with MooseX::Storage code.

METHODS

Top

All the methods in this package are class methods and should be called appropriately.

peek ($data, %options)

This method will help you to verify that the serialized class you have gotten is what you expect it to be before you actually unfreeze/unpack it.

The $data can be either a perl HASH ref or some kind of serialized data (JSON, YAML, etc.).

The %options are as follows:

format

If this is left blank, we assume that $data is a plain perl HASH ref otherwise we attempt to inflate $data based on the value of this option.

Currently only JSON and YAML are supported here.

key

The default is to try and extract the class name, but if you want to check another key in the data, you can set this option. It will return the value found in the key for you.

Introspection

meta

TODO

Top

Add more stuff to this module :)

BUGS

Top

All complex software has bugs lurking in it, and this module is no exception. If you find a bug please either email me, or add the bug to cpan-RT.

AUTHOR

Top

Stevan Little <stevan.little@iinteractive.com>

COPYRIGHT AND LICENSE

Top


MooseX-Storage documentation Contained in the MooseX-Storage distribution.

package MooseX::Storage::Util;
use Moose qw(confess blessed);

use MooseX::Storage::Engine ();
use utf8 ();

our $VERSION   = '0.30';
our $AUTHORITY = 'cpan:STEVAN';

sub peek {
    my ($class, $data, %options) = @_;

    if (exists $options{'format'}) {

        my $inflater = $class->can('_inflate_' . lc($options{'format'}));

        (defined $inflater)
            || confess "No inflater found for " . $options{'format'};

        $data = $class->$inflater($data);
    }

    (ref($data) && ref($data) eq 'HASH' && !blessed($data))
        || confess "The data has to be a HASH reference, but not blessed";

    $options{'key'} ||= $MooseX::Storage::Engine::CLASS_MARKER;

    return $data->{$options{'key'}};

}

sub _inflate_json {
    my ($class, $json) = @_;

    eval { require JSON::Any; JSON::Any->import };
    confess "Could not load JSON module because : $@" if $@;

    utf8::encode($json) if utf8::is_utf8($json);

    my $data = eval { JSON::Any->jsonToObj($json) };
    if ($@) {
        confess "There was an error when attempting to peek at JSON: $@";
    }

    return $data;
}

sub _inflate_yaml {
    my ($class, $yaml) = @_;

    require Best;
    eval { Best->import([[ qw[YAML::Syck YAML] ]]) };
    confess "Could not load YAML module because : $@" if $@;

    my $inflater = Best->which('YAML::Syck')->can('Load');

    (defined $inflater)
        || confess "Could not load the YAML inflator";

    my $data = eval { $inflater->($yaml) };
    if ($@) {
        confess "There was an error when attempting to peek at YAML : $@";
    }
    return $data;
}

no Moose::Role;

1;

__END__