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.
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).
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:
- ENABLING VIA OKAPI: curl -w '\n' -X POST -d '[ { "id": "mod-orders-storage-3.0.0", "action": "enable" } ]' http://localhost:9130/_/proxy/tenants/test-tenant/install?tenantParameters=loadSample=true This results in a post to the module's _tenant API with the following structure:
{
"module_to": "mod-orders-storage-3.3.0",
"parameters": [
{
"key": "loadSample",
"value": "true"
}
]
}
- STANDALONE: A post to http://localhost:8081/_/tenant
{
"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
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
In order to support search and filtering for the APIs /orders-storage/purchase-orders and /orders-storage/po-lines was implemented cross index approach
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 ordersACQ_ORDER_LINE_CHANGED
- for order linesACQ_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.
See project MODORDSTOR at the FOLIO issue tracker.
Other modules are described, with further FOLIO Developer documentation at dev.folio.org