Skip to content

Storage (CRUD) module for Orders

License

Notifications You must be signed in to change notification settings

folio-org/mod-orders-storage

Repository files navigation

mod-orders-storage

Copyright (C) 2018-2023 The Open Library Foundation

This software is distributed under the terms of the Apache License, Version 2.0. See the file "LICENSE" for more information.

Introduction

This is the Orders storage module.

NOTE: This module is intended for internal use only. Please use the APIs provided by mod-orders instead. There is a lot of business logic in mod-orders that will be bypassed if talking directly to the storage layer. While this is mainly important for create/update/delete operations, it also includes get operations as well. For instance, summary information is calculated in the business logic module (mod-orders).

Preparation

Sample Data Loading

Sample data can be optionally loaded during tenant initialization. By default, if no parameters are passed the sample data will not be loaded.

The module supports v1.2 of the Okapi tenant interface. This version of the interface allows Okapi to pass tenant initialization parameters using the tenantParameters key. Currently, the only parameter supported is the loadSample key, which will cause the module to load sample data for the tenant if set to true. Here is an example of passing the parameter to the module via Okapi's //proxy/tenants//install endpoint:

{
  "module_to": "mod-orders-storage-3.3.0",
  "parameters": [
    {
      "key": "loadSample",
      "value": "true"
    }
  ]
}
{
	"module_to": "mod-orders-storage-3.0.0-SNAPSHOT",
	"parameters": [
    {
      "key": "loadSample",
      "value": "true"
    }
    ]
}

DATA SOURCE

The sample data lives in /resources/data folder. Each folder is named identical to the endpoint the data has to be loaded to. The TenantReferenceAPI will then be able to load data into the corresponding table using a POST to the endpoint

Modifying default sample data loading behavior

Sample data load behavior can be modified by passing a command line argument loadSample Unlike the tenant parameters the command Line argument will be applicable for all the tenants.

  • COMMAND LINE: java -jar target/mod-orders-storage-fat.jar loadSample=true

Note: The priority for the parameters in the order Tenant Parameters > Command Line argument > Default value

Search and Filtering on APIs

In order to support search and filtering for the APIs /orders-storage/purchase-orders and /orders-storage/po-lines was implemented cross index approach

Additional information

Kafka domain event pattern

The pattern means that every time when a domain entity is created/updated/deleted a message is posted to kafka topic. Currently, domain events are supported for orders, order lines and pieces The events are posted into the following topics:

  • ACQ_ORDER_CHANGED - for orders
  • ACQ_ORDER_LINE_CHANGED - for order lines
  • ACQ_PIECE_CHANGED - for pieces

The event payload has the following structure:

{
  "id": "12bb13f6-d0fa-41b5-b0ad-d6561975121b",
  "action": "CREATED|UPDATED|DELETED",
  "userId": "1d4f3f6-d0fa-41b5-b0ad-d6561975121b",
  "eventDate": "2024-11-14T10:00:00.000+0000",
  "actionDate": "2024-11-14T10:00:00.000+0000",
  "entitySnapshot": { } // entity being either: order, orderLine, piece
}

Default value for all partitions is 1. Kafka partition key for all the events is entity id.

Issue tracker

See project MODORDSTOR at the FOLIO issue tracker.

Other documentation

Other modules are described, with further FOLIO Developer documentation at dev.folio.org