1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153
|
package MooseX::Storage::Util;
use Moose qw(confess blessed);
use MooseX::Storage::Engine ();
use utf8 ();
our $VERSION = '0.31';
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__
=pod
=head1 NAME
MooseX::Storage::Util - A MooseX::Storage swiss-army chainsaw
=head1 DESCRIPTION
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.
=head1 METHODS
All the methods in this package are class methods and should
be called appropriately.
=over 4
=item B<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 C<$data> can be either a perl HASH ref or some kind of serialized
data (JSON, YAML, etc.).
The C<%options> are as follows:
=over 4
=item I<format>
If this is left blank, we assume that C<$data> is a plain perl HASH ref
otherwise we attempt to inflate C<$data> based on the value of this option.
Currently only JSON and YAML are supported here.
=item I<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.
=back
=back
=head2 Introspection
=over 4
=item B<meta>
=back
=head1 TODO
Add more stuff to this module :)
=head1 BUGS
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.
=head1 AUTHOR
Stevan Little E<lt>stevan.little@iinteractive.comE<gt>
=head1 COPYRIGHT AND LICENSE
Copyright 2007-2008 by Infinity Interactive, Inc.
L<http://www.iinteractive.com>
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.
=cut
|