Merge branch 'master' of git.freeside.biz:/home/git/freeside
[freeside.git] / httemplate / edit / process / quick-cust_pkg.cgi
1 %if ($error) {
2 %  $cgi->param('error', $error);
3 <% $cgi->redirect(popurl(3). 'misc/order_pkg.html?'. $cgi->query_string ) %>
4 %} else {
5 %  my $frag = "cust_pkg". $cust_pkg->pkgnum;
6 %  my $show = $curuser->default_customer_view =~ /^(jumbo|packages)$/
7 %               ? ''
8 %               : ';show=packages';
9 %  my $redir_url = popurl(3)
10 %            ."view/cust_main.cgi?custnum=$custnum$show;fragment=$frag#$frag";
11
12 % # for going right to a provision service after ordering a package
13 % if ( $svcpart ) { 
14 %   $redir_url = popurl(3)."edit/".$part_svc->svcdb.".cgi?".
15 %                  "pkgnum=".$cust_pkg->pkgnum. ";svcpart=$svcpart";
16 %   $redir_url .= ";qualnum=$qualnum" if $qualnum;
17 % }
18 <% header('Package ordered') %>
19   <SCRIPT TYPE="text/javascript">
20     // XXX fancy ajax rebuild table at some point, but a page reload will do for now
21
22     // XXX chop off trailing #target and replace... ?
23     window.top.location = '<% $redir_url %>';
24
25   </SCRIPT>
26
27   </BODY></HTML>
28 %}
29 <%init>
30
31 my $curuser = $FS::CurrentUser::CurrentUser;
32
33 die "access denied"
34   unless $curuser->access_right('Order customer package');
35
36 #untaint custnum (probably not necessary, searching for it is escape enough)
37 $cgi->param('custnum') =~ /^(\d+)$/
38   or die 'illegal custnum '. $cgi->param('custnum');
39 my $custnum = $1;
40 my $cust_main = qsearchs({
41   'table'     => 'cust_main',
42   'hashref'   => { 'custnum' => $custnum },
43   'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
44 });
45 die 'unknown custnum' unless $cust_main;
46
47 #probably not necessary, taken care of by cust_pkg::check
48 $cgi->param('pkgpart') =~ /^(\d+)$/
49   or die 'illegal pkgpart '. $cgi->param('pkgpart');
50 my $pkgpart = $1;
51 $cgi->param('quantity') =~ /^(\d+)$/
52   or die 'illegal quantity '. $cgi->param('quantity');
53 my $quantity = $1;
54 $cgi->param('refnum') =~ /^(\d*)$/
55   or die 'illegal refnum '. $cgi->param('refnum');
56 my $refnum = $1;
57 $cgi->param('locationnum') =~ /^(\-?\d*)$/
58   or die 'illegal locationnum '. $cgi->param('locationnum');
59 my $locationnum = $1;
60 $cgi->param('discountnum') =~ /^(\-?\d*)$/
61   or die 'illegal discountnum '. $cgi->param('discountnum');
62 my $discountnum = $1;
63
64 # for going right to a provision service after ordering a package
65 my( $svcpart, $part_svc ) = ( '', '' );
66 if ( $cgi->param('svcpart') ) {
67   $cgi->param('svcpart') =~ /^(\-?\d*)$/
68      or die 'illegal svcpart '. $cgi->param('svcpart');
69   $svcpart = $1;
70   $part_svc = qsearchs('part_svc', { 'svcpart' => $svcpart } )
71     or die "unknown svcpart $svcpart";
72 }
73
74 my $qualnum = '';
75 if ( $cgi->param('qualnum') ) {
76   $cgi->param('qualnum') =~ /^(\d+)$/ or die 'illegal qualnum';
77   $qualnum = $1;
78 }
79
80
81 my $cust_pkg = new FS::cust_pkg {
82   'custnum'              => $custnum,
83   'pkgpart'              => $pkgpart,
84   'quantity'             => $quantity,
85   'start_date'           => ( scalar($cgi->param('start_date'))
86                                 ? parse_datetime($cgi->param('start_date'))
87                                 : ''
88                             ),
89   'no_auto'              => scalar($cgi->param('no_auto')),
90   'refnum'               => $refnum,
91   'locationnum'          => $locationnum,
92   'discountnum'          => $discountnum,
93   #for the create a new discount case
94   'discountnum__type'    => scalar($cgi->param('discountnum__type')),
95   'discountnum_amount'   => scalar($cgi->param('discountnum_amount')),
96   'discountnum_percent'  => scalar($cgi->param('discountnum_percent')),
97   'discountnum_months'   => scalar($cgi->param('discountnum_months')),
98   'discountnum_setup'    => scalar($cgi->param('discountnum_setup')),
99   'contract_end'         => ( scalar($cgi->param('contract_end'))
100                                 ? parse_datetime($cgi->param('contract_end'))
101                                 : ''
102                             ),
103    'waive_setup'         => ( $cgi->param('waive_setup') eq 'Y' ? 'Y' : '' ),
104 };
105
106 my %opt = ( 'cust_pkg' => $cust_pkg );
107
108 if ( $locationnum == -1 ) {
109   my $cust_location = new FS::cust_location {
110     map { $_ => scalar($cgi->param($_)) }
111         qw( custnum address1 address2 city county state zip country geocode )
112   };
113   $opt{'cust_location'} = $cust_location;
114 }
115
116 my $error = $cust_main->order_pkg( \%opt );
117
118 </%init>