RT# 77160 - added date search on customer timespan report
[freeside.git] / bin / initialize-event
1 #!/usr/bin/perl
2
3 use FS::Misc::Getopt;
4 use FS::part_event;
5 use FS::cust_event;
6 use FS::Record 'dbdef';
7 use FS::Cursor;
8
9 getopts('e:x');
10
11 my $eventpart = $opt{e};
12 my $part_event = FS::part_event->by_key($opt{e})
13   or die "usage: initialize-event -e <eventpart> <username>\n";
14
15
16 my $eventtable = $part_event->eventtable;
17 my $pkey = dbdef->table($eventtable)->primary_key;
18 my $from = " LEFT JOIN (SELECT DISTINCT tablenum AS $pkey FROM cust_event
19                    WHERE eventpart = $eventpart) AS done USING ($pkey)",
20 my $where = " WHERE done.$pkey IS NULL";
21
22 my $count = FS::Record->scalar_sql("SELECT COUNT(*) FROM $eventtable $from $where");
23 print "Event ".$part_event->event."\n".
24       "Will initialize on $count $eventtable records.\n";
25 if (!$opt{x}) {
26   print "Run with -x to make changes.\n";
27   exit;
28 }
29
30
31 print "Disabling event.\n";
32 $part_event->disabled('Y');
33 my $error = $part_event->replace;
34 die $error if $error;
35 my $cursor = FS::Cursor->new({
36   table => $eventtable,
37   addl_from => $from,
38   extra_sql => $where,
39 });
40 my $user = $FS::CurrentUser::CurrentUser->username;
41 my $statustext = "Manually by $user";
42 while (my $record = $cursor->fetch) {
43   my $cust_event = FS::cust_event->new({
44     status      => 'initial',
45     eventpart   => $eventpart,
46     tablenum    => $record->get($pkey),
47     _date       => $^T,
48     statustext  => $statustext,
49   });
50   $error = $cust_event->insert;
51   if ($error) {
52     print "$eventtable #".$record->get($pkey).": $error\n" if $error;
53   } else {
54     $count--;
55   }
56 }
57 print "$count unprocessed records.";
58 if ($count == 0) {
59   print "Re-enabling event.\n";
60   $part_event->disabled('');
61   $error = $part_event->replace;
62   die $error if $error;
63 } else {
64   print "Event is still disabled.\n";
65 }
66
67 print "Finished.\n";
68