# BEGIN LICENSE BLOCK # # Copyright (c) 1996-2003 Jesse Vincent # # (Except where explictly superceded by other copyright notices) # # 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. # # Unless otherwise specified, all modifications, corrections or # extensions to this work which alter its source code become the # property of Best Practical Solutions, LLC when submitted for # inclusion in the work. # # # END LICENSE BLOCK =head1 NAME RT::Condition::Generic - ; =head1 SYNOPSIS use RT::Condition::Generic; my $foo = new RT::Condition::IsApplicable( TransactionObj => $tr, TicketObj => $ti, ScripObj => $scr, Argument => $arg, Type => $type); if ($foo->IsApplicable) { # do something } =head1 DESCRIPTION =head1 METHODS =begin testing ok (require RT::Condition::Generic); =end testing =cut package RT::Condition::Generic; use RT::Base; use strict; use vars qw/@ISA/; @ISA = qw(RT::Base); # {{{ sub new sub new { my $proto = shift; my $class = ref($proto) || $proto; my $self = {}; bless ($self, $class); $self->_Init(@_); return $self; } # }}} # {{{ sub _Init sub _Init { my $self = shift; my %args = ( TransactionObj => undef, TicketObj => undef, ScripObj => undef, TemplateObj => undef, Argument => undef, ApplicableTransTypes => undef, @_ ); $self->{'Argument'} = $args{'Argument'}; $self->{'ScripObj'} = $args{'ScripObj'}; $self->{'TicketObj'} = $args{'TicketObj'}; $self->{'TransactionObj'} = $args{'TransactionObj'}; $self->{'ApplicableTransTypes'} = $args{'ApplicableTransTypes'}; } # }}} # Access Scripwide data # {{{ sub Argument =head2 Argument Return the optional argument associated with this ScripCondition =cut sub Argument { my $self = shift; return($self->{'Argument'}); } # }}} # {{{ sub TicketObj =head2 TicketObj Return the ticket object we're talking about =cut sub TicketObj { my $self = shift; return($self->{'TicketObj'}); } # }}} # {{{ sub ScripObj =head2 ScripObj Return the Scrip object we're talking about =cut sub ScripObj { my $self = shift; return($self->{'ScripObj'}); } # }}} # {{{ sub TransactionObj =head2 TransactionObj Return the transaction object we're talking about =cut sub TransactionObj { my $self = shift; return($self->{'TransactionObj'}); } # }}} # {{{ sub Type =head2 Type =cut sub ApplicableTransTypes { my $self = shift; return($self->{'ApplicableTransTypes'}); } # }}} # Scrip methods #What does this type of Action does # {{{ sub Describe sub Describe { my $self = shift; return ($self->loc("No description for [_1]", ref $self)); } # }}} #Parse the templates, get things ready to go. #If this rule applies to this transaction, return true. # {{{ sub IsApplicable sub IsApplicable { my $self = shift; return(undef); } # }}} # {{{ sub DESTROY sub DESTROY { my $self = shift; # We need to clean up all the references that might maybe get # oddly circular $self->{'TemplateObj'} =undef $self->{'TicketObj'} = undef; $self->{'TransactionObj'} = undef; $self->{'ScripObj'} = undef; } # }}} eval "require RT::Condition::Generic_Vendor"; die $@ if ($@ && $@ !~ qr{^Can't locate RT/Condition/Generic_Vendor.pm}); eval "require RT::Condition::Generic_Local"; die $@ if ($@ && $@ !~ qr{^Can't locate RT/Condition/Generic_Local.pm}); 1;