almarestapi-lib

1.1.9 • Public • Published

Alma REST API Node Library

This library makes it easy to call the Ex Libris Alma REST APIs in Node.js.

Installation

npm install almarestapi-lib --save

API Key

The library expects that the API key be available in an environment variable called ALMA_APIKEY. The API host can be optionally stored in an environment variable called ALMA_APIHOST. The defaut is https://api-na.hosted.exlibrisgroup.com/almaws/v1.

You can call your script with the API key in the command line, as follows:

ALMA_APIKEY=l7xxabcdefghijklmnopqrstuvwxyz node test.js 

Alternatively, the key and/or path can be set using the setOptions method, as follows:

const alma = require('almarestapi-lib');
alma.setOptions('l7xx...');

Usage

To being using the library, require it at the top of your Node file:

var alma = require ('almarestapi-lib');

Async/Await

The library supports usage of async/await. The functions which return a Promise end in the letter 'p', i.e. getp.

var alma = require ('almarestapi-lib');

async function main() {
  try {
    console.log(await alma.getp('/users/joshw?view=brief'));
  } catch (e) {
    console.error('ERROR: ', e.message);
  }
}

main();

Working with JSON

The following functions work with JSON:

Retrieving JSON with getp

await alma.getp('/users/joshw?view=brief');

Updating JSON with putp

var user = await alma.getp('/users/joshw');
user.middle_name = 'Max';
console.log(await alma.putp('/users/joshw', user);

Creating a record with postp

var user = { first_name: 'Josh', last_name: 'Testman', account_type:{value: 'INTERNAL'}};
console.log(await alma.postp('/users', user));

Deleting with deletep

alma.deletep('/users/4101979450000561');

Working with XML

It is preferable to work with XML when calling APIs which relate to BIB records. You can use the XML functions to work with these APIs.

Retrieving a BIB record with getXmlp

var bib = await alma.getXmlp('/bibs/9981140900561');

Updating and creating a BIB record You can use the putXmlp and postXmlp functions to update and create BIB records respectively.

var dom        = require('xmldom').DOMParser;
var xpath      = require('xpath');
const XPATH_TITLE = '/bib/record/datafield[@tag="245"]/subfield[@code="a"]';

var bib = await alma.getXmlp('/bibs/991439870000541');
bib = new dom().parseFromString(bib);
xpath.select(XPATH_TITLE, bib)[0]
  .firstChild.data='History curatorship';
console.log(await alma.putXmlp('/bibs/991439870000541', bib));      

Issues

Feel free to report issues in this repository.

Readme

Keywords

Package Sidebar

Install

npm i almarestapi-lib

Weekly Downloads

16

Version

1.1.9

License

BSD-3-Clause

Unpacked Size

8.12 kB

Total Files

4

Last publish

Collaborators

  • joshmweisman