NAME

MongoDBx::Tiny - Simple Mongo ORM for Perl

VERSION

Version 0.03

SYNOPSIS

# --------------------
package My::Data;

use MongoDBx::Tiny;

CONNECT_INFO  host => 'localhost', port => 27017;
DATABASE_NAME 'my_data';

# --------------------
package My::Data::Foo;

use MongoDBx::Tiny::Document;

COLLECTION_NAME 'foo';

ESSENTIAL qw/code/;
FIELD 'code', INT, LENGTH(10), DEFAULT('0'), REQUIRED;
FIELD 'name', STR, LENGTH(30), DEFAULT('noname');

# --------------------
package main;

my $tiny = My::Data->new;
$tiny->insert(foo => { code => 123, name => "foo_123"}) or die $!;
my $foo = $tiny->single(foo => { code => 123});
$foo->name('foo_321');
$foo->update;
$foo->remove;

EXPORT

A list of functions that can be exported.

CONNECT_INFO

CONNECT_INFO  host => 'localhost', port => 27017;

DATABASE_NAME

DATABASE_NAME 'my_data';

LOAD_PLUGIN

LOAD_PLUGIN 'One'; # MongoDBx::Tiny::Plugin::One
LOAD_PLUGIN 'Two';
LOAD_PLUGIN '+Class::Name';

SUBROUTINES/METHODS

new

my $tiny = My::Data->new();

# or you can specify connect_info, database_name.
my $tiny = My::Data->new({
    connect_info  => [ host => 'localhost', port => 27017 ],
    database_name => 'my_data',
});

get_connection

returns MongoDB::Connection. you can override how to get connection object.

  sub get_connection {
      my $class = shift;

      return MongoDB::Connection->new(@{$class->CONNECT_INFO}) if !$ENV{PLACK_ENV};

      my $key   = 'some_key';
      if (in_scope_container() and my $con = scope_container($key)) {
          return $con;
      } else {
  	    my $con = MongoDB::Connection->new(@{$class->CONNECT_INFO});
  	    scope_container($key, $con) if in_scope_container();
  	    return $con;
      }
  }

connect_info, database_name

alias to installed value

  my $connect_info  = $tiny->connect_info;

  my $database_name = $tiny->database_name;

connection, database

alias to connection and database object.

  my $connection = $tiny->connection; # MongoDB::Connection object

  my $database   = $tiny->database;   # MongoDB::Database object

cursor_class, validator_class, gridfs_class

override if you want.

  MongoDBx::Tiny::Cursor

  MongoDBx::Tiny::Validator

  MongoDBx::Tiny::GridFS

collection

returns MongoDB::Collection

  $collection = $tiny->collection('collection_name')

connect / disconnect

just (re)connect & disconnect

insert,create

$document_object = $tiny->insert('collection_name' => $document);

single

returns MongoDBx::Tiny::Document object.

  $document_object = $tiny->single('collection_name' => $MongoDB_oid_object);
  
  $tiny->single('collection_name' => $oid_text);
  
  $query = { field => $val };
  $tiny->single('collection_name' => $query);
returns MongoDBx::Tiny::Cursor object.

  $query = { field => $val };
  $cursor = $tiny->search('collection_name' => $query);
  while (my $object = $cursor->next) {
      # warn $object->id;
  }
  
  # list context
  @object = $tiny->search('collection_name' => $query);

update

$tiny->update('collection_name',$query,$document);

remove

$tiny->remove('collection_name',$query);

count

$count_num = $tiny->count('collection_name',$query);

document_to_object

$document_object = $tiny->document_to_object('collection_name',$document);

validate

$validator = $tiny->validate('collecion_name',$document,$opt);

  my $validator = $tiny->validate(
      'foo',
      { code => 123, name => "foo_123"},
      { state => 'insert' }
  );
  my $foo1      = $tiny->insert(
      'foo',
      $validator->document,
      { state => 'insert', no_validate => 1 }
  );
  # erros: [{ field => 'field1', code => 'errorcode', message => 'message1' },,,]
  my @erros         = $validator->erros; 
  
  my @fields        = $validator->errors('field');
  my @error_code    = $validator->errors('code');
  my @error_message = $validator->errors('message');

gridfs

returns MongoDBx::Tiny::GridFS

  $gridfs = $tiny->gridfs();
  
  $gridfs = $tiny->gridfs({database => $mongo_databse_object });
  
  $gridfs = $tiny->gridfs({fields => 'other_filename' });

    my $gridfs = $tiny->gridfs;
    $gridfs->put('/tmp/foo.txt', {"filename" => 'foo.txt' });
    my $foo_txt = $gridfs->get({ filename => 'foo.txt' })->slurp;
    
    $gridfs->put('/tmp/bar.txt','bar.txt');
    my $bar_txt = $gridfs->get('bar.txt')->slurp;

document_class

$document_class_name = $tiny->document_class('collecion_name');

load_plugin

  # --------------------
  
  package MyDB;
  use MongoDBx::Tiny;

  LOAD_PLUGIN('PluginName');
  LOAD_PLUGIN('+Class::Name');
  
  # --------------------
  package MongoDBx::Tiny::Plugin::PluginName;
  use strict;
  use warnings;
  use utf8;
  
  our @EXPORT = qw/function_for_plugin/;
  
  sub function_for_plugin {}
  
  # --------------------
  
  $tiny->function_for_plugin;

process

[EXPERIMENTAL]

  $tiny->process('collecion_name','some',@args);

    $tiny->process('foo','some',$validator,$arg); # just call Data::Foo::process_some
    
    #
    sub process_foo {
        my ($class,$tiny,$validator,$arg) = @_;
    }

set_indexes

[EXPERIMENTAL]

  $tiny->set_indexes('collection_name');

unset_indexes

[EXPERIMENTAL]

  # drop indexes without "_id";
  $tiny->unset_indexes('collection_name');

SEE ALSO

MongoDBx::Tiny::Document
MongoDBx::Tiny::Attributes
MongoDBx::Tiny::Relation
MongoDBx::Tiny::Util
MongoDBx::Tiny::Cursor
MongoDBx::Tiny::Validator
MongoDBx::Tiny::GridFS
MongoDBx::Tiny::GridFS::File
MongoDBx::Tiny::Plugin::SingleByCache

SUPPORT

https://github.com/naoto43/mongodbx-tiny/

AUTHOR

Naoto ISHIKAWA, <toona at seesaa.co.jp>

LICENSE AND COPYRIGHT

Copyright 2013 Naoto ISHIKAWA.

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.