From df4a87d4a69761715791a10cbf94383af345350d Mon Sep 17 00:00:00 2001 From: Kyle M Hall Date: Mon, 6 Mar 2017 12:05:31 +0000 Subject: [PATCH] Bug 18104 - allow SIP2 field AE (personal name ) to be customized Koha's SIP2 server sends the patron's name in the format "Firstname Surname" which is not very good for machine reading. We need to allow the format of the patron name to be customized in a manner similar to what is done with the DA field on bug 16755. Test Plan: 1) Apply this patch, start or restart your SIP server 2) Find a patron with a first and last name 3) Send a patron information request via the sip2 cli tool 4) Note the AE field has the format " " ( i.e. the current behavior ) 5) Add this parameter to the login stanza you are using: ae_field_template="[% patron.surname %][% IF patron.firstname %], [% patron.firstname %][% END %]" 6) Restart your SIP server 7) Repeat step 3 8) Note the AE field now has the format ", " Signed-off-by: Kyle M Hall Signed-off-by: Benjamin Daeuber Signed-off-by: Marcel de Rooy Signed-off-by: Jonathan Druart --- C4/SIP/ILS/Patron.pm | 20 ++++++++++++++++++++ C4/SIP/Sip/MsgType.pm | 6 +++--- etc/SIPconfig.xml | 1 + 3 files changed, 24 insertions(+), 3 deletions(-) diff --git a/C4/SIP/ILS/Patron.pm b/C4/SIP/ILS/Patron.pm index 64ef4f6817..391926b06c 100644 --- a/C4/SIP/ILS/Patron.pm +++ b/C4/SIP/ILS/Patron.pm @@ -191,6 +191,26 @@ sub AUTOLOAD { } } +sub name { + my ( $self, $template ) = @_; + + if ($template) { + require Template; + require Koha::Patrons; + + my $tt = Template->new(); + + my $patron = Koha::Patrons->find( $self->{borrowernumber} ); + + my $output; + $tt->process( \$template, { patron => $patron }, \$output ); + return $output; + } + else { + return $self->{name}; + } +} + sub check_password { my ( $self, $pwd ) = @_; diff --git a/C4/SIP/Sip/MsgType.pm b/C4/SIP/Sip/MsgType.pm index f3815cf92b..dded51e22c 100644 --- a/C4/SIP/Sip/MsgType.pm +++ b/C4/SIP/Sip/MsgType.pm @@ -420,7 +420,7 @@ sub build_patron_status { $resp .= patron_status_string($patron); $resp .= $lang . timestamp(); - $resp .= add_field( FID_PERSONAL_NAME, $patron->name ); + $resp .= add_field( FID_PERSONAL_NAME, $patron->name( $server->{account}->{ae_field_template} ) ); # while the patron ID we got from the SC is valid, let's # use the one returned from the ILS, just in case... @@ -948,7 +948,7 @@ sub handle_patron_info { # while the patron ID we got from the SC is valid, let's # use the one returned from the ILS, just in case... $resp .= add_field( FID_PATRON_ID, $patron->id ); - $resp .= add_field( FID_PERSONAL_NAME, $patron->name ); + $resp .= add_field( FID_PERSONAL_NAME, $patron->name( $server->{account}->{ae_field_template} ) ); # TODO: add code for the fields # hold items limit @@ -1246,7 +1246,7 @@ sub handle_patron_enable { $resp .= $patron->language . timestamp(); $resp .= add_field( FID_PATRON_ID, $patron->id ); - $resp .= add_field( FID_PERSONAL_NAME, $patron->name ); + $resp .= add_field( FID_PERSONAL_NAME, $patron->name( $server->{account}->{ae_field_template} ) ); if ( defined($patron_pwd) ) { $resp .= add_field( FID_VALID_PATRON_PWD, sipbool( $patron->check_password($patron_pwd) ) ); } diff --git a/etc/SIPconfig.xml b/etc/SIPconfig.xml index 80f667e30f..f51f0938b5 100644 --- a/etc/SIPconfig.xml +++ b/etc/SIPconfig.xml @@ -51,6 +51,7 @@