NAME

Elastic::Model::Domain - The domain (index or alias) where your docs are stored.

VERSION

version 0.02

SYNOPSIS

Get a domain instance

$domain = $model->domain('myapp');

Create a new doc/object

$user = $domain->new_doc( user => \%args );
$user->save;

# or:

$user = $domain->create( user => \%args);

Retrieve a doc by ID

$user = $domain->get( $type => $id );

$user = $domain->try_get( $type => $id );      # return undef if missing

Check if a doc exists

$bool = $domain->exists( $type => $id );

Delete a doc by ID

$uid = $domain->delete( $type => $id );

$user = $domain->try_delete( $type => $id );   # return undef if missing

Create a view on the current domain

$view = $domain->view(%args);

DESCRIPTION

A "domain" is like a database handle used for CRUD (creating, updating or deleting) individual objects or documents. The $domain->name can be the name of an index or an index alias. A domain can only belong to a single namespace.

NOTE: If $domain->name is an alias, it can only point to a single index.

ATTRIBUTES

name

A $domain->name must be either the name of an index or of an index alias which points to a single index. The index or alias must exist, and must be known to the namespace.

namespace

The Elastic::Model::Namespace object to which this domain belongs.

INSTANTIATOR

new()

$domain = $model->domain_class->new({
    name            => $domain_name,
    namespace       => $namespace,
});

Although documented here, you shouldn't need to call new() yourself. Instead you should use "domain()" in Elastic::Model::Role::Model:

$domain = $model->domain($domain_name);

METHODS

new_doc()

$doc = $domain->new_doc( $type => \%args );

new_doc() will create a new object in the class that maps to type $type, passing %args to new() in the associated class. For instance:

$user = $domain->new_doc(
    user => {
        id   => 1,
        name => 'Clint',
    }
);

create()

$doc = $domain->create( $type => \%args );

This is the equivalent of:

$doc = $domain->new_doc( $type => \%args )->save();

get()

$doc = $domain->get( $type => $id );
$doc = $domain->get( $type => $id, routing => $routing, ... );

Retrieves a doc of type $type with ID $id from index $domain->name or throws an exception if the doc doesn't exist. See "get_doc()" in Elastic::Model::Role::Store for more parameters which can be passed.

try_get()

$doc = $domain->try_get( $type => $id );
$doc = $domain->try_get( $type => $id, routing => $routing, ... );

Retrieves a doc of type $type with ID $id from index $domain->name or returns undef if the doc doesn't exist.

exists()

$bool = $domain->exists( $type => $id );
$bool = $domain->exists( $type => $id, routing => $routing, ... );

Checks if a doc of type $type with ID $id exists in index $domain->name. See "doc_exists()" in Elastic::Model::Role::Store for more parameters which can be passed.

delete()

$uid = $domain->delete( $type => $id );
$uid = $domain->delete( $type => $id, routing => $routing, ... );

Deletes a doc of type $type with ID $id from index $domain->name or throws an exception if the doc doesn't exist. See "delete_doc()" in Elastic::Model::Role::Store for more parameters which can be passed.

try_delete()

$uid = $domain->try_delete( $type => $id );
$uid = $domain->try_delete( $type => $id, routing => $routing, ... );

Deletes a doc of type $type with ID $id from index $domain->name or returns undef if the doc doesn't exist.

view()

$view = $domain->view(%args)

Creates a view with the "domain" in Elastic::Model::View set to $domain->name. A view is used for searching docs in a $domain.

AUTHOR

Clinton Gormley <drtech@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2012 by Clinton Gormley.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.