diff options
Diffstat (limited to 'lib/Net/Riak/Object.pm')
-rw-r--r-- | lib/Net/Riak/Object.pm | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/lib/Net/Riak/Object.pm b/lib/Net/Riak/Object.pm index 7148d4f..aa8fbcd 100644 --- a/lib/Net/Riak/Object.pm +++ b/lib/Net/Riak/Object.pm @@ -5,6 +5,7 @@ package Net::Riak::Object; use Moose; use Scalar::Util; use Net::Riak::Link; +use Data::Dumper; with 'Net::Riak::Role::Replica' => {keys => [qw/r w dw/]}; with 'Net::Riak::Role::Base' => {classes => @@ -23,6 +24,9 @@ has vtag => (is => 'rw', isa => 'Str'); has content_type => (is => 'rw', isa => 'Str', default => 'application/json'); has location => ( is => 'rw', isa => 'Str' ); has _jsonize => (is => 'rw', isa => 'Bool', lazy => 1, default => 1); + +has i2indexes => ( is => 'rw', isa => 'HashRef' ); + has links => ( traits => ['Array'], is => 'rw', @@ -69,6 +73,54 @@ sub store { $self->client->store_object($w, $dw, $self); } +sub add_index { + my($self, $index, $data) = @_; + + if ( defined($index) && defined($data) ) { + my $ref = undef; + if ( defined($self->i2indexes) ) { $ref = $self->i2indexes; } + + if ( length($index) > 4 && $index =~ /^.+_bin$/ && length($data) > 0 ) + { + $ref->{$index} = $data; + + } + if ( length($index) > 4 && $index =~ /^.+_int$/ && $data =~ /^\d+$/ ) + { + $ref->{$index} = $data; + } + $self->i2indexes($ref); + } + $self->i2indexes; +} + +sub remove_index { + my($self, $index, $data) = @_; + if ( defined($index) && defined($data) ) { + if ( defined($self->i2indexes) ) { + my $ref = $self->i2indexes; + + if ( $index =~ /^.+_bin$/ ) { + if ( defined($ref->{$index}) && $ref->{$index} eq $data ) + { + + delete(${$ref}{$index}); + } + $self->i2indexes($ref); + } + if ( $index =~ /^.+_int$/ ) { + if ( defined($ref->{$index}) && $ref->{$index} == $data ) + { + print "Deleting $index\n"; + delete(${$ref}{$index}); + } + $self->i2indexes($ref); + } + print Dumper($ref),"\n"; + } + } +} + sub status { my ($self) = @_; warn "DEPRECATED: status method will be removed in the 0.17 release, please use ->client->status."; |