-
Notifications
You must be signed in to change notification settings - Fork 0
OHSU-Library/alma-user-load
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
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 0
No packages published