summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Wells <mark@freeside.biz>2016-10-13 20:31:59 -0700
committerMark Wells <mark@freeside.biz>2016-10-14 09:37:50 -0700
commit756185797d569c5bbd3a541a55bb8c33b1b7cabc (patch)
treec621426c319cc5b73470e43703408d1319338df4
parent44f6ba635e70aa9a1a60ef6d2d046535d719ef3f (diff)
script to manually initialize events, #72949
-rwxr-xr-xbin/initialize-event68
1 files changed, 68 insertions, 0 deletions
diff --git a/bin/initialize-event b/bin/initialize-event
new file mode 100755
index 000000000..f186e195f
--- /dev/null
+++ b/bin/initialize-event
@@ -0,0 +1,68 @@
+#!/usr/bin/perl
+
+use FS::Misc::Getopt;
+use FS::part_event;
+use FS::cust_event;
+use FS::Record 'dbdef';
+use FS::Cursor;
+
+getopts('e:x');
+
+my $eventpart = $opt{e};
+my $part_event = FS::part_event->by_key($opt{e})
+ or die "usage: initialize-event -e <eventpart> <username>\n";
+
+
+my $eventtable = $part_event->eventtable;
+my $pkey = dbdef->table($eventtable)->primary_key;
+my $from = " LEFT JOIN (SELECT DISTINCT tablenum AS $pkey FROM cust_event
+ WHERE eventpart = $eventpart) AS done USING ($pkey)",
+my $where = " WHERE done.$pkey IS NULL";
+
+my $count = FS::Record->scalar_sql("SELECT COUNT(*) FROM $eventtable $from $where");
+print "Event ".$part_event->event."\n".
+ "Will initialize on $count $eventtable records.\n";
+if (!$opt{x}) {
+ print "Run with -x to make changes.\n";
+ exit;
+}
+
+
+print "Disabling event.\n";
+$part_event->disabled('Y');
+my $error = $part_event->replace;
+die $error if $error;
+my $cursor = FS::Cursor->new({
+ table => $eventtable,
+ addl_from => $from,
+ extra_sql => $where,
+});
+my $user = $FS::CurrentUser::CurrentUser->username;
+my $statustext = "Manually by $user";
+while (my $record = $cursor->fetch) {
+ my $cust_event = FS::cust_event->new({
+ status => 'initial',
+ eventpart => $eventpart,
+ tablenum => $record->get($pkey),
+ _date => $^T,
+ statustext => $statustext,
+ });
+ $error = $cust_event->insert;
+ if ($error) {
+ print "$eventtable #".$record->get($pkey).": $error\n" if $error;
+ } else {
+ $count--;
+ }
+}
+print "$count unprocessed records.";
+if ($count == 0) {
+ print "Re-enabling event.\n";
+ $part_event->disabled('');
+ $error = $part_event->replace;
+ die $error if $error;
+} else {
+ print "Event is still disabled.\n";
+}
+
+print "Finished.\n";
+