diff options
author | Mark Wells <mark@freeside.biz> | 2016-10-13 20:31:59 -0700 |
---|---|---|
committer | Mark Wells <mark@freeside.biz> | 2016-10-14 09:37:50 -0700 |
commit | 756185797d569c5bbd3a541a55bb8c33b1b7cabc (patch) | |
tree | c621426c319cc5b73470e43703408d1319338df4 | |
parent | 44f6ba635e70aa9a1a60ef6d2d046535d719ef3f (diff) |
script to manually initialize events, #72949
-rwxr-xr-x | bin/initialize-event | 68 |
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"; + |