Catmandu
view release on metacpan or search on metacpan
lib/Catmandu/Store.pm view on Meta::CPAN
package Catmandu::Store;
use Catmandu::Sane;
our $VERSION = '1.2025';
use Hash::Util::FieldHash qw(fieldhash);
use Catmandu::Util qw(require_package);
use Moo::Role;
use MooX::Aliases;
use namespace::clean;
with 'Catmandu::Logger';
has bag_class => (is => 'ro', default => sub {ref($_[0]) . '::Bag'},);
has default_bag => (is => 'lazy');
has default_plugins => (is => 'ro', default => sub {[]},);
has default_options => (is => 'ro', default => sub {+{}},);
has bag_options => (is => 'ro', init_arg => 'bags', default => sub {+{}},);
has key_prefix => (is => 'lazy', default => sub {'_'},);
has id_key => (is => 'lazy', alias => 'id_field');
sub key_for {
$_[0]->key_prefix . $_[1];
}
sub _build_id_key {
$_[0]->key_for('id');
}
sub _build_default_bag {
'data';
}
sub new_bag {
my ($self, $name, $opts) = @_;
$opts ||= {};
$opts->{store} = $self;
$opts->{name} = $name // $self->default_bag;
my $default_opts = $self->default_options;
my $bag_opts = $self->bag_options->{$opts->{name}} //= {};
$opts = {%$default_opts, %$bag_opts, %$opts};
my $pkg = require_package(delete($opts->{class}) // $self->bag_class);
my $default_plugins = $self->default_plugins;
my $plugins = delete($opts->{plugins}) // [];
if (@$default_plugins || @$plugins) {
$pkg = $pkg->with_plugins(@$default_plugins, @$plugins);
}
$pkg->new($opts);
}
{
fieldhash my %bag_instances;
sub bags {
my ($self) = @_;
$bag_instances{$self} ||= {};
}
sub bag {
my ($self, $name) = @_;
$name ||= $self->default_bag;
$self->bags->{$name} ||= $self->new_bag($name);
}
}
1;
__END__
=pod
=head1 NAME
Catmandu::Store - Namespace for packages that can make data persistent
=head1 SYNOPSIS
# From the command line
$ catmandu import JSON into MongoDB --database_name 'bibliography' < data.json
$ catmandu export MongoDB --database_name 'bibliography' to YAML
$ catmandu export MongoDB --database_name 'bibliography' --query '{"PublicationYear": "1937"}'
$ catmandu count MongoDB --database_name 'bibliography' --query '{"PublicationYear": "1937"}'
# From Perl
use Catmandu;
my $store = Catmandu->store('MongoDB',database_name => 'bibliography');
my $obj1 = $store->bag->add({ name => 'Patrick' });
printf "obj1 stored as %s\n" , $obj1->{_id};
# Force an id in the store
my $obj2 = $store->bag->add({ _id => 'test123' , name => 'Nicolas' });
my $obj3 = $store->bag->get('test123');
$store->bag->delete('test123');
$store->bag->delete_all;
( run in 0.829 second using v1.01-cache-2.11-cpan-75ffa21a3d4 )