1 package NCIP::Handler::AcceptItem;
5 NCIP::Handler::AcceptItem
9 Not to be called directly, NCIP::Handler will pick the appropriate Handler
10 object, given a message type
20 our @ISA = qw(NCIP::Handler);
26 my $root = $xmldoc->documentElement();
27 my $xpc = XML::LibXML::XPathContext->new;
28 $xpc->registerNs( 'ns', $self->namespace() );
29 my $itemid = $xpc->findnodes( '//ns:ItemId', $root );
32 my $accepted = $self->ils->acceptitem($itemid);
35 my ( $from, $to ) = $self->get_agencies($xmldoc);
37 # we switch these for the templates
38 # because we are responding, to becomes from, from becomes to
39 $vars->{'fromagency'} = $to;
40 $vars->{'toagency'} = $from;
42 $vars->{'messagetype'} = 'AcceptItemResponse';
43 $vars->{'barcode'} = $itemid;
44 if ( !$accepted->{success} ) {
45 $vars->{'processingerror'} = 1;
46 $vars->{'processingerrortype'} = $accepted->{'messages'};
47 $vars->{'processingerrorelement'} = 'UniqueItemIdentifier';
48 $output = $self->render_output( 'problem.tt', $vars );
51 my $elements = $self->get_user_elements($xmldoc);
52 $vars->{'elements'} = $elements;
53 $vars->{'accept'} = $accepted;
54 $output = $self->render_output( 'response.tt', $vars );