summaryrefslogtreecommitdiff
path: root/httemplate/edit/process/quick-cust_pkg.cgi
blob: 2fde17f5ea1a32868e5aedafb5a3edf18197b5d4 (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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
%if ($error) {
%  $cgi->param('error', $error);
<% $cgi->redirect(popurl(3). 'misc/order_pkg.html?'. $cgi->query_string ) %>
%} else {
%  my $frag = "cust_pkg". $cust_pkg->pkgnum;
%  my $show = $curuser->default_customer_view =~ /^(jumbo|packages)$/
%               ? ''
%               : ';show=packages';
<% header('Package ordered') %>
  <SCRIPT TYPE="text/javascript">
    // XXX fancy ajax rebuild table at some point, but a page reload will do for now

    // XXX chop off trailing #target and replace... ?
    window.top.location = '<% popurl(3). "view/cust_main.cgi?custnum=$custnum$show;fragment=$frag#$frag" %>';

  </SCRIPT>

  </BODY></HTML>
%}
<%init>

my $curuser = $FS::CurrentUser::CurrentUser;

die "access denied"
  unless $curuser->access_right('Order customer package');

#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;
$cgi->param('discountnum') =~ /^(\-?\d*)$/
  or die 'illegal discountnum '. $cgi->param('discountnum');
my $discountnum = $1;


my $cust_pkg = new FS::cust_pkg {
  'custnum'              => $custnum,
  'pkgpart'              => $pkgpart,
  'start_date'           => ( scalar($cgi->param('start_date'))
                                ? parse_datetime($cgi->param('start_date'))
                                : ''
                            ),
  'no_auto'              => scalar($cgi->param('no_auto')),
  'refnum'               => $refnum,
  'locationnum'          => $locationnum,
  'discountnum'          => $discountnum,
  #for the create a new discount case
  'discountnum__type'    => scalar($cgi->param('discountnum__type')),
  'discountnum_amount'   => scalar($cgi->param('discountnum_amount')),
  'discountnum_percent'  => scalar($cgi->param('discountnum_percent')),
  'discountnum_months'   => scalar($cgi->param('discountnum_months')),
  #'discountnum_disabled' => scalar($cgi->param('discountnum_disabled')),
};

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>