X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fmisc%2Fprocess%2Fcancel_pkg.html;h=805d1a711bbaa6bbab1519c08f1335369ae048d4;hp=cd533be101b8407570c77bb10632d9300925ee1b;hb=eb4ff7f73c5d4bdf74a3472448b5a195598ff4cd;hpb=96192f1c88de6f54c856cac650bd2e1338e64fbc diff --git a/httemplate/misc/process/cancel_pkg.html b/httemplate/misc/process/cancel_pkg.html index cd533be10..805d1a711 100755 --- a/httemplate/misc/process/cancel_pkg.html +++ b/httemplate/misc/process/cancel_pkg.html @@ -1,7 +1,23 @@ +<% header("Package $past{$method}") %> + + + +<%once> + +my %past = ( 'cancel' => 'cancelled', + 'expire' => 'expired', + 'suspend' => 'suspended', + 'adjourn' => 'adjourned', + ); + + <%init> + #untaint method my $method = $cgi->param('method'); -$method =~ /^(cancel|expire|suspend)$/ || die "Illegal method"; +$method =~ /^(cancel|expire|suspend|adjourn)$/ || die "Illegal method"; $method = $1; #untaint pkgnum @@ -15,7 +31,7 @@ $reasonnum =~ /^(-?\d+)$/ || die "Illegal reasonnum"; $reasonnum = $1; my $date = time; -if ($method eq 'expire'){ +if ($method eq 'expire' || $method eq 'adjourn'){ #untaint date $date = $cgi->param('date'); str2time($cgi->param('date')) =~ /^(\d+)$/ || die "Illegal date"; @@ -24,55 +40,30 @@ if ($method eq 'expire'){ my $cust_pkg = qsearchs( 'cust_pkg', {'pkgnum'=>$pkgnum} ); -my $oldAutoCommit = $FS::UID::AutoCommit; -local $FS::UID::AutoCommit = 0; -my $dbh = dbh; - -my $otaker = $FS::CurrentUser::CurrentUser->name; -$otaker = $FS::CurrentUser::CurrentUser->username - if ($otaker eq "User, Legacy"); +#my $otaker = $FS::CurrentUser::CurrentUser->name; +#$otaker = $FS::CurrentUser::CurrentUser->username +# if ($otaker eq "User, Legacy"); -my $error = ''; if ($reasonnum == -1) { - - $error = 'Enter a new reason (or select an existing one)' - unless $cgi->param('newreasonnum') !~ /^\s*$/; - - my $reason = new FS::reason({ 'reason_type' => $cgi->param('newreasonnumT'), - 'reason' => $cgi->param('newreasonnum'), - }); - $error ||= $reason->insert; - $reasonnum = $reason->reasonnum - unless $error; + $reasonnum = { + 'typenum' => scalar( $cgi->param('newreasonnumT') ), + 'reason' => scalar( $cgi->param('newreasonnum' ) ), + }; } -unless ($error) { - if ($method eq 'expire'){ - my %hash = $cust_pkg->hash; - $hash{'expire'}=$date; - my $new = new FS::cust_pkg (\%hash); - $error = $new->replace($cust_pkg, 'reason' => $reasonnum); - }else{ - $error = $cust_pkg->$method( 'reason' => $reasonnum ); - } +my $error; +if ($method eq 'expire' || $method eq 'adjourn'){ + my %hash = $cust_pkg->hash; + $hash{$method} = $date; + my $new = new FS::cust_pkg \%hash; + $error = $new->replace($cust_pkg, 'reason' => $reasonnum); +} else { + $error = $cust_pkg->$method( 'reason' => $reasonnum ); } if ($error) { $cgi->param('error', $error); - $dbh->rollback if $oldAutoCommit; print $cgi->redirect(popurl(2). "cancel_pkg.html?". $cgi->query_string ); } -$dbh->commit or die $dbh->errstr if $oldAutoCommit; - - my %past = ( 'cancel' => 'cancelled', - 'expire' => 'expired', - 'suspend' => 'suspended', - ); -<% header("Package $past{$method}") %> - - -