The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

NAME

Mongoose::Class - sugary Mongoose-oriented replacement for Moose

SYNOPSIS

    package MySchema::Person;
    use Mongoose::Class; # uses Moose for you
    with 'Mongoose::Document';

    has 'name'          => ( is => 'rw', isa => 'Str' );
    has_many 'siblings' => ( is => 'rw', isa => 'Person' );
    belongs_to 'club'   => ( is => 'rw', isa => 'Club' );
    has_one 'father'    => ( is => 'rw', isa => 'Person' );

DESCRIPTION

This is very much a work-in-progress.

Basically, this module adds some sugar into your Mongoose Document class by defining some stand-in replacements for Moose's own has.

    has_many
    has_one
    belongs_to

The idea: fewer keystrokes and improved readability by self-documenting your class.

METHODS

has_one

Wrapper around Moose's own has, but allows for a shorter syntax:

    has_one 'name';            # isa=>'Any', is=>'rw' added
    has_one 'age' => 'Num';    # is=>'rw' added
    has_one 'age' => 'Num', default=>99;

belongs_to

It's the same as using has_one from above. It exists to improve your code expressiveness.

has_many

Wraps the defined relationship with another class using Mongoose::Join.

This:

    has_many 'employees' => ( isa=>'Employee' );

    # or

    has_many 'employees' => 'Employee';

Becomes this:

    has 'employees' => (
        is      => 'ro',
        isa     => 'Mongoose::Join[Employee]',
        default => sub { Mongoose::Join->new( with_class=>'Employee' ) }
    );