2018-04-11 17:02:31 +00:00
|
|
|
// @flow
|
|
|
|
|
|
|
|
import { parseURLParams } from '../config';
|
|
|
|
import { toState } from '../redux';
|
|
|
|
|
|
|
|
/**
|
2018-04-13 10:57:12 +00:00
|
|
|
* Returns the effective value of a configuration/preference/setting by applying
|
|
|
|
* a precedence among the values specified by JWT, URL, profile, and config.
|
2018-04-11 17:02:31 +00:00
|
|
|
*
|
2018-04-13 10:57:12 +00:00
|
|
|
* @param {Object|Function} stateful - The redux state object or
|
|
|
|
* {@code getState} function.
|
|
|
|
* @param {string} propertyName - The name of the
|
|
|
|
* configuration/preference/setting (property) to retrieve.
|
2018-04-11 17:02:31 +00:00
|
|
|
* @param {{
|
2018-04-13 10:57:12 +00:00
|
|
|
* config: boolean,
|
|
|
|
* jwt: boolean,
|
|
|
|
* profile: boolean,
|
|
|
|
* urlParams: boolean
|
|
|
|
* }} [sources] - A set/structure of {@code boolean} flags indicating the
|
|
|
|
* configuration/preference/setting sources to consider/retrieve values from.
|
2018-04-11 17:02:31 +00:00
|
|
|
* @returns {any}
|
|
|
|
*/
|
|
|
|
export function getPropertyValue(
|
|
|
|
stateful: Object | Function,
|
|
|
|
propertyName: string,
|
2018-04-13 10:57:12 +00:00
|
|
|
sources?: Object
|
2018-04-11 17:02:31 +00:00
|
|
|
) {
|
2018-04-13 10:57:12 +00:00
|
|
|
// Default values don't play nicely with partial objects and we want to make
|
|
|
|
// the function easy to use without exhaustively defining all flags:
|
|
|
|
sources = { // eslint-disable-line no-param-reassign
|
|
|
|
// Defaults:
|
|
|
|
config: true,
|
|
|
|
jwt: true,
|
|
|
|
profile: true,
|
|
|
|
urlParams: true,
|
|
|
|
|
|
|
|
...sources
|
|
|
|
};
|
|
|
|
|
|
|
|
// Precedence: jwt -> urlParams -> profile -> config.
|
|
|
|
|
2018-04-11 17:02:31 +00:00
|
|
|
const state = toState(stateful);
|
|
|
|
|
2018-04-13 10:57:12 +00:00
|
|
|
// jwt
|
|
|
|
if (sources.jwt) {
|
|
|
|
const value = state['features/base/jwt'][propertyName];
|
2018-04-11 17:02:31 +00:00
|
|
|
|
2018-04-13 10:57:12 +00:00
|
|
|
if (typeof value !== 'undefined') {
|
|
|
|
return value[propertyName];
|
|
|
|
}
|
2018-04-11 17:02:31 +00:00
|
|
|
}
|
|
|
|
|
2018-04-13 10:57:12 +00:00
|
|
|
// urlParams
|
|
|
|
if (sources.urlParams) {
|
|
|
|
const urlParams
|
|
|
|
= parseURLParams(state['features/base/connection'].locationURL);
|
|
|
|
const value = urlParams[`config.${propertyName}`];
|
|
|
|
|
|
|
|
if (typeof value !== 'undefined') {
|
|
|
|
return value;
|
|
|
|
}
|
2018-04-11 17:02:31 +00:00
|
|
|
}
|
|
|
|
|
2018-04-13 10:57:12 +00:00
|
|
|
// profile
|
|
|
|
if (sources.profile) {
|
|
|
|
const value = state['features/base/profile'][propertyName];
|
|
|
|
|
|
|
|
if (typeof value !== 'undefined') {
|
|
|
|
return value;
|
|
|
|
}
|
2018-04-11 17:02:31 +00:00
|
|
|
}
|
|
|
|
|
2018-04-13 10:57:12 +00:00
|
|
|
// config
|
|
|
|
if (sources.config) {
|
|
|
|
const value = state['features/base/config'][propertyName];
|
|
|
|
|
|
|
|
if (typeof value !== 'undefined') {
|
|
|
|
return value;
|
|
|
|
}
|
2018-04-11 17:02:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return undefined;
|
|
|
|
}
|