@janiscommerce/client-settings
v5.0.0
Published
A package to handle client settings
Downloads
955
Readme
client-settings
A package to handle client settings. This package allows you to declare all the settings available for each entity of your service.
It also provides you with a class to easily get the settings value per client, with a fallback in the default values you have previously defined. You have many other tools to help you, like two APIs to get and update the settings, sample schemas for them, hooks for sls-helper and sls-helper-plugin-janis, also uses Client data from client-creator, etc.
Installation
npm install @janiscommerce/client-settings
Usage
Settings definition
Settings must be previously defined in a "definition file". The default definition file location is project-path/schemas/settings/index.js
.
If you want to get it from somewhere else, you can call ClientSettings.setSettingsDefinitionPath()
(remember to use an absolut path).
The definition file is just a JS file that exports the following structure (with as many settings as needed):
module.exports = {
[entity]: {
[settingName]: {
description: 'A description of what this setting does',
struct: 'The validation to use with @janiscommerce/superstruct package',
default: settingDefaultValue, // Of any type
saveEmptyValue: false
}
}
}
For example:
const { struct } = require('@janiscommerce/superstruct');
module.exports = {
product: {
defaultStatus: {
description: 'The status to be set to a product if any status is provided',
struct: struct.enum(['active', 'inactive']),
default: 'active',
saveEmptyValue: false
},
},
sku: {
defaultUnitMultiplier: {
description: 'The unit multiplier to be set to an SKU if any multiplier is provided',
struct: 'number & positive',
default: 1,
saveEmptyValue: true
}
}
}
Important!
If the setting property saveEmptyValue
is set to false
, any of the following values null - '' - 0 - {} - []
will not be saved. In any other case, the saveEmptyValue
property is set to true
.
Settings fetch
To fetch the clients settings, you must use the ClientSettings
class. You must always set a session before fetching any setting.
const { ClientSettings } = require('@janiscommerce/client-settings');
// mySession must be an instance of @janiscommerce/api-session
ClientSettings.setSession(mySession);
const productDefaultStatus = ClientSettings.get('product', 'defaultStatus');
console.log(productDefaultStatus); // For example, 'active'
Settings management
To allow the user to change the client settings values, you have to implement a few things:
- The Serverless helpers hooks
// serverless.js
const { helper } = require('sls-helper');
const { ServerlessHelperHooks } = require('@janiscommerce/client-settings');
module.exports = helper({
hooks: [
// other hooks
...ServerlessHelperHooks()
// You can pass an object that acceps an array of manual includes for you APIs.
// For example:
// ...ServerlessHelperHooks({
// includes: [
// 'some/file/path'
// ]
// })
]
});
- A GET API to fetch the current configuration.
// src/api/setting/get.js
const { GetSettingApi } = require('@janiscommerce/client-settings');
module.exports = GetSettingApi;
- A PUT API to update the current configuration.
// src/api/setting/put.js
const { PutSettingApi } = require('@janiscommerce/client-settings');
module.exports = PutSettingApi;
- The schemas for both APIs:
The GET Schema: get.yml
The PUT Schema: put.yml
- An Edit view schema:
Here's an example that you must customize with your own settings: edit.yml
Important!
- Remember you replace
your-service
for your actual service name in both API Schemas and in the view schema. - Remember to add the
Settings
tag to your API schema. - And remember to add the permissions to you permissions definition!
ClientSettings API
const { ClientSettings } = require('@janiscommerce/client-settings');
To fetch client settings or their default values.
setSession(session)
session
An instance of API Session
Chainable. Returns the this
object.
setSettingsDefinitionPath(path)
path
The absolute path to the definitions file
Chainable. Returns the this
object.
setCacheTime(timeInSeconds)
timeInSeconds
The seconds that the settings will keep in cache. By default One Hour Cache
Chainable. Returns the this
object.
async get(entity, settingName)
entity
The name of the entity that owns the settingsettingName
The name of the setting to fetch
Resolves the setting value (of any type).
Rejects a ClientSettingsError
if one of the following errors occur:
- The definition file can't be found
- The setting is not present in the definition file
- DB connection fails when fetching the value
If a setting value is not present in the client.setting
document, it will return the default value, defined in the definition file.
Also, the class automatically caches the values of each setting once they are required.