summaryrefslogtreecommitdiff
path: root/httemplate/misc/process/bulk_cancel_pkg.cgi
blob: def0ad2839347ca83bb8d12a6c25a195c4e8fba2 (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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
% if ($error) {
<% $cgi->redirect(popurl(2)."bulk_cancel_pkg.cgi?".$cgi->query_string ) %>
% }
<% include('/elements/popup-topreload.html', "Packages Cancelled") %>
<%init>

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right('Bulk change customer packages');

my $error;

if (!$error) {

  my %search_hash = ();

  $search_hash{'query'} = $cgi->param('query');

  #scalars
  for (qw( agentnum cust_status cust_main_salesnum salesnum custnum magic status
         custom cust_fields pkgbatch zip reasonnum
         477part 477rownum date 
      )) 
  {
    $search_hash{$_} = $cgi->param($_) if length($cgi->param($_));
  }

  #arrays
  for my $param (qw( pkgpart classnum refnum towernum )) {
    $search_hash{$param} = [ $cgi->param($param) ]
      if grep { $_ eq $param } $cgi->param;
  }

  #scalars that need to be passed if empty
  for my $param (qw( censustract censustract2 )) {
    $search_hash{$param} = $cgi->param($param) || ''
      if grep { $_ eq $param } $cgi->param;
  }

  #location flags (checkboxes)
  my @loc = grep /^\w+$/, $cgi->param('loc');
  $search_hash{"location_$_"} = 1 foreach @loc;

  my $report_option = $cgi->param('report_option');
  $search_hash{report_option} = $report_option if $report_option;

  for my $param (grep /^report_option_any/, $cgi->param) {
    $search_hash{$param} = $cgi->param($param);
  }

  ###
  # parse dates
  ###

  #false laziness w/report_cust_pkg.html and bulk_pkg_increment_bill.cgi
  my %disable = (
    'all'             => {},
    'one-time charge' => { 'last_bill'=>1, 'bill'=>1, 'adjourn'=>1, 'susp'=>1, 'expire'=>1, 'cancel'=>1, },
    'active'          => { 'susp'=>1, 'cancel'=>1 },
    'suspended'       => { 'cancel' => 1 },
    'cancelled'       => {},
    ''                => {},
  );

  foreach my $field (qw( setup last_bill bill adjourn susp expire contract_end change_date cancel active )) {

    $search_hash{$field.'_null'} = scalar( $cgi->param($field.'_null') );

    my($beginning, $ending) = FS::UI::Web::parse_beginning_ending($cgi, $field);

    next if $beginning == 0 && $ending == 4294967295
       or $disable{$cgi->param('status')}->{$field};

    $search_hash{$field} = [ $beginning, $ending ];

  }

  my $sql_query = FS::cust_pkg->search(\%search_hash);
  $sql_query->{'select'} = 'cust_pkg.pkgnum';

  ## set suspend info
  $cgi->param('cancel_reasonnum') =~ /^(\d+)$/ or die "Illegal Reason";
  my $cancel_reasonnum = $1;

  #my $cancel_date = '';
  #if ( $cgi->param('cancel_date') ) {
  #  parse_datetime($cgi->param('cancel_date')) =~ /^(\d+)$/ or die "Illegal date";
  #  $cancel_date = $1;
  #}

  foreach my $pkgnum (map { $_->pkgnum } qsearch($sql_query)) {
    my $cust_pkg = qsearchs('cust_pkg',{'pkgnum'=>$pkgnum});

    $error .= ($error ? ' / ' : '').
              $cust_pkg->cancel('reason'      => $cancel_reasonnum,
                                #'date'        => $cancel_date,
                               );
  }

}

$cgi->param("error", substr($error, 0, 512)); # arbitrary length believed
                                              # suited for all supported
                                              # browsers
</%init>