This commit was generated by cvs2svn to compensate for changes in r9232,
[freeside.git] / rt / lib / RT / Approval / Rule / Passed.pm
1 # BEGIN BPS TAGGED BLOCK {{{
2
3 # COPYRIGHT:
4
5 # This software is Copyright (c) 1996-2009 Best Practical Solutions, LLC
6 #                                          <jesse@bestpractical.com>
7
8 # (Except where explicitly superseded by other copyright notices)
9
10
11 # LICENSE:
12
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
16 # from www.gnu.org.
17
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.
22
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., 51 Franklin Street, Fifth Floor, Boston, MA
26 # 02110-1301 or visit their web page on the internet at
27 # http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
28
29
30 # CONTRIBUTION SUBMISSION POLICY:
31
32 # (The following paragraph is not intended to limit the rights granted
33 # to you to modify and distribute this software under the terms of
34 # the GNU General Public License and is only of importance to you if
35 # you choose to contribute your changes and enhancements to the
36 # community by submitting them to Best Practical Solutions, LLC.)
37
38 # By intentionally submitting any modifications, corrections or
39 # derivatives to this work, or any other work intended for use with
40 # Request Tracker, to Best Practical Solutions, LLC, you confirm that
41 # you are the copyright holder for those contributions and you grant
42 # Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
43 # royalty-free, perpetual, license to use, copy, create derivative
44 # works based on those contributions, and sublicense and distribute
45 # those contributions and any derivatives thereof.
46
47 # END BPS TAGGED BLOCK }}}
48
49 package RT::Approval::Rule::Passed;
50 use strict;
51 use warnings;
52 use base 'RT::Approval::Rule';
53
54 use constant Description => "Notify Owner of their ticket has been approved by some or all approvers"; # loc
55
56 sub Prepare {
57     my $self = shift;
58     return unless $self->SUPER::Prepare();
59
60     $self->OnStatusChange('resolved');
61 }
62
63 sub Commit {
64     my $self = shift;
65     my $note;
66     my $t = $self->TicketObj->Transactions;
67
68     while ( my $o = $t->Next ) {
69         next unless $o->Type eq 'Correspond';
70         $note .= $o->Content . "\n" if $o->ContentObj;
71     }
72
73     my ($top) = $self->TicketObj->AllDependedOnBy( Type => 'ticket' );
74     my $links  = $self->TicketObj->DependedOnBy;
75
76     while ( my $link = $links->Next ) {
77         my $obj = $link->BaseObj;
78         next unless $obj->Type eq 'approval';
79
80         for my $other ($obj->AllDependsOn( Type => 'approval' )) {
81             if ( $other->QueueObj->IsActiveStatus( $other->Status ) ) {
82                 $other->__Set(
83                     Field => 'Status',
84                     Value => 'deleted',
85                 );
86             }
87
88         }
89         $obj->SetStatus( Status => 'open', Force => 1 );
90     }
91
92     my $passed = !$top->HasUnresolvedDependencies( Type => 'approval' );
93     my $template = $self->GetTemplate(
94         $passed ? 'All Approvals Passed' : 'Approval Passed',
95         TicketObj => $top,
96         Approval => $self->TicketObj,
97         Approver => $self->TransactionObj->CreatorObj,
98         Notes => $note,
99     ) or die;
100
101     $top->Correspond( MIMEObj => $template->MIMEObj );
102
103     if ($passed) {
104         $self->RunScripAction('Notify Owner', 'Approval Ready for Owner',
105                               TicketObj => $top);
106     }
107
108     return;
109 }
110
111 1;