2020-06-17 18:12:01 -04:00
|
|
|
import { assignWithDepth } from './utils';
|
2020-06-26 09:26:56 -04:00
|
|
|
import { logger } from './logger';
|
2020-07-22 16:46:41 -04:00
|
|
|
import theme from './themes';
|
2020-07-29 18:38:59 +02:00
|
|
|
import config from './defaultConfig';
|
2020-07-22 16:46:41 -04:00
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
// debugger;
|
2020-06-26 09:26:56 -04:00
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
export const defaultConfig = Object.freeze(config);
|
2020-06-26 09:26:56 -04:00
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
let siteConfig = assignWithDepth({}, defaultConfig);
|
|
|
|
let directives = [];
|
|
|
|
let currentConfig = assignWithDepth({}, defaultConfig);
|
2020-06-26 09:26:56 -04:00
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
export const updateCurrentConfig = (siteCfg, _directives) => {
|
|
|
|
let cfg = assignWithDepth({}, siteCfg);
|
2020-06-26 09:26:56 -04:00
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
// Apply directives
|
2020-07-29 22:19:23 +02:00
|
|
|
let themeVariables = {};
|
|
|
|
for (let i = 0; i < _directives.length; i++) {
|
|
|
|
const d = _directives[i];
|
2020-07-29 18:38:59 +02:00
|
|
|
sanitize(d);
|
|
|
|
cfg = assignWithDepth(cfg, d);
|
2020-07-30 19:18:18 +02:00
|
|
|
if (d.theme) {
|
|
|
|
cfg.themeVariables = theme[cfg.theme].getThemeVariables(d.themeVariables);
|
2020-06-26 09:26:56 -04:00
|
|
|
}
|
2020-07-29 22:19:23 +02:00
|
|
|
}
|
|
|
|
if (cfg.theme && theme[cfg.theme]) {
|
2020-07-30 19:18:18 +02:00
|
|
|
let tVars = assignWithDepth({}, cfg.themeVariables);
|
|
|
|
tVars = assignWithDepth(tVars, themeVariables);
|
|
|
|
const variables = theme[cfg.theme].getThemeVariables(tVars);
|
2020-07-29 18:38:59 +02:00
|
|
|
cfg.themeVariables = variables;
|
2020-06-26 09:26:56 -04:00
|
|
|
}
|
2019-10-11 15:39:50 +02:00
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
currentConfig = cfg;
|
|
|
|
return cfg;
|
|
|
|
};
|
2020-06-26 09:26:56 -04:00
|
|
|
/**
|
2020-07-20 20:07:57 -07:00
|
|
|
*## setSiteConfig
|
2020-07-14 18:11:36 -07:00
|
|
|
*| Function | Description | Type | Values |
|
|
|
|
*| --------- | ------------------- | ------- | ------------------ |
|
|
|
|
*| setSiteConfig|Sets the siteConfig to desired values | Put Request | Any Values, except ones in secure array|
|
|
|
|
***Notes:**
|
|
|
|
*Sets the siteConfig. The siteConfig is a protected configuration for repeat use. Calls to reset() will reset
|
|
|
|
*the currentConfig to siteConfig. Calls to reset(configApi.defaultConfig) will reset siteConfig and currentConfig
|
|
|
|
*to the defaultConfig
|
|
|
|
*Note: currentConfig is set in this function
|
|
|
|
**Default value: At default, will mirror Global Config**
|
2020-06-26 09:26:56 -04:00
|
|
|
* @param conf - the base currentConfig to use as siteConfig
|
|
|
|
* @returns {*} - the siteConfig
|
|
|
|
*/
|
|
|
|
export const setSiteConfig = conf => {
|
2020-07-30 19:18:18 +02:00
|
|
|
console.warn('Setting site config');
|
2020-07-29 18:38:59 +02:00
|
|
|
siteConfig = assignWithDepth({}, defaultConfig);
|
|
|
|
siteConfig = assignWithDepth(siteConfig, conf);
|
2020-07-30 19:18:18 +02:00
|
|
|
|
|
|
|
if (conf.theme) {
|
|
|
|
siteConfig.themeVariables = theme[conf.theme].getThemeVariables(conf.themeVariables);
|
|
|
|
}
|
|
|
|
|
2020-07-29 18:38:59 +02:00
|
|
|
currentConfig = updateCurrentConfig(siteConfig, directives);
|
|
|
|
return siteConfig;
|
|
|
|
};
|
|
|
|
export const updateSiteConfig = conf => {
|
|
|
|
siteConfig = assignWithDepth(siteConfig, conf);
|
|
|
|
updateCurrentConfig(siteConfig, directives);
|
|
|
|
|
|
|
|
return siteConfig;
|
2020-06-26 09:26:56 -04:00
|
|
|
};
|
|
|
|
/**
|
2020-07-20 20:07:57 -07:00
|
|
|
*## getSiteConfig
|
2020-07-14 18:11:36 -07:00
|
|
|
*| Function | Description | Type | Values |
|
|
|
|
*| --------- | ------------------- | ------- | ------------------ |
|
|
|
|
*| setSiteConfig|Returns the current siteConfig base configuration | Get Request | Returns Any Values in siteConfig|
|
|
|
|
***Notes**:
|
|
|
|
*Returns **any** values in siteConfig.
|
2020-06-26 09:26:56 -04:00
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
export const getSiteConfig = () => {
|
|
|
|
return assignWithDepth({}, siteConfig);
|
|
|
|
};
|
|
|
|
/**
|
2020-07-20 20:07:57 -07:00
|
|
|
*## setConfig
|
2020-07-14 18:11:36 -07:00
|
|
|
*| Function | Description | Type | Values |
|
|
|
|
*| --------- | ------------------- | ------- | ------------------ |
|
|
|
|
*| setSiteConfig|Sets the siteConfig to desired values | Put Request| Any Values, except ones in secure array|
|
|
|
|
***Notes**:
|
|
|
|
*Sets the currentConfig. The parameter conf is sanitized based on the siteConfig.secure keys. Any
|
|
|
|
*values found in conf with key found in siteConfig.secure will be replaced with the corresponding
|
|
|
|
*siteConfig value.
|
2020-06-26 09:26:56 -04:00
|
|
|
* @param conf - the potential currentConfig
|
|
|
|
* @returns {*} - the currentConfig merged with the sanitized conf
|
|
|
|
*/
|
|
|
|
export const setConfig = conf => {
|
2020-07-29 18:38:59 +02:00
|
|
|
// sanitize(conf);
|
|
|
|
// Object.keys(conf).forEach(key => {
|
|
|
|
// const manipulator = manipulators[key];
|
|
|
|
// conf[key] = manipulator ? manipulator(conf[key]) : conf[key];
|
|
|
|
// });
|
2020-07-16 23:39:38 +02:00
|
|
|
|
2020-06-26 09:26:56 -04:00
|
|
|
assignWithDepth(currentConfig, conf);
|
2020-07-29 18:38:59 +02:00
|
|
|
|
2020-06-26 09:26:56 -04:00
|
|
|
return getConfig();
|
|
|
|
};
|
2020-07-29 18:38:59 +02:00
|
|
|
|
2020-06-26 09:26:56 -04:00
|
|
|
/**
|
2020-07-20 20:07:57 -07:00
|
|
|
* ## getConfig
|
2020-07-14 18:11:36 -07:00
|
|
|
*| Function | Description | Type | Return Values |
|
|
|
|
*| --------- | ------------------- | ------- | ------------------ |
|
|
|
|
*| getConfig |Obtains the currentConfig | Get Request | Any Values from currentConfig|
|
|
|
|
***Notes**:
|
|
|
|
*Returns **any** the currentConfig
|
2020-06-26 09:26:56 -04:00
|
|
|
* @returns {*} - the currentConfig
|
|
|
|
*/
|
|
|
|
export const getConfig = () => {
|
|
|
|
return assignWithDepth({}, currentConfig);
|
|
|
|
};
|
|
|
|
/**
|
2020-07-20 20:07:57 -07:00
|
|
|
*## sanitize
|
2020-07-14 18:11:36 -07:00
|
|
|
*| Function | Description | Type | Values |
|
|
|
|
*| --------- | ------------------- | ------- | ------------------ |
|
|
|
|
*| sanitize |Sets the siteConfig to desired values. | Put Request |None|
|
|
|
|
*Ensures options parameter does not attempt to override siteConfig secure keys
|
|
|
|
*Note: modifies options in-place
|
2020-06-26 09:26:56 -04:00
|
|
|
* @param options - the potential setConfig parameter
|
|
|
|
*/
|
|
|
|
export const sanitize = options => {
|
|
|
|
Object.keys(siteConfig.secure).forEach(key => {
|
|
|
|
if (typeof options[siteConfig.secure[key]] !== 'undefined') {
|
|
|
|
// DO NOT attempt to print options[siteConfig.secure[key]] within `${}` as a malicious script
|
|
|
|
// can exploit the logger's attempt to stringify the value and execute arbitrary code
|
2020-07-29 18:38:59 +02:00
|
|
|
logger.debug(
|
2020-06-26 09:26:56 -04:00
|
|
|
`Denied attempt to modify a secure key ${siteConfig.secure[key]}`,
|
|
|
|
options[siteConfig.secure[key]]
|
|
|
|
);
|
|
|
|
delete options[siteConfig.secure[key]];
|
|
|
|
}
|
|
|
|
});
|
|
|
|
};
|
2020-07-29 18:38:59 +02:00
|
|
|
|
|
|
|
export const addDirective = directive => {
|
|
|
|
directives.push(directive);
|
|
|
|
updateCurrentConfig(siteConfig, directives);
|
|
|
|
};
|
|
|
|
|
2020-06-26 09:26:56 -04:00
|
|
|
/**
|
2020-07-20 20:07:57 -07:00
|
|
|
*## reset
|
2020-07-14 18:11:36 -07:00
|
|
|
*| Function | Description | Type | Required | Values |
|
|
|
|
*| --------- | ------------------- | ------- | -------- | ------------------ |
|
|
|
|
*| reset|Resets currentConfig to conf| Put Request | Required | None|
|
|
|
|
*
|
|
|
|
*| Parameter | Description |Type | Required | Values|
|
|
|
|
*| --- | --- | --- | --- | --- |
|
|
|
|
*| conf| base set of values, which currentConfig coul be **reset** to.| Dictionary | Required | Any Values, with respect to the secure Array|
|
|
|
|
*
|
|
|
|
**Notes :
|
|
|
|
(default: current siteConfig ) (optional, default `getSiteConfig()`)
|
2020-06-26 09:26:56 -04:00
|
|
|
* @param conf - the base currentConfig to reset to (default: current siteConfig )
|
|
|
|
*/
|
2020-07-29 18:38:59 +02:00
|
|
|
export const reset = () => {
|
|
|
|
// Replace current config with siteConfig
|
|
|
|
directives = [];
|
|
|
|
updateCurrentConfig(siteConfig, directives);
|
2020-06-17 18:14:10 -04:00
|
|
|
};
|