X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Flib%2FRT%2FAction%2FAutoOpen.pm;h=e819ca9897f860e54569a1ce7e63903393a25697;hb=45d35d5739d05e602bc317739485693e0e9ff0b5;hp=e1cf0ae7cc8f5ea7f8f133be82d3da099b61ef19;hpb=63a268637b2d51a8766412617724b9436439deb6;p=freeside.git diff --git a/rt/lib/RT/Action/AutoOpen.pm b/rt/lib/RT/Action/AutoOpen.pm index e1cf0ae7c..e819ca989 100644 --- a/rt/lib/RT/Action/AutoOpen.pm +++ b/rt/lib/RT/Action/AutoOpen.pm @@ -1,40 +1,40 @@ # BEGIN BPS TAGGED BLOCK {{{ -# +# # COPYRIGHT: -# -# This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC -# -# +# +# This software is Copyright (c) 1996-2014 Best Practical Solutions, LLC +# +# # (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 @@ -43,7 +43,7 @@ # 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 }}} # This Action will open the BASE if a dependent is resolved. @@ -51,55 +51,67 @@ package RT::Action::AutoOpen; use strict; use warnings; - use base qw(RT::Action); =head1 DESCRIPTION -Opens a ticket unless it's allready open, but only unless transaction -L. +This action automatically moves a ticket to an active status. + +Status is not changed if there is no active statuses in the lifecycle. + +Status is not changed if the current status is first active for ticket's status +lifecycle. For example if ticket's status is 'processing' and active statuses are +'processing', 'on hold' and 'waiting' then status is not changed, but for ticket +with status 'on hold' other rules are checked. + +Status is not changed if it's in the list of C statuses for the +current scheme and creator of the current transaction +is one of the ticket's requestors. -Doesn't open a ticket if message's head has field C with -C substring. +Status is not changed if message's head has field C with C +substring. + +Status is set to the first possible active status. If the ticket's +status is C then RT finds all possible transitions from C +status and selects first one that results in the ticket having an +active status. =cut sub Prepare { my $self = shift; - # if the ticket is already open or the ticket is new and the message is more mail from the - # requestor, don't reopen it. + my $ticket = $self->TicketObj; + my $next = $ticket->FirstActiveStatus; + return 1 unless defined $next; - my $status = $self->TicketObj->Status; - return undef if $status eq 'open'; - return undef if $status eq 'new' && $self->TransactionObj->IsInbound; + # no change if the ticket is in initial status and the message is a mail + # from a requestor + return 1 if $ticket->QueueObj->Lifecycle->IsInitial($ticket->Status) + && $self->TransactionObj->IsInbound; if ( my $msg = $self->TransactionObj->Message->First ) { - return undef if ($msg->GetHeader('RT-Control') || '') =~ /\bno-autoopen\b/i; + return 1 if ($msg->GetHeader('RT-Control') || '') =~ /\bno-autoopen\b/i; } + $self->{'set_status_to'} = $next; + return 1; } sub Commit { my $self = shift; - my $oldstatus = $self->TicketObj->Status; - $self->TicketObj->__Set( Field => 'Status', Value => 'open' ); - $self->TicketObj->_NewTransaction( - Type => 'Status', - Field => 'Status', - OldValue => $oldstatus, - NewValue => 'open', - Data => 'Ticket auto-opened on incoming correspondence' - ); + return 1 unless my $new_status = $self->{'set_status_to'}; + my ($val, $msg) = $self->TicketObj->SetStatus( $new_status ); + unless ( $val ) { + $RT::Logger->error( "Couldn't auto-open ticket: ". $msg ); + return 0; + } return 1; } -eval "require RT::Action::AutoOpen_Vendor"; -die $@ if ($@ && $@ !~ qr{^Can't locate RT/Action/AutoOpen_Vendor.pm}); -eval "require RT::Action::AutoOpen_Local"; -die $@ if ($@ && $@ !~ qr{^Can't locate RT/Action/AutoOpen_Local.pm}); +RT::Base->_ImportOverlays(); 1;