X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=htdocs%2Fedit%2Fprocess%2Fpart_pkg.cgi;h=3ec31589a0ad3d0761993855dccbca0acd0718aa;hb=c116ce940c33dcd7e37a87a8eb2936e17cc68b11;hp=78ed696138ebbc045db6a0d28ee14cdd4fbb9aca;hpb=61f2610ee6b8660a206a05675899ed72a5e59296;p=freeside.git diff --git a/htdocs/edit/process/part_pkg.cgi b/htdocs/edit/process/part_pkg.cgi index 78ed69613..3ec31589a 100755 --- a/htdocs/edit/process/part_pkg.cgi +++ b/htdocs/edit/process/part_pkg.cgi @@ -1,6 +1,6 @@ #!/usr/bin/perl -Tw # -# $Id: part_pkg.cgi,v 1.2 1998-11-15 13:16:15 ivan Exp $ +# $Id: part_pkg.cgi,v 1.7 1999-01-19 05:13:55 ivan Exp $ # # process/part_pkg.cgi: Edit package definitions (process form) # @@ -17,30 +17,47 @@ # lose background, FS::CGI ivan@sisd.com 98-sep-2 # # $Log: part_pkg.cgi,v $ -# Revision 1.2 1998-11-15 13:16:15 ivan +# Revision 1.7 1999-01-19 05:13:55 ivan +# for mod_perl: no more top-level my() variables; use vars instead +# also the last s/create/new/; +# +# Revision 1.6 1999/01/18 22:47:56 ivan +# s/create/new/g; and use fields('table_name') +# +# Revision 1.5 1998/12/30 23:03:29 ivan +# bugfixes; fields isn't exported by derived classes +# +# Revision 1.4 1998/12/17 08:40:24 ivan +# s/CGI::Request/CGI.pm/; etc +# +# Revision 1.3 1998/11/21 07:17:58 ivan +# bugfix to work for regular aswell as custom pricing +# +# Revision 1.2 1998/11/15 13:16:15 ivan # first pass as per-user custom pricing # use strict; +use vars qw( $cgi $pkgpart $old $new $part_svc ); use CGI; use CGI::Carp qw(fatalsToBrowser); use FS::UID qw(cgisuidsetup); use FS::CGI qw(eidiot popurl); -use FS::Record qw(qsearch qsearchs); -use FS::part_pkg qw(fields); +use FS::Record qw(qsearch qsearchs fields); +use FS::part_pkg; use FS::pkg_svc; use FS::cust_pkg; -my($cgi)=new CGI; +$cgi = new CGI; &cgisuidsetup($cgi); -my($pkgpart)=$cgi->param('pkgpart'); +$pkgpart = $cgi->param('pkgpart'); -my($old)=qsearchs('part_pkg',{'pkgpart'=>$pkgpart}) if $pkgpart; +$old = qsearchs('part_pkg',{'pkgpart'=>$pkgpart}) if $pkgpart; -my($new)=create FS::part_pkg ( { +$new = new FS::part_pkg ( { map { - $_, $cgi->param($_); + $_, scalar($cgi->param($_)); } fields('part_pkg') } ); @@ -59,7 +76,6 @@ if ( $pkgpart ) { $pkgpart=$new->getfield('pkgpart'); } -my($part_svc); foreach $part_svc (qsearch('part_svc',{})) { # don't update non-changing records in part_svc (causing harmless but annoying # "Records identical" errors). ivan@sisd.com 98-jan-19 @@ -71,7 +87,7 @@ foreach $part_svc (qsearch('part_svc',{})) { }); my($old_quantity)=$old_pkg_svc ? $old_pkg_svc->quantity : 0; next unless $old_quantity != $quantity; #!here - my($new_pkg_svc)=create FS::pkg_svc({ + my($new_pkg_svc)=new FS::pkg_svc({ 'pkgpart' => $pkgpart, 'svcpart' => $part_svc->getfield('svcpart'), #'quantity' => $cgi->param('pkg_svc'. $part_svc->getfield('svcpart')), @@ -86,18 +102,16 @@ foreach $part_svc (qsearch('part_svc',{})) { } } -unless ( $cgi->param('pkgnum') =~ /^(\d+)$/ ) { - #$req->cgi->redirect("../../view/part_pkg.cgi?$pkgpart"); - #$req->cgi->redirect("../../edit/part_pkg.cgi?$pkgpart"); - $cgi->redirect("../../browse/part_pkg.cgi"); +unless ( $cgi->param('pkgnum') && $cgi->param('pkgnum') =~ /^(\d+)$/ ) { + print $cgi->redirect(popurl(3). "browse/part_pkg.cgi"); } else { my($old_cust_pkg) = qsearchs( 'cust_pkg', { 'pkgnum' => $1 } ); my %hash = $old_cust_pkg->hash; $hash{'pkgpart'} = $pkgpart; - my($new_cust_pkg) = create FS::cust_pkg \%hash; + my($new_cust_pkg) = new FS::cust_pkg \%hash; my $error = $new_cust_pkg->replace($old_cust_pkg); eidiot "Error modifying cust_pkg record: $error\n" if $error; - print $cgi->redirect(popurl(3). "/view/cust_main.cgi?". $new_cust_pkg->custnum); + print $cgi->redirect(popurl(3). "view/cust_main.cgi?". $new_cust_pkg->custnum); }