diff options
author | ivan <ivan> | 2009-12-31 13:16:41 +0000 |
---|---|---|
committer | ivan <ivan> | 2009-12-31 13:16:41 +0000 |
commit | 63a268637b2d51a8766412617724b9436439deb6 (patch) | |
tree | a50f6d4c7829d5c80905e989144317192a44dc90 /rt/lib/RT/Shredder/Plugin/Base/Search.pm | |
parent | 65a561e3cd8c1ba94f6282f5d2a1cd9783afbd21 (diff) | |
parent | b4b0c7e72d7eaee2fbfc7022022c9698323203dd (diff) |
This commit was generated by cvs2svn to compensate for changes in r8690,
which included commits to RCS files with non-trunk default branches.
Diffstat (limited to 'rt/lib/RT/Shredder/Plugin/Base/Search.pm')
-rw-r--r-- | rt/lib/RT/Shredder/Plugin/Base/Search.pm | 142 |
1 files changed, 142 insertions, 0 deletions
diff --git a/rt/lib/RT/Shredder/Plugin/Base/Search.pm b/rt/lib/RT/Shredder/Plugin/Base/Search.pm new file mode 100644 index 000000000..21de15982 --- /dev/null +++ b/rt/lib/RT/Shredder/Plugin/Base/Search.pm @@ -0,0 +1,142 @@ +# BEGIN BPS TAGGED BLOCK {{{ +# +# COPYRIGHT: +# +# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC +# <jesse@bestpractical.com> +# +# (Except where explicitly superseded by other copyright notices) +# +# +# LICENSE: +# +# This work is made available to you under the terms of Version 2 of +# the GNU General Public License. A copy of that license should have +# been provided with this software, but in any event can be snarfed +# from www.gnu.org. +# +# This work is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +# General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA +# 02110-1301 or visit their web page on the internet at +# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html. +# +# +# CONTRIBUTION SUBMISSION POLICY: +# +# (The following paragraph is not intended to limit the rights granted +# to you to modify and distribute this software under the terms of +# the GNU General Public License and is only of importance to you if +# you choose to contribute your changes and enhancements to the +# community by submitting them to Best Practical Solutions, LLC.) +# +# By intentionally submitting any modifications, corrections or +# derivatives to this work, or any other work intended for use with +# Request Tracker, to Best Practical Solutions, LLC, you confirm that +# you are the copyright holder for those contributions and you grant +# Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable, +# royalty-free, perpetual, license to use, copy, create derivative +# works based on those contributions, and sublicense and distribute +# those contributions and any derivatives thereof. +# +# END BPS TAGGED BLOCK }}} + +package RT::Shredder::Plugin::Base::Search; + +use strict; +use warnings FATAL => 'all'; + +use base qw(RT::Shredder::Plugin::Base); + +=head1 NAME + +RT::Shredder::Plugin::Base - base class for Shredder plugins. + +=cut + +sub Type { return 'search' } + +=head1 ARGUMENTS + +Arguments which all plugins support. + +=head2 limit - unsigned integer + +Allow you to limit search results. B<< Default value is C<10> >>. + +=head1 METHODS + +=cut + +sub SupportArgs +{ + my %seen; + return sort + grep $_ && !$seen{$_}, + shift->SUPER::SupportArgs(@_), + qw(limit); +} + +sub TestArgs +{ + my $self = shift; + my %args = @_; + if( defined $args{'limit'} && $args{'limit'} ne '' ) { + my $limit = $args{'limit'}; + $limit =~ s/[^0-9]//g; + unless( $args{'limit'} eq $limit ) { + return( 0, "'limit' should be an unsigned integer"); + } + $args{'limit'} = $limit; + } else { + $args{'limit'} = 10; + } + return $self->SUPER::TestArgs( %args ); +} + +sub SetResolvers { return 1 } + + +=head2 FetchNext $collection [, $init] + +Returns next object in collection as method L<RT::SearchBuilder/Next>, but +doesn't stop on page boundaries. + +When method is called with true C<$init> arg it enables pages on collection +and selects first page. + +Main purpose of this method is to avoid loading of whole collection into +memory as RT does by default when pager is not used. This method init paging +on the collection, but doesn't stop when reach page end. + +Example: + + $plugin->FetchNext( $tickets, 'init' ); + while( my $ticket = $plugin->FetchNext( $tickets ) ) { + ... + } + +=cut + +use constant PAGE_SIZE => 100; +sub FetchNext { + my ($self, $objs, $init) = @_; + if ( $init ) { + $objs->RowsPerPage( PAGE_SIZE ); + $objs->FirstPage; + return; + } + + my $obj = $objs->Next; + return $obj if $obj; + $objs->NextPage; + return $objs->Next; +} + +1; + |