1 # BEGIN BPS TAGGED BLOCK {{{
5 # This software is Copyright (c) 1996-2005 Best Practical Solutions, LLC
6 # <jesse@bestpractical.com>
8 # (Except where explicitly superseded by other copyright notices)
13 # This work is made available to you under the terms of Version 2 of
14 # the GNU General Public License. A copy of that license should have
15 # been provided with this software, but in any event can be snarfed
18 # This work is distributed in the hope that it will be useful, but
19 # WITHOUT ANY WARRANTY; without even the implied warranty of
20 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
21 # General Public License for more details.
23 # You should have received a copy of the GNU General Public License
24 # along with this program; if not, write to the Free Software
25 # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
28 # CONTRIBUTION SUBMISSION POLICY:
30 # (The following paragraph is not intended to limit the rights granted
31 # to you to modify and distribute this software under the terms of
32 # the GNU General Public License and is only of importance to you if
33 # you choose to contribute your changes and enhancements to the
34 # community by submitting them to Best Practical Solutions, LLC.)
36 # By intentionally submitting any modifications, corrections or
37 # derivatives to this work, or any other work intended for use with
38 # Request Tracker, to Best Practical Solutions, LLC, you confirm that
39 # you are the copyright holder for those contributions and you grant
40 # Best Practical Solutions, LLC a nonexclusive, worldwide, irrevocable,
41 # royalty-free, perpetual, license to use, copy, create derivative
42 # works based on those contributions, and sublicense and distribute
43 # those contributions and any derivatives thereof.
45 # END BPS TAGGED BLOCK }}}
49 RT::ScripCondition - RT scrip conditional
53 use RT::ScripCondition;
58 This module should never be called directly by client code. it's an internal module which
59 should only be accessed through exported APIs in other modules.
64 ok (require RT::ScripCondition);
73 package RT::ScripCondition;
76 no warnings qw(redefine);
82 $self->{'table'} = "ScripConditions";
83 return ($self->SUPER::_Init(@_));
90 my %Cols = ( Name => 'read',
91 Description => 'read',
92 ApplicableTransTypes => 'read',
95 Creator => 'read/auto',
96 Created => 'read/auto',
97 LastUpdatedBy => 'read/auto',
98 LastUpdated => 'read/auto'
100 return($self->SUPER::_Accessible(@_, %Cols));
108 Takes a hash. Creates a new Condition entry.
109 should be better documented.
115 return($self->SUPER::Create(@_));
123 No API available for deleting things just yet.
129 return(0, $self->loc('Unimplemented'));
135 =head2 Load IDENTIFIER
137 Loads a condition takes a name or ScripCondition id.
143 my $identifier = shift;
145 unless (defined $identifier) {
149 if ($identifier !~ /\D/) {
150 return ($self->SUPER::LoadById($identifier));
153 return ($self->LoadByCol('Name', $identifier));
158 # {{{ sub LoadCondition
160 =head2 LoadCondition HASH
162 takes a hash which has the following elements: TransactionObj and TicketObj.
163 Loads the Condition module in question.
170 my %args = ( TransactionObj => undef,
174 #TODO: Put this in an eval
175 $self->ExecModule =~ /^(\w+)$/;
177 my $type = "RT::Condition::". $module;
179 eval "require $type" || die "Require of $type failed.\n$@\n";
181 $self->{'Condition'} = $type->new ( 'ScripConditionObj' => $self,
182 'TicketObj' => $args{'TicketObj'},
183 'ScripObj' => $args{'ScripObj'},
184 'TransactionObj' => $args{'TransactionObj'},
185 'Argument' => $self->Argument,
186 'ApplicableTransTypes' => $self->ApplicableTransTypes,
187 CurrentUser => $self->CurrentUser
192 # {{{ The following methods call the Condition object
199 Helper method to call the condition module\'s Describe method.
205 return ($self->{'Condition'}->Describe());
210 # {{{ sub IsApplicable
214 Helper method to call the condition module\'s IsApplicable method.
220 return ($self->{'Condition'}->IsApplicable());
230 $self->{'Condition'} = undef;