install_date TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT NOW()
);
-INSERT INTO config.upgrade_log (version) VALUES ('0305'); -- phasefx
+INSERT INTO config.upgrade_log (version) VALUES ('0306'); -- atz
CREATE TABLE config.bib_source (
id SERIAL PRIMARY KEY,
$$[%- USE date -%]
[%# start JEDI document -%]
[%- BLOCK big_block -%]
-["order", {
- "po_number":[% target.id %],
- "date":"[% date.format(date.now, '%Y%m%d') %]",
- "buyer":[
- {"id":"[% target.ordering_agency.mailing_address.san %]",
- "reference":{"API":"[% target.ordering_agency.mailing_address.san %]"}}
- ],
- "vendor":[
- "[% target.provider.san %]", // [% target.provider.name %] ([% target.provider.id %])
- {"id-qualifier":"91", "reference":{"IA":"[% target.provider.id %]"}, "id":"[% target.provider.san %]"}
- ],
- "currency":"[% target.provider.currency_type %]",
- "items":[
+{
+ "recipient":"[% target.provider.san %]",
+ "sender":"[% target.ordering_agency.mailing_address.san %]",
+ "body": [{
+ "ORDERS":[ "order", {
+ "po_number":[% target.id %],
+ "date":"[% date.format(date.now, '%Y%m%d') %]",
+ "buyer":[{
+ [%- IF target.provider.edi_default.vendcode -%]
+ "id":"[% target.ordering_agency.mailing_address.san _ ' ' _ target.provider.edi_default.vendcode %]",
+ "id-qualifier": 91
+ [%- ELSE -%]
+ "id":"[% target.ordering_agency.mailing_address.san %]"
+ [%- END -%]
+ }],
+ "vendor":[
+ [%- # target.provider.name (target.provider.id) -%]
+ "[% target.provider.san %]",
+ {"id-qualifier": 92, "id":"[% target.provider.id %]"}
+ ],
+ "currency":"[% target.provider.currency_type %]",
+ "items":[
[% FOR li IN target.lineitems %]
{
"identifiers":[
{"id-qualifier":"SA","id":"[% li.id %]"},
- {"id-qualifier":"IB","id":"[% helpers.get_li_attr('isbn', li.attributes) %]"}
+ {"id-qualifier":"IB","id":"[% helpers.get_li_attr('isbn_13', li.attributes) || helpers.get_li_attr('isbn_10', li.attributes) %]"}
],
"price":[% li.estimated_unit_price || '0.00' %],
"desc":[
{"BPH":"[% helpers.get_li_attr('pagination','', li.attributes) %]"}
],
"quantity":[% li.lineitem_details.size %]
- [%-# TODO: lineitem details (later) -%]
- }[% UNLESS loop.last %],[% END -%]
- [%- END %]
- ],
- "line_items":[% target.lineitems.size %]
-}]
+ }[% UNLESS loop.last %],[% END %]
+ [%-# TODO: lineitem details (later) -%]
+ [% END %]
+ ],
+ "line_items":[% target.lineitems.size %]
+ }] [% # close ORDERS array %]
+ }] [% # close body array %]
+}
[% END %]
[% tempo = PROCESS big_block; helpers.escape_json(tempo) %]
$$
--- /dev/null
+BEGIN;
+
+INSERT INTO config.upgrade_log (version) VALUES ('0306'); --atz
+
+UPDATE action_trigger.event_definition SET template =
+$$[%- USE date -%]
+[%# start JEDI document -%]
+[%- BLOCK big_block -%]
+{
+ "recipient":"[% target.provider.san %]",
+ "sender":"[% target.ordering_agency.mailing_address.san %]",
+ "body": [{
+ "ORDERS":[ "order", {
+ "po_number":[% target.id %],
+ "date":"[% date.format(date.now, '%Y%m%d') %]",
+ "buyer":[{
+ [%- IF target.provider.edi_default.vendcode -%]
+ "id":"[% target.ordering_agency.mailing_address.san _ ' ' _ target.provider.edi_default.vendcode %]",
+ "id-qualifier": 91
+ [%- ELSE -%]
+ "id":"[% target.ordering_agency.mailing_address.san %]"
+ [%- END -%]
+ }],
+ "vendor":[
+ [%- # target.provider.name (target.provider.id) -%]
+ "[% target.provider.san %]",
+ {"id-qualifier": 92, "id":"[% target.provider.id %]"}
+ ],
+ "currency":"[% target.provider.currency_type %]",
+ "items":[
+ [% FOR li IN target.lineitems %]
+ {
+ "identifiers":[
+ {"id-qualifier":"SA","id":"[% li.id %]"},
+ {"id-qualifier":"IB","id":"[% helpers.get_li_attr('isbn_13', li.attributes) || helpers.get_li_attr('isbn_10', li.attributes) %]"}
+ ],
+ "price":[% li.estimated_unit_price || '0.00' %],
+ "desc":[
+ {"BTI":"[% helpers.get_li_attr('title', '', li.attributes) %]"},
+ {"BPU":"[% helpers.get_li_attr('publisher', '', li.attributes) %]"},
+ {"BPD":"[% helpers.get_li_attr('pubdate', '', li.attributes) %]"},
+ {"BPH":"[% helpers.get_li_attr('pagination','', li.attributes) %]"}
+ ],
+ "quantity":[% li.lineitem_details.size %]
+ }[% UNLESS loop.last %],[% END %]
+ [%-# TODO: lineitem details (later) -%]
+ [% END %]
+ ],
+ "line_items":[% target.lineitems.size %]
+ }] [% # close ORDERS array %]
+ }] [% # close body array %]
+}
+[% END %]
+[% tempo = PROCESS big_block; helpers.escape_json(tempo) %]
+$$
+WHERE id = 23;
+
+COMMIT;
use Data::Dumper;
use vars qw/$debug/;
-use OpenILS::Utils::CStoreEditor; # needs init() after IDL is loaded (by Cronscript session)
use OpenILS::Utils::Cronscript;
use OpenILS::Utils::Fieldmapper;
use OpenILS::Application::AppUtils;
$debug = 1;
}
-my %opts = (
+my %defaults = (
'quiet' => 0,
'max-batch-size=i' => -1
);
-my $cs = OpenILS::Utils::Cronscript->new(\%opts);
-$cs->session('open-ils.acq') or die "No session created";
+my $cs = OpenILS::Utils::Cronscript->new(\%defaults);
-OpenILS::Utils::CStoreEditor::init();
-
-sub editor {
- my $ed = OpenILS::Utils::CStoreEditor->new(@_) or die "Failed to get new CStoreEditor";
- return $ed;
-}
-
-my $e = editor();
+my $opts = $cs->MyGetOptions();
+my $e = $cs->editor() or die "Failed to get new CStoreEditor";
my $hook = 'acqpo.activated';
my $defs = $e->search_action_trigger_event_definition({
- hook => $hook,
+ hook => $hook,
reactor => 'GeneratePurchaseOrderJEDI',
- active => 't'
+ active => 't'
});
+$opts->{verbose} = 0 if $opts->{quiet};
+
+
# print Dumper($defs);
print "\nHook '$hook' is used in ", scalar(@$defs), " event definition(s):\n";
$Data::Dumper::Indent = 1;
-my $remaining = $cs->first_defined('max-batch-size');
+my $remaining = $opts->{'max-batch-size'};
+
+my $subq = {
+ select => { acqedim => ['purchase_order'] },
+ from => 'acqedim',
+ where => {
+ message_type => 'ORDERS',
+ status => {'!=' => 'retry' },
+ purchase_order => {'!=' => undef }
+ }
+};
+
foreach my $def (@$defs) {
last if $remaining == 0;
printf "%3s - '%s'\n", $def->id, $def->name;
# give me all completed JEDI events that link to purchase_orders
# that have no delivery attempts or are in the retry state
+
my $query = {
select => {atev => ['id']},
- from => 'atev',
- where => {
+ from => 'atev',
+ where => {
event_def => $def->id,
- state => 'complete',
+ state => 'complete',
target => {
- 'not in' => {
- select => {acqedim => ['purchase_order']},
- from => 'acqedim',
- where => {
- message_type => 'ORDERS',
- status => {'!=' => 'retry'}
- }
- }
+ 'not in' => $subq
}
},
order_by => {atev => ['add_time']}
$query->{limit} = $remaining if $remaining > 0;
+ if ($opts->{verbose}) {
+ my $excluded = $e->json_query($subq);
+ print "Excluded: ", scalar(@$excluded), " purchase order(s): ", join("\n", map {Dumper $_} @$excluded), "\n";
+ }
+
my $events = $e->json_query($query);
if(!$events) {
$message->jedi($event->template_output()->data);
print "\ntarget->provider->edi_default->id: ", $target->provider->edi_default->id, "\n";
- print "\nNow calling attempt_translation\n\n";
+ my $logstr2 = sprintf "event %s, PO %s, template_output %s", $_->{id}, $message->purchase_order, $event->template_output->id;
+ printf "\nNow calling attempt_translation for $logstr2\n\n";
unless (OpenILS::Application::Acq::EDI->attempt_translation($message, 1)) {
- print STDERR "ERROR: attempt_translation failed, skipping message\n";
+ print STDERR "ERROR: attempt_translation failed for $logstr2\n";
next;
# The premise here is that if the translator failed, it is better to try again later from a "fresh" fetched file
# than to add a cascade of failing inscrutable copies of the same message(s) to our DB.
}
- print "Writing new message + translation to DB\n";
+ print "Writing new message + translation to DB for $logstr2\n";
$e->xact_begin;
if($message->isnew) {
unless($e->create_acq_edi_message($message)) {
- $logger->error("Error creating acq.edi_message for PO ".$target->id.' : '.$e->die_event);
+ $logger->error("Error creating acq.edi_message for $logstr2: ".$e->die_event);
next;
}
} else {
unless($e->update_acq_edi_message($message)) {
- $logger->error("Error updating acq.edi_message for PO ".$target->id.' : '.$e->die_event);
+ $logger->error("Error updating acq.edi_message for $logstr2: ".$e->die_event);
next;
}
}
$e->xact_commit;
- print "Calling send_core(...)\n";
+ print "Calling send_core(...) for message (", $message->id, ")\n";
my $res = OpenILS::Application::Acq::EDI->send_core($target->provider->edi_default, [$message->id]);
if (@$res) {
my $message_out = shift @$res;