[freeside-commits] freeside/httemplate/edit/process quick-cust_pkg.cgi, 1.12, 1.13
Ivan,,,
ivan at wavetail.420.am
Fri Jan 9 16:43:08 PST 2009
- Previous message: [freeside-commits] freeside/FS/FS Conf.pm, 1.257, 1.258 cust_pkg.pm, 1.106, 1.107 cust_main.pm, 1.396, 1.397
- Next message: [freeside-commits] freeside/httemplate/elements tr-select-cust_location.html, NONE, 1.1 location.html, 1.1, 1.2
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
Update of /home/cvs/cvsroot/freeside/httemplate/edit/process
In directory wavetail.420.am:/tmp/cvs-serv22996/httemplate/edit/process
Modified Files:
quick-cust_pkg.cgi
Log Message:
more work on package service addresses: hide locations when they're all the default, config to show them anyway / finish implementing package ordering, fix all the state/county weirdness when changing the location dropdown. RT#4499
Index: quick-cust_pkg.cgi
===================================================================
RCS file: /home/cvs/cvsroot/freeside/httemplate/edit/process/quick-cust_pkg.cgi,v
retrieving revision 1.12
retrieving revision 1.13
diff -u -d -r1.12 -r1.13
--- quick-cust_pkg.cgi 29 Mar 2008 06:42:17 -0000 1.12
+++ quick-cust_pkg.cgi 10 Jan 2009 00:43:06 -0000 1.13
@@ -2,7 +2,7 @@
% $cgi->param('error', $error);
<% $cgi->redirect(popurl(3). 'misc/order_pkg.html?'. $cgi->query_string ) %>
%} else {
-% my $frag = "cust_pkg". $cust_pkg[0]->pkgnum;
+% my $frag = "cust_pkg". $cust_pkg->pkgnum;
<% header('Package ordered') %>
<SCRIPT TYPE="text/javascript">
// XXX fancy ajax rebuild table at some point, but a page reload will do for now
@@ -19,15 +19,45 @@
die "access denied"
unless $FS::CurrentUser::CurrentUser->access_right('Order customer package');
-#untaint custnum
+#untaint custnum (probably not necessary, searching for it is escape enough)
$cgi->param('custnum') =~ /^(\d+)$/
or die 'illegal custnum '. $cgi->param('custnum');
my $custnum = $1;
+my $cust_main = qsearchs({
+ 'table' => 'cust_main',
+ 'hashref' => { 'custnum' => $custnum },
+ 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
+});
+die 'unknown custnum' unless $cust_main;
+
+#probably not necessary, taken care of by cust_pkg::check
$cgi->param('pkgpart') =~ /^(\d+)$/
or die 'illegal pkgpart '. $cgi->param('pkgpart');
my $pkgpart = $1;
+$cgi->param('refnum') =~ /^(\d*)$/
+ or die 'illegal refnum '. $cgi->param('refnum');
+my $refnum = $1;
+$cgi->param('locationnum') =~ /^(\-?\d*)$/
+ or die 'illegal locationnum '. $cgi->param('locationnum');
+my $locationnum = $1;
-my @cust_pkg = ();
-my $error = FS::cust_pkg::order($custnum, [ $pkgpart ], [], \@cust_pkg, [ $cgi->param('refnum') ] );
+my $cust_pkg = new FS::cust_pkg {
+ 'custnum' => $custnum,
+ 'pkgpart' => $pkgpart,
+ 'refnum' => $refnum,
+ 'locationnum' => $locationnum,
+};
+
+my %opt = ( 'cust_pkg' => $cust_pkg );
+
+if ( $locationnum == -1 ) {
+ my $cust_location = new FS::cust_location {
+ map { $_ => scalar($cgi->param($_)) }
+ qw( custnum address1 address2 city county state zip country )
+ };
+ $opt{'cust_location'} = $cust_location;
+}
+
+my $error = $cust_main->order_pkg( %opt );
</%init>
- Previous message: [freeside-commits] freeside/FS/FS Conf.pm, 1.257, 1.258 cust_pkg.pm, 1.106, 1.107 cust_main.pm, 1.396, 1.397
- Next message: [freeside-commits] freeside/httemplate/elements tr-select-cust_location.html, NONE, 1.1 location.html, 1.1, 1.2
- Messages sorted by:
[ date ]
[ thread ]
[ subject ]
[ author ]
More information about the freeside-commits
mailing list