Objective
SOAJS provides the ability to store data per tenant. What this means is that each tenant has a config object, and this object is only accessed by the users of that specific tenant.
This space will show you:
Enable services config
Anchor | ||||
---|---|---|---|---|
|
Since the services config is tied to the tenant, our service must be multitenant, so we have to set extKeyRequired to true. Let's setup a simple microservice to demonstrate this.
Note | ||
---|---|---|
| ||
Remember that a service is composed, at least, of a config.js and index.js file. Click here to remember how to build a service. |
Code Block | ||||||
---|---|---|---|---|---|---|
| ||||||
'use strict';
module.exports = {
"serviceVersion": 1,
"serviceName": "servicesConfig",
"serviceGroup": "SOAJS Services Config Example",
"servicePort": 4130,
"requestTimeout": 30,
"requestTimeoutRenewal": 5,
"extKeyRequired": true,
"errors": {},
"schema": {
"/get": {
"_apiInfo": {
"l": "get name"
}
}
}
}; |
Code Block | ||||||
---|---|---|---|---|---|---|
| ||||||
'use strict';
var soajs = require('soajs');
var config = require('./config.js');
var service = new soajs.server.service(config);
service.init(function() {
service.get("/get", function(req, res) {
var name = req.soajs.servicesConfig.name;
res.json(req.soajs.buildResponse(null, "Hello " + name));
});
service.start();
}); |
Configure services config from Dashboard
Anchor | ||||
---|---|---|---|---|
|
We need to create at least two tenants to see how the response will differ based on which key we provide the request.
Check out the Manage Pillar page to learn how to create a tenant and configure its services config.
Example
Anchor | ||||
---|---|---|---|---|
|
Now that everything is set up, let's test our service though an example.
Code Block | ||||||
---|---|---|---|---|---|---|
| ||||||
# Go to the directory where you created your config.js and index.js files
cd /opt/soajs/node_modules/servicesConfig.example
# Export necessary environment variable
export SOAJS_ENV=dev
# Run the service
node . |
The service is now running and listening for requests.
Using a terminal window, Postman, Insomnia, etc... we can test our service.
Note | ||
---|---|---|
| ||
Make sure that the keys in the header of your requests are the keys that you created and not the one form the screenshot! |
We see that depending on which key we use in the header, the response returns the name specified in the service config of each tenant!