From af56c5c5cf0fde61544175edbf901b5313498ea2 Mon Sep 17 00:00:00 2001 From: Bill Erickson Date: Tue, 11 Dec 2012 12:07:37 -0500 Subject: [PATCH] Script to collect CSV notification status responses For 3rd-party services which provide batch notifications status updates via CSV file. The script assumes the action/trigger event definition ID is included in the response and, from there, applyes the "status" value to the async_output of the event definition in question. Signed-off-by: Bill Erickson Signed-off-by: Mike Rylander --- Open-ILS/src/support-scripts/csv_notify_fetcher.pl | 198 +++++++++++++++++++++ 1 file changed, 198 insertions(+) create mode 100755 Open-ILS/src/support-scripts/csv_notify_fetcher.pl diff --git a/Open-ILS/src/support-scripts/csv_notify_fetcher.pl b/Open-ILS/src/support-scripts/csv_notify_fetcher.pl new file mode 100755 index 0000000000..e144bb711d --- /dev/null +++ b/Open-ILS/src/support-scripts/csv_notify_fetcher.pl @@ -0,0 +1,198 @@ +#!/usr/bin/perl +use strict; +use warnings; +use DateTime; +use Getopt::Long; +use OpenSRF::AppSession; +use OpenILS::Utils::CStoreEditor; +use OpenILS::Utils::Fieldmapper; +use OpenILS::Utils::RemoteAccount; +use OpenSRF::Utils::Logger qw/$logger/; + +my $osrf_config = '/openils/conf/opensrf_core.xml'; +my $remote_account = ''; +my $remote_file = ''; +my $local_dir = '/tmp'; # locally stored file directory +my $local_file = ''; # locally stored file name +my $response_file = ''; # local file with response data +my $delete_file = 0; +my $verbose = 0; +my $help = 0; +my $remote_conn = undef; + +GetOptions( + 'osrf-config=s' => \$osrf_config, + 'remote-account=s' => \$remote_account, + 'remote-file=s' => \$remote_file, + 'local-file=s' => \$local_file, + 'local-dir=s' => \$local_dir, + 'response-file=s' => \$response_file, + 'delete-file' => \$delete_file, + 'help' => \$help, + 'verbose' => \$verbose +); + +sub help { + print <bootstrap_client(config_file => $osrf_config); +Fieldmapper->import(IDL => + OpenSRF::Utils::SettingsClient->new->config_value("IDL")); +OpenILS::Utils::CStoreEditor::init(); +my $editor = OpenILS::Utils::CStoreEditor->new; + +if (!$response_file and $remote_account) { + + # fetch data remotely and push the data into $response_file + + my $racct = $editor->retrieve_config_remote_account($remote_account); + die "No such remote account $remote_account" unless $racct; + + my $type; + my $host = $racct->host; + ($host =~ s/^(S?FTP)://i and $type = uc($1)) or + ($host =~ s/^(SSH|SCP)://i and $type = 'SCP'); + $host =~ s#//##; + + if ($local_file) { + # user specified local file name + $response_file = "$local_dir/$local_file"; + } else { + $response_file = File::Temp->new()->filename; + } + + print "Connecting to host $host\n" if $verbose; + + $remote_conn = OpenILS::Utils::RemoteAccount->new( + type => $type, + remote_host => $host, + account_object => $racct, + local_file => $response_file, + remote_file => $remote_file + ); + + my $res = $remote_conn->get; + + die "Unable to fetch from remote server [$remote_account] : " . + $remote_conn->error . "\n" unless $res; + + print "Fetched file $remote_file => $response_file\n" if $verbose; +} + +# at this point, $file contains CSV, because it was already +# there or because we just fetched it from the remote account +open(FILE, $response_file) or + die "Unable to open response file: '$response_file' : $!\n"; + +binmode(FILE, ":utf8"); + +while () { + chomp; + + my ($id, $stat) = /"(.+)","(.+)"/g; + next unless $id and $stat; + + $logger->info("csv: processing event $id; stat $stat"); + + my $event = $editor->retrieve_action_trigger_event($id); + + if (!$event) { + $logger->warn("csv: unable to find event $id"); + next; + } + + if ($event->async_output) { + $logger->info("csv: skipping event $id; async_output already set"); + next; + } + + $editor->xact_begin; + + # store the response output + my $output = Fieldmapper::action_trigger::event_output->new; + $output->data($stat); + + unless ($editor->create_action_trigger_event_output($output)) { + $logger->warn("csv: error creating event ". + "output for event $id: ". $editor->die_event); + next; + } + + # link the async response output to the original event + $event->async_output($output->id); + + unless ($editor->update_action_trigger_event($event)) { + $logger->warn("csv: error updating event $id: ". $editor->die_event); + next; + } + + $editor->xact_commit; +} + +$editor->disconnect; + +if ($delete_file) { + # after we have successfully processed the file, + # delete it from the remote server. + + $remote_conn->delete($remote_file); + + # delete the local file unless the user + # specified a location to save the file + unlink($response_file) unless $local_file; +} -- 2.11.0