The EPrints software package from University of Southampton provides a rich internal Perl API along with a RESTful web API. The latter has been used extensively by Caltech Library to facilitate content reuse across campus for our various EPrints repositories. The challenge now is to move beyond the present limitations. (See priorities two and three of the AY 22 Caltech Library's strategic plan)
Extending EPrints directly is error prone and cumbersome. Implementing features in Perl safely is only the start of trouble if we modify EPrints directly. In contrast EPrints' MySQL database structure has proven to be durable and predictable. MySQL can be leverage directly to extended API seeks to beyond our current constraints.
What should an extended web API look like?
- The extended API should be web accessible to support data platforms such as feeds.library.caltech.edu as well as our growing cast of application hosted on apps.library.caltech.edu
- It needs to interact with MySQL's EPrints database safely, e.g. be read only
- Minimize the load on EPrints' MySQL database, e.g. favor simple SQL queries perhaps limiting them to single table scans
- Be near zero management, it should run as a service that doesn't require on going interventions and easily integrate into DLD's monitoring infrastructure
An extended API should provide a limited web service that maps URL end points to simple MySQL queries run against the various EPrints databases. The service should be easy to implement require minimal resources, e.g. one prepared SQL statement per end point.
Security and privacy should be front and center when implementing any web service. By returning EPrint ID only we limit the risk of exposing in appropriate metadata (e.g. author information). The EPrint ID is an integer without specific meaning. It does not give you access to sensitive information.
The following URL end points are intended to take one unique identifier and map that to one or more EPrint IDs. This can be done because each unique ID targeted can be identified by querying a single table in EPrints. In addition the scan can return the complete results since all EPrint IDs are integers and returning all EPrint IDs in any of our repositories is sufficiently small to be returned in a single HTTP request.
/<REPO_ID>/doi/<DOI>
with the adoption of EPrints "doi" field in the EPrint table it makes sense to have a quick translation of DOI to EPrint id for a given EPrints repository./<REPO_ID>/creator-id/<CREATOR_ID>
scans the name creator id field associated with creators and returns a list of EPrint ID/<REPO_ID>/creator-orcid/<ORCID>
scans the "orcid" field associated with creators and returns a list of EPrint ID/<REPO_ID>/editor-id/<CREATOR_ID>
scans the name creator id field associated with editors and returns a list of EPrint ID/<REPO_ID>/contributor-id/<CONTRIBUTOR_ID>
scans the "id" field associated with a contributors and returns a list of EPrint ID/<REPO_ID>/advisor-id/<ADVISOR_ID>
scans the name advisor id field associated with advisors and returns a list of EPrint ID/<REPO_ID>/committee-id/<COMMITTEE_ID>
scans the committee id field associated with committee members and returns a list of EPrint ID/<REPO_ID>/group-id/<GROUP_ID>
this scans group ID and returns a list of EPrint IDs associated with the group/<REPO_ID>/grant-number/<GRANT_NUMBER>
returns a list of EPrint IDs associated with the grant number/<REPO_ID>/creator-name/<FAMILY_NAME>/<GIVEN_NAME>
scans the name fields associated with creators and returns a list of EPrint ID/<REPO_ID>/editor-name/<FAMILY_NAME>/<GIVEN_NAME>
scans the family and given name field associated with a editors and returns a list of EPrint ID/<REPO_ID>/contributor-name/<FAMILY_NAME>/<GIVEN_NAME>
scans the family and given name field associated with a contributors and returns a list of EPrint ID/<REPO_ID>/advisor-name/<FAMILY_NAME>/<GIVEN_NAME>
scans the name fields associated with advisors returns a list of EPrint ID/<REPO_ID>/committee-name/<FAMILY_NAME>/<GIVEN_NAME>
scans the family and given name fields associated with committee members and returns a list of EPrint ID/<REPO_ID>/pubmed/<PUBMED_ID>
returns a list of EPrint IDs associated with the PubMed ID/<REPO_ID>/issn/<ISSN>
returns a list of EPrint IDs associated with the ISSN/<REPO_ID>/isbn/<ISSN>
returns a list of EPrint IDs associated with the ISSN/<REPO_ID>/patent-number/<PATENT_NUMBER
returns a list of EPrint IDs associated with the patent number
The follow API end points would facilitate faster updates to our feeds platform as well as allow us to create a separate public view of our EPrint repository content.
/<REPO_ID>/updated/<TIMESTAMP>/<TIMESTAMP>
returns a list of EPrint IDs updated starting at the first timestamp (timestamps should have a resolution to the minute, e.g. "YYYY-MM-DD HH:MM:SS") through inclusive of the second timestmap (if the second is omitted the timestamp is assumed to be "now")/<REPO_ID>/deleted/<TIMESTAMP>/<TIMESTAMP>
through the returns a list of EPrint IDs deleted starting at first timestamp through inclusive of the second timestamp, if the second timestamp is omitted it is assumed to be "now"/<REPO_ID>/pubdate/<APROX_DATESTAMP>/<APPOX_DATESTAMP>
this query scans the EPrint table for records with publication starts starting with the first approximate date through inclusive of the second approximate date. If the second date is omitted it is assumed to be "today". Approximate dates my be expressed just the year (starting with Jan 1, ending with Dec 31), just the year and month (starting with first day of month ending with the last day) or year, month and day. The end returns zero or more EPrint IDs.
The following end points would be nice to have but they would either requirecustomization of our existing EPrints deployments or require significant work on part of our Library staff to populate.
/<REPO_ID>/editor-orcid/<ORCID>
scans the "orcid" field associated with a editors and returns a list of EPrint ID/<REPO_ID>/contributor-orcid/<ORCID>
scans the "orcid" field associated with a contributors and returns a list of EPrint ID/<REPO_ID>/advisor-orcid/<ORCID>
scans the "orcid" field associated with advisors and returns a list of EPrint ID/<REPO_ID>/committee-orcid/<ORCID>
scans the "orcid" field associated with committee members and returns a list of EPrint ID/<REPO_ID>/group-ror/<ROR>
this scans the local group ROR related fields and returns a list of EPrint ids./<REPO_ID>/funder-ror/<FUNDER_ROR>
returns a list of EPrint IDs associated with the funder's ROR
EPrints XML is complex and hard to work with. A simplified data structure could make working with our repository data much easier. If user/role restrictions were enforced in an extended EPrints API it could provide a clean JSON expression of a more general bibliographic record. Additionally would couple provide JSON documents suitable for direct ingest into Solr/Lunr search engines. At that stage it might also be desirable to allow updates to existing EPrints records via the extended API.