blob: 817c88087a01c29f5dfa1d619a8daa4686765582 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
%
%
%my $error = '';
%
%#untaint custnum
%$cgi->param('custnum') =~ /^(\d+)$/;
%my $custnum = $1;
%
%my @remove_pkgnums = map {
% /^(\d+)$/ or die "Illegal remove_pkg value!";
% $1;
%} $cgi->param('remove_pkg');
%
%my $error_redirect;
%my @pkgparts;
%if ( $cgi->param('new_pkgpart') =~ /^(\d+)$/ ) { #came from misc/change_pkg.cgi
% $error_redirect = "misc/change_pkg.cgi";
% @pkgparts = ($1);
%} else { #came from edit/cust_pkg.cgi
% $error_redirect = "edit/cust_pkg.cgi";
% foreach my $pkgpart ( map /^pkg(\d+)$/ ? $1 : (), $cgi->param ) {
% if ( $cgi->param("pkg$pkgpart") =~ /^(\d+)$/ ) {
% my $num_pkgs = $1;
% while ( $num_pkgs-- ) {
% push @pkgparts,$pkgpart;
% }
% } else {
% $error = "Illegal quantity";
% last;
% }
% }
%}
%
%$error ||= FS::cust_pkg::order($custnum,\@pkgparts,\@remove_pkgnums);
%
%if ($error) {
% $cgi->param('error', $error);
% print $cgi->redirect(popurl(3). $error_redirect. '?'. $cgi->query_string );
%} else {
% print $cgi->redirect(popurl(3). "view/cust_main.cgi?$custnum");
%}
%
%
|