Some SIP devices need access to item fields that are not sent as item information in the checkin, checkout and item information responses.
It makes sense to allow these fields to be sent in an arbitrary and configurable way, rather than hard code in each special case.
Test Plan:
1) Apply this patch
2) Edit your SIP2 config file, add the following within the login stanza:
<item_field field="XX" code="<item field 1>" />
<item_field field="XZ" code="<item fied 2>" />
where <item field 1> and <item field 2> are item table columns of your choosing
3) Using the sip cli emulator, run checkout, checkin and item information
messages using that item.
4) Note the values you set for the item columns are sent in the
corrosponding fields!
Signed-off-by: Jill Kleven <jill.kleven@pueblolibrary.org>
Fixed merge conflict with number of tests (was 5, changed to 7 which is correct)
Signed-off-by: Joonas Kylmälä <joonas.kylmala@helsinki.fi>
Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
use Template;
use C4::SIP::ILS::Transaction;
+use C4::SIP::Sip qw(add_field);
use C4::Debug;
use C4::Context;
$self->{'collection_code'} = $item->ccode;
$self->{ 'call_number' } = $item->itemcallnumber;
+ $self->{object} = $item;
+
my $it = $item->effective_itemtype;
my $itemtype = Koha::Database->new()->schema()->resultset('Itemtype')->find( $it );
$self->{sip_media_type} = $itemtype->sip_media_type() if $itemtype;
}
return ModReserveFill($hold);
}
+
+=head2 build_additional_item_fields_string
+
+This method builds the part of the sip message for additional item fields
+to send in the item related message responses
+
+=cut
+
+sub build_additional_item_fields_string {
+ my ( $self, $server ) = @_;
+
+ my $string = q{};
+
+ if ( $server->{account}->{item_field} ) {
+ my @fields_to_send =
+ ref $server->{account}->{item_field} eq "ARRAY"
+ ? @{ $server->{account}->{item_field} }
+ : ( $server->{account}->{item_field} );
+
+ foreach my $f ( @fields_to_send ) {
+ my $code = $f->{code};
+ my $value = $self->{object}->$code;
+ $string .= add_field( $f->{field}, $value );
+ }
+ }
+
+ return $string;
+}
+
1;
__END__
}
}
+ $resp .= $item->build_additional_item_fields_string( $server ) if $item;
+
if ( $protocol_version >= 2 ) {
# Financials : return irrespective of ok status
if ($item) {
$resp .= add_field( FID_PERM_LOCN, $item->permanent_location, $server );
$resp .= maybe_add( FID_TITLE_ID, $item->title_id, $server );
+ $resp .= $item->build_additional_item_fields_string( $server );
}
if ( $protocol_version >= 2 ) {
$resp .= maybe_add( FID_SCREEN_MSG, $item->screen_msg, $server );
$resp .= maybe_add( FID_PRINT_LINE, $item->print_line, $server );
+
+ $resp .= $item->build_additional_item_fields_string( $server );
}
$self->write_msg( $resp, undef, $server->{account}->{terminator}, $server->{account}->{encoding} );
<screen_msg_regex find="Greetings from Koha." replace="Welcome to your library!" />
<screen_msg_regex find="Invalid patron barcode." replace="Barcode not found, are you sure this is your library card?" />
<patron_attribute field="XY" code="CODE" />
+ <item_field field="ZY" code="permanent_location" />
<syspref_overrides>
<AllFinesNeedOverride>0</AllFinesNeedOverride>
</syspref_overrides>
# along with Koha; if not, see <http://www.gnu.org/licenses>.
use Modern::Perl;
-use Test::More tests => 6;
+use Test::More tests => 7;
use Test::MockObject;
use Test::MockModule;
use Test::Warn;
$schema->storage->txn_rollback;
};
+
+subtest "Test build_additional_item_fields_string" => sub {
+ my $schema = Koha::Database->new->schema;
+ $schema->storage->txn_begin;
+
+ plan tests => 2;
+
+ my $builder = t::lib::TestBuilder->new();
+
+ my $item = $builder->build( { source => 'Item' } );
+ my $ils_item = C4::SIP::ILS::Item->new( $item->{barcode} );
+
+ my $server = {};
+ $server->{account}->{item_field}->{code} = 'itemnumber';
+ $server->{account}->{item_field}->{field} = 'XY';
+ my $attribute_string = $ils_item->build_additional_item_fields_string( $server );
+ is( $attribute_string, "XY$item->{itemnumber}|", 'Attribute field generated correctly with single param' );
+
+ $server = {};
+ $server->{account}->{item_field}->[0]->{code} = 'itemnumber';
+ $server->{account}->{item_field}->[0]->{field} = 'XY';
+ $server->{account}->{item_field}->[1]->{code} = 'biblionumber';
+ $server->{account}->{item_field}->[1]->{field} = 'YZ';
+ $attribute_string = $ils_item->build_additional_item_fields_string( $server );
+ is( $attribute_string, "XY$item->{itemnumber}|YZ$item->{biblionumber}|", 'Attribute field generated correctly with multiple params' );
+
+ $schema->storage->txn_rollback;
+};
+
# Here is room for some more subtests
# END of main code