Bug 23531: fix ILSDI non-implemented but documented parameters
authorArthur Suzuki <arthur.suzuki@biblibre.com>
Tue, 3 Sep 2019 09:08:49 +0000 (11:08 +0200)
committerMartin Renvoize <martin.renvoize@ptfs-europe.com>
Wed, 18 Mar 2020 08:42:31 +0000 (08:42 +0000)
test plan :
1/ Submit a hold through ILSDI with start_date and expiry_date parameters
2/ Verify in Koha those parameters are not applied to the newly created
reserve. Delete reserve.
3/ Apply patch and repeat 1.
4/ Verify the reserve created by same request as 1 now has both dates
applied and visible in Koha.

Signed-off-by: Christophe Croullebois <christophe.croullebois@biblibre.com>
Signed-off-by: Arthur Suzuki <arthur.suzuki@biblibre.com>
Signed-off-by: David Nind <david@davidnind.com>
Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org>
Signed-off-by: Martin Renvoize <martin.renvoize@ptfs-europe.com>

C4/ILSDI/Services.pm
koha-tmpl/opac-tmpl/bootstrap/en/modules/ilsdi.tt
opac/ilsdi.pl

index 1ed424e..23c4022 100644 (file)
@@ -673,9 +673,9 @@ Parameters:
     IP address where the end user request is being placed
   - pickup_location (Optional)
     a branch code indicating the location to which to deliver the item for pickup
-  - needed_before_date (Optional)
-    date after which hold request is no longer needed
-  - pickup_expiry_date (Optional)
+  - start_date (Optional)
+    date after which hold request is no longer needed if the document has not been made available
+  - expiry_date (Optional)
     date after which item returned to shelf if item is not picked up
 
 =cut
@@ -728,6 +728,16 @@ sub HoldTitle {
     return { code => 'libraryNotPickupLocation' } unless $destination->pickup_location;
     return { code => 'cannotBeTransferred' } unless $biblio->can_be_transferred({ to => $destination });
 
+    my $resdate;
+    if ( $cgi->param('start_date') ) {
+        $resdate = $cgi->param('start_date');
+    }
+
+    my $expdate;
+    if ( $cgi->param('expiry_date') ) {
+        $expdate = $cgi->param('expiry_date');
+    }
+
     # Add the reserve
     #    $branch,    $borrowernumber, $biblionumber,
     #    $constraint, $bibitems,  $priority, $resdate, $expdate, $notes,
@@ -735,11 +745,13 @@ sub HoldTitle {
     my $priority= C4::Reserves::CalculatePriority( $biblionumber );
     AddReserve(
         {
-            branch         => $branch,
-            borrowernumber => $borrowernumber,
-            biblionumber   => $biblionumber,
-            priority       => $priority,
-            title          => $title,
+            branch           => $branch,
+            borrowernumber   => $borrowernumber,
+            biblionumber     => $biblionumber,
+            priority         => $priority,
+            reservation_date => $resdate,
+            expiration_date  => $expdate,
+            title            => $title,
         }
     );
 
@@ -769,9 +781,9 @@ Parameters:
     an itemnumber
   - pickup_location (Optional)
     a branch code indicating the location to which to deliver the item for pickup
-  - needed_before_date (Optional)
-    date after which hold request is no longer needed
-  - pickup_expiry_date (Optional)
+  - start_date (Optional)
+    date after which hold request is no longer needed if the item has not been made available
+  - expiry_date (Optional)
     date after which item returned to shelf if item is not picked up
 
 =cut
@@ -815,16 +827,28 @@ sub HoldItem {
     my $canitembereserved = C4::Reserves::CanItemBeReserved( $borrowernumber, $itemnumber, $branch )->{status};
     return { code => $canitembereserved } unless $canitembereserved eq 'OK';
 
+    my $resdate;
+    if ( $cgi->param('start_date') ) {
+        $resdate = $cgi->param('start_date');
+    }
+
+    my $expdate;
+    if ( $cgi->param('expiry_date') ) {
+        $expdate = $cgi->param('expiry_date');
+    }
+
     # Add the reserve
     my $priority = C4::Reserves::CalculatePriority($biblionumber);
     AddReserve(
         {
-            branch         => $branch,
-            borrowernumber => $borrowernumber,
-            biblionumber   => $biblionumber,
-            priority       => $priority,
-            title          => $title,
-            itemnumber     => $itemnumber,
+            branch           => $branch,
+            borrowernumber   => $borrowernumber,
+            biblionumber     => $biblionumber,
+            priority         => $priority,
+            reservation_date => $resdate,
+            expiration_date  => $expdate,
+            title            => $title,
+            itemnumber       => $itemnumber,
         }
     );
 
index dde7091..0664a64 100644 (file)
                                     <dd>IP address where the end user request is being placed</dd>
                                     <dt><strong>pickup_location</strong> (Optional)</dt>
                                     <dd>an identifier indicating the location to which to deliver the item for pickup</dd>
-                                    <dt><strong>needed_before_date</strong> (Optional)</dt>
+                                    <dt><strong>start_date</strong> (Optional)</dt>
                                     <dd>date after which hold request is no longer needed</dd>
-                                    <dt><strong>pickup_expiry_date</strong> (Optional)</dt>
+                                    <dt><strong>expiry_date</strong> (Optional)</dt>
                                     <dd>date after which item returned to shelf if item is not picked up</dd>
                                 </dl>
                                 <h4>Example Call</h4>
                                     <dd>the ILS identifier for the specific item on which the request is placed</dd>
                                     <dt><strong>pickup_location</strong> (Optional)</dt>
                                     <dd>an identifier indicating the location to which to deliver the item for pickup</dd>
-                                    <dt><strong>needed_before_date</strong> (Optional)</dt>
+                                    <dt><strong>start_date</strong> (Optional)</dt>
                                     <dd>date after which hold request is no longer needed</dd>
-                                    <dt><strong>pickup_expiry_date</strong> (Optional)</dt>
+                                    <dt><strong>expiry_date</strong> (Optional)</dt>
                                     <dd>date after which item returned to shelf if item is not picked up</dd>
                                 </dl>
                                 <h4>Example Call</h4>
index 346f23e..a3e9566 100755 (executable)
@@ -108,8 +108,8 @@ my %optional = (
     'GetPatronStatus'     => [],
     'GetServices'         => [],
     'RenewLoan'           => ['desired_due_date'],
-    'HoldTitle'  => [ 'pickup_location', 'needed_before_date', 'pickup_expiry_date' ],
-    'HoldItem'   => [ 'pickup_location', 'needed_before_date', 'pickup_expiry_date' ],
+    'HoldTitle'  => [ 'pickup_location', 'start_date', 'expiry_date' ],
+    'HoldItem'   => [ 'pickup_location', 'start_date', 'expiry_date' ],
     'CancelHold' => [],
 );