Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Laser/ERM integration is a collection of features aimed at allowing a LASER site to synchronize their subscriptions (Content Lists) and licenses with the FOLIO ERM Agreements and Licenses apps. The integration works via a new backed module : mod-remote-sync (https://github.com/folio-org/mod-remote-sync) and related UI: ui-remote-sync (https://github.com/folio-org/ui-remote-sync). Taken together, remote-sync is general purpose scriptable ETL tool for FOLIO into which arbitrary configurations can be loaded and used to keep FOLIO in sync with a remote data source. Whilst remote-sync itself is intended to be general and reusable, the configuration for LASER is solution specific and can be found here (https://raw.githubusercontent.com/k-int/folio-sync-tools/main/laser/laser_registry.json).

...

On the left side, the record source is listed. Boxes in this column represent the actual raw records which will be / have been collected from a remote source. Remote sync runs on a cron schedule which is invoked every 60 minutes. If a previous extract job has not yet completed, the task is skipped. This means remote-sync will try to synchronize with a remote source once per hour. Because some sources (LASER) do not provide a good cursor mechanism the only way to tell if a record has changed is to download the content and compare the current version with the previous one. That is exactly the process which takes place in this box for LASER. The main aim of the first column is to take a datasource with heterogeneous cursor semantics and turn it into a record stream which can be enumerated. The boxes on the left hand side correspond to the "source" record types in the registry. 

...

LASER LICENSE Procedures

License Import Procedure - Control

...

  1. for each property in the incoming LASER license
    1. Look up the property in the mapping configuration
      1. If Found
        1. Look at the TYPE defined in the mapping configuration
          1. Text:
            1. join all the LASER  notes together and add them to the custprop note field
            2. Add the value of the custom property as a TEXT field
            3. If there is NO-Value set the value to "No-Value"
          2. Date
            1. Join all the notes as for text
            2. Store the value in the value field
          3. Refdata
            1. Join notes
            2. Look up the value in the mappings config
            3. If a mapped value is found, set the value
            4. If not, ignore the value.
      2. If Not Found
        1. Ignore

...


LASER Subscription procedures

For each incoming subscription

  1. If the sync titles setting is yes
    1. Generate the FOLIO Package import JSON for the subscription
    2. upsert (Insert or update) the package definition and remember the package details (UUID)
  2. upsert (Insert or update) the subscription


upsertPackage procedure

We defer entirely to the agreements package ingest routine here - there is no special processing in remote-sync. Agreements uses package reference to decide if it should import or update a package so we hand the whole bundle off to the /erm/packages/import endpoint

upsertSubscription procedure

  1. check to see if we have seen this incoming sub before.
    1. If we have - attempt the agreementUpdate procedure
    2. otherwise - see if we have feedback about creating, ignoring or mapping this subscription
      1. create - create a new agreement and store the ID so we can map it in the future
      2. ignore - do nothing
      3. map - retrieve the mapped ID from the user feedback and apply the agreementUpdate procedure


agreementCreate procedure

  1. Create the agreement lines
    1. use the package ID created in the upsertPackage procedure to connect the agreementLine to the package
    2. set the AL note to "LASER:${subscription.globalUID}"
    3. Set activeFrom to subscription.startDate
    4. set activeTo to subscription.endDate
  2. apply buildPeriods procedure
  3. Set the linked license to any license referenced by this subscription
  4. Post the agreement
    1.   [
                name:subscription.name,
                agreementStatus:statusString,
                reasonForClosure: reasonForClosure,
                description:"Created by remote-sync from LAS:eR on ${new Date()}",
                localReference: subscription.globalUID,
                periods: periods,
                linkedLicenses: linked_licenses,
                items: items,
                customProperties: processSubscriptionProperties(rms,[:],subscription,local_context),
                isPerpetual: subscription.hasPerpetualAccess
              ]

agreementUpdate procedure

  1. lookUp any existing controlling license
  2. If the existing (FOLIO) license data is different to the new (LASER) license data unlink the existing controlling license and link the new controlling license
  3. update periods
    1. for each period in the FOLIO agreement. If the FOLIO period DOES NOT overlap with the period from the LASER agreement
      1. Add the agreement period as a new period to the FOLIO agreement
    2. if it DOES overlap
      1. We cannot continue, ask the user to rectify the dates
  4. Check that there is an AL for the package attached to this sub - if not - add a new AL for the package (Title list changed at laser effectively)
  5. post updated subscription information

buildPeriods procedure

  1. clear any existing periods from the FOLIO record
  2. replace that period with a new period as per
  3.     Map newPeriod = [

          startDate: subscription.startDate,

          endDate: subscription.endDate

        ]