Introduction
Like all SOAJS microservices, OAuth microservice has different layers of configuration. Local configuration, tenant-level configuration if the microservice is a multitenant one, and registry configuration. Moreover, OAuth can have a custom separate database for tokens and users.
Configuration Layers
1 - Tenant configuration
Provisioning is a configuration that all SOAJS micro-services can acquire once you turn on multi-tenant for them. Once a service becomes multi-tenant, you can provide custom tenant configuration to it at run time. If you have 2 tenants that can access the oAuth service, then the provisioned configuration for each tenant will be loaded once that tenant invokes an API in oAuth.
The below configuration is supported by the oAuth micro-service and can be configured & changed at the tenant level under the Manage Pillar.
Configuration Sample
Code Block | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
{ _id: "%tenant_id%", type: "tenant_type", code: "tenant_code", profile: {...}, locked: true, name: "tenant_name", description: "tenant_description", oauth: { secret: "tenant_oauth_secret", pin: { "%product_name%": { enabled: true } }, disabled: 0, //OAuth enabled or not type: 2,//OAuth type loginMode: "%login_mode%" }, applications: [ { product: "%product_name%", package: "%package_name%", appId: "%app_id%", description: "%application_description%", _TTL: 604800000, keys: [ { key: "%internal_key%", extKeys: [ { extKey: "%ext_key%", device: null, geo: null, env: "%env_name%", expDate: null, dashboardAccess: true } ], config: { "%env_name%": { commonFields: {...}, urac: {...}, oauth: { loginMode: "urac", passportLogin: { "github": {...}, "facebook": {...}, "twitter": {...}, "google": {...}, } } } } } ] } ] } |
Steps to add tenant-level configuration
2 - Environment configuration (registry)
This configuration is on the environment level. OAuth configuration can be added from SOAJS Console also.
3 - Separate Database for tokens and users
OAuth can have a separate database that can be added from Deploy tab in SOAJS Console → Databases
Tenant Key Configuration (provision)
Info | ||
---|---|---|
| ||
In provision - key configuration |
Passport Login: Define application keys for passport integration. Currently supporting Azure, Github, Twitter, Facebook, and Google. Got to the link for more information and an example of the configuration.OAuth allows third-party login via one of the below methods:
OpenAM login: SSO (Single Sign-On).
LDAP (Lightweight Directory Access Protocol) login: Active directory login.