3 # Copyright (c) 1996-2003 Jesse Vincent <jesse@bestpractical.com>
5 # (Except where explictly superceded by other copyright notices)
7 # This work is made available to you under the terms of Version 2 of
8 # the GNU General Public License. A copy of that license should have
9 # been provided with this software, but in any event can be snarfed
12 # This work is distributed in the hope that it will be useful, but
13 # WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 # General Public License for more details.
17 # Unless otherwise specified, all modifications, corrections or
18 # extensions to this work which alter its source code become the
19 # property of Best Practical Solutions, LLC when submitted for
20 # inclusion in the work.
26 RT::Queues - a collection of RT::Queue objects
40 ok (require RT::Queues);
47 no warnings qw(redefine);
52 $self->{'table'} = "Queues";
53 $self->{'primary_key'} = "id";
55 # By default, order by name
56 $self->OrderBy( ALIAS => 'main',
60 return ($self->SUPER::_Init(@_));
68 A subclass of DBIx::SearchBuilder::_DoSearch that makes sure that _Disabled rows never get seen unless
69 we're explicitly trying to see them.
76 #unless we really want to find disabled rows, make sure we\'re only finding enabled ones.
77 unless($self->{'find_disabled_rows'}) {
78 $self->LimitToEnabled();
81 return($self->SUPER::_DoSearch(@_));
91 my %args = ( ENTRYAGGREGATOR => 'AND',
93 $self->SUPER::Limit(%args);
101 Returns the next queue that this user can see.
109 my $Queue = $self->SUPER::Next();
110 if ((defined($Queue)) and (ref($Queue))) {
112 if ($Queue->CurrentUserHasRight('SeeQueue')) {
116 #If the user doesn't have the right to show this queue
118 return($self->Next());
121 #if there never was any queue