References
https://openlibraryfoundation.atlassian.net/issues/?jql=issuekey%20%3D%20DCB-1542%20OR%20issue%20in%20linkedIssues(%22DCB-1542%22)%20ORDER%20BY%20issuekey%20ASCAdditional:
Overview
This document outlines the requirements and workflows needed to integrate Alma with the DCB service to support Alma bibliographic data ingestion, patron verification, request placement, circulation tracking, and request finalization in OpenRS.
Ingest and Suppression
Alma supports the OAI-PMH mechanism for harvesting bibliographic records. For more details on the OAI-PMH Alma integration, refer to the official documentation: OAI-PMH Alma Integration
Patron verification
Authentication
Alma supports the SAML 2.0 Web Browser SSO profile for user authentication and authorization. Further information on this integration can be found here:
SAML Authentication.
Eligibility
After the patron has been successfully authenticated, DCB must determine if the patron is eligible to place a request. The patron is eligible if the following conditions are met:
Alma patron record is active.
Alma patron record does not have any active patron blocks.
The types of active blocks include:
Alma operator-assigned blocks
System-assigned blocks (limits)
Overdue blocks due to an overdue item (punitive blocks)
Check for Patron Blocks
Endpoint:
GET /almaws/v1/users/{user_id}
Key Field:
user_block
: Provides details about active blocks on the user's account.
Example Request:
http GET https://api-na.hosted.exlibrisgroup.com/almaws/v1/users/12345678?apikey={your_api_key}
Example Response:
json { "primary_id": "12345678", "first_name": "John", "last_name": "Doe", "user_block": [ { "block_type": "General", "description": "User has overdue items", "status": "Active" } ], "user_status": "Active" }
Details can be found here.
Place Requests
Place request at lending agency
Before placing DCB request at the lending agency, a virtual patron needs to be found or created in Alma.
Creating a virtual patron in Alma
A virtual patron in Alma can be created by using the Rest user API. The mandatory fields for this API are as follows:
record_type:
Publicprimary_id:
The primary identifier of the userAccount_type:
ExternalUser_group
(optional): Used in fulfillment policieslast_name
: Used in displays and search
For more details on creating a user, refer to Create user
Creating an item-level request in Alma
Item-level requests can be created using the Rest User request API. Key parameters and mandatory fields include:
Parameters:
Bib/Holding/Item ID
: The bibliographic, holding, or item ID.User_id:
The ID of the requesting user.
Mandatory Fields:
request_type
: HOLDpickup_location_type
: LIBRARYpickup_location_library
: The pickup location library code.material_type
(optional): Used in fulfillment policies.
For more details on creating a request for an item, refer to Create request for an Item
Alma request details
Once a request is created in Alma, it will have a unique ID and include the following information:
Request type: Patron physical item request
Item's status: Item in place
Pickup at: Pickup location
Item material type
Workflow step: Pickup from shelf
Process status: New (Not started)
Managed by Library: The library where the available inventory is located
Managed by Desk: The circulation desk where the available inventory is located
Place request at borrowing agency
Before placing DCB request at the borrowing agency, a virtual item needs to be found or created in Alma.
Creating a virtual item in Alma
A virtual item in Alma can be created by using the following APIs:
Mandatory Fields:
The actual record
: XML string describing the recordrecord_format:
Default is marc21suppress_from_publishing
: default is true
Parameters:
mms_id
: Bib record ID
Mandatory Fields:
The actual record
: XML string describing the recordsuppress_from_publishing
: tbd
Parameters:
Barcode
physical_material_type
policy
: Interlibrary Loanlocation
?
Creating an item-level request
Item-level requests can be created using the Rest User Request API. Key parameters and mandatory fields include:
Parameters:
Bib/Holding/Item ID
: The bibliographic, holding, or item ID.User_id
: The ID of the requesting user.
Mandatory Fields:
request_type
: HOLDpickup_location_type
: LIBRARYpickup_location_library
: The pickup location library code.material_type
(optional): Used in fulfillment policies.
For more details on creating a request for an item, refer to Create request for an Item
Circulate Requests
Circulation tracking and reaction (lending)
Lifecycle | Given | When | Then |
---|---|---|---|
Dispatched by Supplying Library |
| DCB Patron Request Workflow matches corresponding request details at
| Trigger DCB
|
Received at Pickup Library |
| DCB Patron Request Workflow matches corresponding request details at
| Trigger
|
Item Checked Out to Patron at Pickup Library |
| DCB Patron Request Workflow matches corresponding request details at
| Trigger
|
Item Returned by Borrowing Patron |
| DCB Patron Request Workflow matches corresponding request details at either
| Trigger
|
Received Back at Lending Agency |
| DCB Patron Request Workflow matches corresponding request details at either
| Trigger
|
Workflow diagram
1. Placing the request
When a patron places a DCB request, it goes through initial checks and follows the sequence of status transitions (more details https://openlibraryfoundation.atlassian.net/wiki/x/IYAZqw) :
DCB Status Transition:
SUBMITTED_TO_DCB,
PATRON_VERIFIED,
RESOLVED,
REQUEST_PLACED_AT_SUPPLYING_AGENCY,
CONFIRMED,
REQUEST_PLACED_AT_BORROWING_AGENCY
Alma status updates:
Request type: Patron physical item request
Process status: New (Not started)
Item Status: "Item in place" (indicating the item is currently available on the shelf)
2. Item is sent out to the borrowing agency
Alma updates:
Request status: In progress
Item status: Transit
DCB status transition:
Transaction status changes on PICKUP_TRANSIT
3. Item received in borrowing agency:
DCB status transition:
Transaction status changes to RECEIVED_AT_PICKUP > READY_FOR_PICKUP
Alma updates:
No status updates
4. Item is loaned in borrowing agency:
DCB status transition:
Transaction status changes to LOANED
A loan is created in Alma.
Alma status updates:
Request status: In progress
Item status: Loan
Loan is created
Alma loan creation
To create the loan in Alma, the Rest Item Loan API is used with the following parameters and fields:
Parameters:
User_id
: The ID of the requesting user.item_pid
oritem_barcode
: Item ID or barcode must be supplied
Mandatory Fields:
circ_desk
: Circulation desk code(DCB parameter?)library
: Library code responsible for the loan(lending agency?)request_id
For more details on creating a loan, refer to Create user loan
5. Item returned at the borrowing library
DCB status transition:
Transaction status changes to RETURN_TRANSIT
Alma updates:
No status updates
6. Item returned to the lending library (scan item at lending library):
Alma status updates:
Request status: Completed
Item status: Item in place
Loan is closed
DCB status transition:
Transaction status changes to COMPLETED
Circulation tracking and reaction (borrowing)
tbd
Finalization
Common Request Closure Statuses in Alma
Completed. The request has been successfully fulfilled.
Canceled. The request has been canceled, either manually by a user/staff member or automatically by the system.
Expired. The request has expired without being fulfilled, based on library-defined expiration rules.
Rejected. The request was rejected by library staff or the system due to eligibility, policy, or technical reasons.
Failed. The request could not be fulfilled due to a failure in the process.
Hold Shelf Expired. The item was placed on the hold shelf but was not picked up within the designated time frame.
Retrieving Request Closure Status via API
Endpoint:
GET /almaws/v1/bibs/{mms_id}/requests
Example Request:
http GET https://api-na.hosted.exlibrisgroup.com/almaws/v1/bibs/123456789/requests?apikey={your_api_key}
Key Fields in Response:
request_status
: Shows the current or final status of the request.expiry_date
: Indicates the expiration date, if applicable.pickup_location
: Provides the location where the item was to be picked up.
Example Response:
json { "total_record_count": 2, "requests": [ { "request_id": "12345", "request_status": "Completed", "expiry_date": "2024-11-30T23:59:00Z", "pickup_location": "Main Library" }, { "request_id": "67890", "request_status": "Canceled", "expiry_date": null, "pickup_location": "Science Library" } ] }
Cancel a request in Alma via the API
Endpoint:
DELETE /almaws/v1/bibs/{mms_id}/requests/{request_id}
Required Parameters
mms_id
: The bibliographic record ID of the item for which the request was made.request_id
: The unique identifier of the request to be canceled.
Required Parameters
mms_id
: The bibliographic record ID of the item for which the request was made.request_id
: The unique identifier of the request to be canceled.
Example Request
http DELETE https://api-na.hosted.exlibrisgroup.com/almaws/v1/bibs/123456789/requests/987654321?reason=User%20no%20longer%20needs%20item&apikey={your_api_key}