Provided by: libcatmandu-filestore-perl_1.16-1_all bug

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.