Skip to content

Perl Script containing 4 different loading functions for pushing user data via the Alma users API

Notifications You must be signed in to change notification settings

OHSU-Library/alma-user-load

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

# Alma Load User (via API)

## Installation

Requirements:
-- Config::General
-- DBI
-- LWP
-- Time::Piece
-- XML::Twig
- MySQL DB libempdata (schema in repo)

## Usage

alma_load_users.pl --function=[FULL|FULL_STUDENTS|UPDATE|MAINTAIN|(USERID)] --commit=[YES/NO]

alma_load_users.pl - Contains 5 different loading functions for pushing user data via
  the Alma users API:

1. FULL Load: Query our locally managed HR/Banner user DB libempdata and return ALL
   users. Push data to API, overwriting all externally managed data fields.
   Runs Monthly. If user is not matched by employee_id or primary_id, then it is created
   via a POST call.
2. FULL_STUDENTS Load: Same as FULL above, but will only work with student (BANNER)
   data.
3. UPDATE Load: Query libempdata and return recently updated users from last 6 hours.
   Push data to API, overwriting all externally managed data fields. If user is not 
   matched by employee_id or primary_id, then it is created via a POST call.
4. MAINTAIN Load: Query Analytics API Shared/Oregon Health and Science University/
   Recently_Modified_Users -- these are users modified within the last 24hrs. Query 
   libempdata and match users. Push data to API, overwriting all externally managed data
   fields.
5. (USERID) load: If you pass a primary_id (eg 'user@ohsu.edu') to the function call, 
   then the MAINTAIN load code above will run for that user only. Useful to manually
   fix individual user accounts.

commit=YES will push changes to Alma user DB via the API. Setting to NO will only
   make query calls and report back without writing to DB.

last updated: 01/11/18, np, OHSU Library

## History

-= 1/11/18 Changes =-
Added XML parsing block to check if there are any internally managed fields in 
contact_info when PUTing a user. If so, retain these fields. Generally an internally
managed field will be set as "preferred". The new block checks to ensure that a preferred 
field is set for each of the address, email and phone blocks. If none is set, the 
externally managed field is to set "preferred".

-= 7/20/17 Changes =-
Added debug/error catch code on retrieving XML error payloads from API calls. There are
random 'ROUTING_ERROR' and 'No response from Alma' failures that sometimes occur during
normal script operation. These errors only started appearing when switching from a 
user/pass auth to gateway auth. Problem may be related to Oracle issues noted here: 

https://developers.exlibrisgroup.com/forum/posts/list/158.page

Added FULL_STUDENTS function: same as FULL but only runs against BANNER data.

-= 6/20/17 Changes =-
Switched Alma API from user/pass to gateway authentication.

-= 1/18/17 Changes =-
Modified SQL procedure libempdata.SIS_XML_FULL to be overloadable and accept single
letter character to limit full result set. Defaults to letter 'a' so a full (a-z) result
set is returned if no value is passed. Passing a letter via shell CLI will limit result
set, i.e. if you run --function=FULLm then m-z result set will be used during load.

-= 1/13/17 Changes =-
Modified SQL to ensure POST/create new user sets preferred_language attribute during 
POST. Otherwise error 401658 "General Error" will be thrown. This is related to updates 
made to Alma for January 2017 Release.
 
## Credits

## License

About

Perl Script containing 4 different loading functions for pushing user data via the Alma users API

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published