Group
Extension

Data-Riak-Fast/lib/Data/Riak/Fast/MapReduce/Phase/Link.pm

package Data::Riak::Fast::MapReduce::Phase::Link;
use Mouse;

use JSON::XS ();

# ABSTRACT: Link phase of a MapReduce

with ('Data::Riak::Fast::MapReduce::Phase');

=head1 DESCRIPTION

A map/reduce link phase for Data::Riak::Fast

=head1 SYNOPSIS

  my $lp = Data::Riak::Fast::MapReduce::Phase::Link->new(
    bucket=> "foo",
    tag   => "friend",
    keep  => 0
  );

=head2 bucket

The name of the bucket from which links should be followed.

=cut

has bucket => (
    is => 'rw',
    isa => 'Str',
    predicate => 'has_bucket'
);

has phase => (
    is => 'ro',
    isa => 'Str',
    default => 'link'
);

=head2 tag

The name of the tag of links that should be followed

=cut

has tag => (
    is => 'rw',
    isa => 'Str',
    predicate => 'has_tag'
);

=head1 METHOD
=head2 pack()

Serialize this link phase.

=cut

sub pack {
    my $self = shift;

    my $href = {};

    $href->{keep} = $self->keep ? JSON::XS::true() : JSON::XS::false() if $self->has_keep;
    $href->{bucket} = $self->bucket if $self->has_bucket;
    $href->{tag} = $self->tag if $self->has_tag;

    $href;
}

1;


Powered by Groonga
Maintained by Kenichi Ishigaki <ishigaki@cpan.org>. If you find anything, submit it on GitHub.