X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fedit%2Fprocess%2Fpart_pkg.cgi;h=5d9c2355b847a4d1e6ef963722b7eab4cd3a07b0;hb=d6dbf288fd8ea42ebd5171d80817356248cf22ce;hp=1158222b638665e8d29736d61c9f5ddce8b9c1d8;hpb=1d719ccff55b1a82208fdf44b6dcd2da96b3c42e;p=freeside.git diff --git a/httemplate/edit/process/part_pkg.cgi b/httemplate/edit/process/part_pkg.cgi index 1158222b6..5d9c2355b 100755 --- a/httemplate/edit/process/part_pkg.cgi +++ b/httemplate/edit/process/part_pkg.cgi @@ -1,16 +1,30 @@ % % %my $dbh = dbh; +%my $conf = new FS::Conf; % %my $pkgpart = $cgi->param('pkgpart'); % %my $old = qsearchs('part_pkg',{'pkgpart'=>$pkgpart}) if $pkgpart; % +%tie my %plans, 'Tie::IxHash', %{ FS::part_pkg::plan_info() }; +%my $href = $plans{$cgi->param('plan')}->{'fields'}; +% %#fixup plandata +%my $error; %my $plandata = $cgi->param('plandata'); %my @plandata = split(',', $plandata); %$cgi->param('plandata', -% join('', map { "$_=". join(', ', $cgi->param($_)). "\n" } @plandata ) +% join('', map { my $parser = sub { shift }; +% $parser = $href->{$_}{parse} if exists($href->{$_}{parse}); +% my $value = join(', ', &$parser($cgi->param($_))); +% my $check = $href->{$_}{check}; +% if ( $check && ! &$check($value) ) { +% $value = join(', ', $cgi->param($_)); +% $error ||= "Illegal ". ($href->{$_}{name}||$_). ": $value"; +% } +% "$_=$value\n"; +% } @plandata ) %); % %foreach (qw( setuptax recurtax disabled )) { @@ -29,13 +43,19 @@ % } fields('part_pkg') %} ); % +%my $oldAutoCommit = $FS::UID::AutoCommit; +%local $FS::UID::AutoCommit = 0; +% %my %pkg_svc = map { $_ => scalar($cgi->param("pkg_svc$_")) } % map { $_->svcpart } % qsearch('part_svc', {} ); % -%my $error; %my $custnum = ''; -%if ( $cgi->param('taxclass') eq '(select)' ) { +%if ( $error ) { +% +% # fall through +% +%} elsif ( $cgi->param('taxclass') eq '(select)' ) { % % $error = 'Must select a tax class'; % @@ -55,7 +75,7 @@ % $pkgpart = $new->pkgpart; %} % -%unless ($error) { +%unless ( $error || $conf->exists('agent_defaultpkg') ) { % my $error = $new->process_m2m( % 'link_table' => 'type_pkgs', % 'target_table' => 'agent_type', @@ -63,11 +83,14 @@ % ); %} %if ( $error ) { +% $dbh->rollback if $oldAutoCommit; % $cgi->param('error', $error ); % print $cgi->redirect(popurl(2). "part_pkg.cgi?". $cgi->query_string ); %} elsif ( $custnum ) { +% $dbh->commit or die $dbh->errstr if $oldAutoCommit; % print $cgi->redirect(popurl(3). "view/cust_main.cgi?$custnum"); %} else { +% $dbh->commit or die $dbh->errstr if $oldAutoCommit; % print $cgi->redirect(popurl(3). "browse/part_pkg.cgi"); %} %