NAME Catmandu::FileStore - Namespace for packages that can make files persistent SYNOPSIS # From the command line # Export a list of all file containers $ catmandu export File::Simple --root t/data to YAML # Export a list of all files in container '1234' $ catmandu export File::Simple --root t/data --bag 1234 to YAML # Add a file to the container '1234' $ catmandu stream /tmp/myfile.txt to File::Simple --root t/data --bag 1234 --id myfile.txt # Download the file 'myfile.txt' from the container '1234' $ catmandu stream File::Simple --root t/data --bag 1234 --id myfile.txt to /tmp/output.txt # Delete the file 'myfile.txt' from the container '1234' $ catmandu delete File::Simple --root t/data --bag 1234 --id myfile.txt # From Perl use Catmandu; my $store = Catmandu->store('File::Simple' , root => 't/data'); # List all containers $store->index->each(sub { my $container = shift; print "%s\n" , $container->{_id}; }); # Add a new container $store->index->add({ _id => '1234' }); # Get the container my $files = $store->index->files('1234'); # Add a file to the container $files->upload(IO::File->new('<foobar.txt'), 'foobar.txt'); my $file = $files->get('foobar.txt'); # Stream the contents of a file $files->stream(IO::File->new('>foobar.txt'), $file); # Delete a file $files->delete('foobar.txt'); # Delete a container $store->index->delete('1234'); DESCRIPTION Each Catmandu::FileStore is a Catmandu::Store and inherits all its methods, A Catmandu::FileStore is package to store and retrieve binary content in an filesystem, memory or a network. A Catmandu::FileStore contains one or more Catmandu::FileBag which is a kind of folder. Each Catmandu::FileBag contains one or more files. One special Catmandu::FileBag is the index and contains the listing of all Catmandu::FileBag in the Catmandu::FileStore. CONFIGURATION index_bag The name of the index bag to use when no bag name is give. The index bag is a bag containing a listing of all Catmandu::FileBag-s in the Store. my $index = $store->index; $index->each(sub { my $bag = shift; printf "%s\n" , $bag->{_id}; }); index_class The default class implementation to use for an index of Catmandu::FileBag-s. By default this is the Catmandu::FileStore implementation with '::Index' added. METHODS bag($name) Create or retieve a bag with name $name. Returns a Catmandu::FileBag. index Returns the index Catmandu::FileBag for the Catmandu::FileStore. my $index = $store->index; # Add a new file container $index->add({ _id => '1234'}); # Anf use it... my $container = $store->bag('1234'); $container->upload(IO::File->new('data.txt') , 'data.txt'); log Return the current logger. Can be used when creating your own Stores. E.g. package Catmandu::Store::Hash; ... sub generator { my ($self) = @_; $self->log->debug("generating record"); ... } See also: Catmandu for activating the logger in your main code. AUTHOR Patrick Hochstenbach, <patrick.hochstenbach at ugent.be> Nicolas Steenlant, <nicolas.steenlant at ugent.be> Nicolas Franck, <nicolas.franck at ugent.be> SEE ALSO Catmandu::Store::File::Simple, Catmandu::Store::File::Memory, Catmandu::FileBag LICENSE AND COPYRIGHT This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License. See http://dev.perl.org/licenses/ for more information.