NAME

DustyDB::Record - role for DustyDB models

VERSION

version 0.05

SYNOPSIS

package MyModel;
use DustyDB::Object;

has key name => (
    is  => 'rw',
    isa => 'Str',
);
has description => (
    is => 'rw',
    isa => 'Str',
);

DESCRIPTION

Do not use this class directly. Use DustyDB::Object instead. The attributes and methods shown here are available in any class that uses DustyDB::Object because such classes do this role.

ATTRIBUTES

db

This is a required attribute that must be set to a DustyDB object that will be used to save this. In general, you will never need to set this yourself.

However, if you want to construct your record class directly, you can do something like this.

my $db = DustyDB->new( path => 'foo.db' );
my $object = MyModel->new( db => $db, name => 'foo', description => 'bar' );

METHODS

save

my $key = $self->save;

This method saves the object into the database and returns a key identifying the object. The key is a hash reference created using the attributes that have the DustyDB::Key trait set.

delete

$self->delete;

This method delets the object from the database. This does not invalidate the object in memory or alter it in any other way.

CAVEATS

When creating your models you cannot have an attribute named db or an attribute named class_name. The db name is used directly as an attribute by this role and class_name may be used when storing the data in some cases.