1 package WebPAC::Output::Riak;
6 use base qw/WebPAC::Common WebPAC::Output Class::Accessor/;
7 __PACKAGE__->mk_accessors(qw(
14 use Data::Dump qw/dump/;
20 WebPAC::Output::Riak - feed data into Riak Search
32 my $log = $self->_get_logger;
36 my $bucket = $self->bucket || join('.', $self->database, $self->input || 'webpac2' );
38 $self->{_riak} = Net::Riak->new( host => $self->url );
39 $self->{_bucket} = $self->{_riak}->bucket( $bucket );
40 $self->{_bucket}->set_properties({
41 precommit => [ { mod => 'riak_search_kv_hook', fun => 'precommit' } ],
44 $log->info( $self->url,"/riak/$bucket" );
45 # warn dump($self->{_bucket}->get_properties);
55 Adds one entry to database.
62 my ($self,$id,$ds) = @_;
63 my $log = $self->_get_logger;
65 # $log->debug( 'ds = ', $id, sub { dump($ds) } );
68 $data->{$_} = join(' ', @{ $ds->{$_}->{search} }) foreach
69 map { m/^\d+$/ ? $_ = $_ . '_num' : $_ }
70 # add _num suffix for riak search https://wiki.basho.com/display/RIAK/Riak+Search+-+Schema
71 grep { exists $ds->{$_}->{search} }
74 my $obj = $self->{_bucket}->new_object( $id, $data );
77 $log->debug( 'json = ', $id, sub { dump($data) } );
93 my $log = $self->_get_logger();
95 $log->info('finish ', $self->{_count}, ' documents');
102 Dobrica Pavlinusic, C<< <dpavlin@rot13.org> >>
104 =head1 COPYRIGHT & LICENSE
106 Copyright 2010 Dobrica Pavlinusic, All Rights Reserved.
108 This program is free software; you can redistribute it and/or modify it
109 under the same terms as Perl itself.
113 1; # End of WebPAC::Output::Riak