payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
92 lines (91 loc) • 12.7 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "sanitizeConfig", {
enumerable: true,
get: function() {
return sanitizeConfig;
}
});
const _deepmerge = /*#__PURE__*/ _interop_require_default(require("deepmerge"));
const _isplainobject = require("is-plain-object");
const _defaultUser = require("../auth/defaultUser");
const _sanitize = /*#__PURE__*/ _interop_require_default(require("../collections/config/sanitize"));
const _migrationsCollection = require("../database/migrations/migrationsCollection");
const _errors = require("../errors");
const _sanitize1 = /*#__PURE__*/ _interop_require_default(require("../globals/config/sanitize"));
const _preferencesCollection = /*#__PURE__*/ _interop_require_default(require("../preferences/preferencesCollection"));
const _checkDuplicateCollections = /*#__PURE__*/ _interop_require_default(require("../utilities/checkDuplicateCollections"));
const _defaults = require("./defaults");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const sanitizeAdminConfig = (configToSanitize)=>{
const sanitizedConfig = {
...configToSanitize
};
// add default user collection if none provided
if (!sanitizedConfig?.admin?.user) {
const firstCollectionWithAuth = sanitizedConfig.collections.find(({ auth })=>Boolean(auth));
if (firstCollectionWithAuth) {
sanitizedConfig.admin.user = firstCollectionWithAuth.slug;
} else {
sanitizedConfig.admin.user = _defaultUser.defaultUserCollection.slug;
sanitizedConfig.collections.push(_defaultUser.defaultUserCollection);
}
}
if (!sanitizedConfig.collections.find(({ slug })=>slug === sanitizedConfig.admin.user)) {
throw new _errors.InvalidConfiguration(`${sanitizedConfig.admin.user} is not a valid admin user collection`);
}
return sanitizedConfig;
};
const sanitizeConfig = (incomingConfig)=>{
const configWithDefaults = (0, _deepmerge.default)(_defaults.defaults, incomingConfig, {
isMergeableObject: _isplainobject.isPlainObject
});
if (!configWithDefaults.serverURL) {
configWithDefaults.serverURL = '';
}
const config = sanitizeAdminConfig(configWithDefaults);
if (config.localization && config.localization.locales?.length > 0) {
// clone localization config so to not break everything
const firstLocale = config.localization.locales[0];
if (typeof firstLocale === 'string') {
config.localization.localeCodes = [
...config.localization.locales
];
// is string[], so convert to Locale[]
config.localization.locales = config.localization.locales.map((locale)=>({
code: locale,
label: locale,
rtl: false,
toString: ()=>locale
}));
} else {
// is Locale[], so convert to string[] for localeCodes
config.localization.localeCodes = config.localization.locales.reduce((locales, locale)=>{
locales.push(locale.code);
return locales;
}, []);
config.localization.locales = config.localization.locales.map((locale)=>({
...locale,
toString: ()=>locale.code
}));
}
}
configWithDefaults.collections.push((0, _preferencesCollection.default)(configWithDefaults));
configWithDefaults.collections.push(_migrationsCollection.migrationsCollection);
config.collections = config.collections.map((collection)=>(0, _sanitize.default)(configWithDefaults, collection));
(0, _checkDuplicateCollections.default)(config.collections);
if (config.globals.length > 0) {
config.globals = (0, _sanitize1.default)(config);
}
if (config.serverURL !== '') {
config.csrf.push(config.serverURL);
}
return config;
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/config/sanitize.ts"],"sourcesContent":["import merge from 'deepmerge'\nimport { isPlainObject } from 'is-plain-object'\n\nimport type {\n  Config,\n  LocalizationConfigWithLabels,\n  LocalizationConfigWithNoLabels,\n  SanitizedConfig,\n} from './types'\n\nimport { defaultUserCollection } from '../auth/defaultUser'\nimport sanitizeCollection from '../collections/config/sanitize'\nimport { migrationsCollection } from '../database/migrations/migrationsCollection'\nimport { InvalidConfiguration } from '../errors'\nimport sanitizeGlobals from '../globals/config/sanitize'\nimport getPreferencesCollection from '../preferences/preferencesCollection'\nimport checkDuplicateCollections from '../utilities/checkDuplicateCollections'\nimport { defaults } from './defaults'\n\nconst sanitizeAdminConfig = (configToSanitize: Config): Partial<SanitizedConfig> => {\n  const sanitizedConfig = { ...configToSanitize }\n\n  // add default user collection if none provided\n  if (!sanitizedConfig?.admin?.user) {\n    const firstCollectionWithAuth = sanitizedConfig.collections.find(({ auth }) => Boolean(auth))\n    if (firstCollectionWithAuth) {\n      sanitizedConfig.admin.user = firstCollectionWithAuth.slug\n    } else {\n      sanitizedConfig.admin.user = defaultUserCollection.slug\n      sanitizedConfig.collections.push(defaultUserCollection)\n    }\n  }\n\n  if (!sanitizedConfig.collections.find(({ slug }) => slug === sanitizedConfig.admin.user)) {\n    throw new InvalidConfiguration(\n      `${sanitizedConfig.admin.user} is not a valid admin user collection`,\n    )\n  }\n\n  return sanitizedConfig as Partial<SanitizedConfig>\n}\n\nexport const sanitizeConfig = (incomingConfig: Config): SanitizedConfig => {\n  const configWithDefaults: Config = merge(defaults, incomingConfig, {\n    isMergeableObject: isPlainObject,\n  }) as Config\n\n  if (!configWithDefaults.serverURL) {\n    configWithDefaults.serverURL = ''\n  }\n\n  const config: Partial<SanitizedConfig> = sanitizeAdminConfig(configWithDefaults)\n\n  if (config.localization && config.localization.locales?.length > 0) {\n    // clone localization config so to not break everything\n    const firstLocale = config.localization.locales[0]\n    if (typeof firstLocale === 'string') {\n      config.localization.localeCodes = [\n        ...(config.localization as unknown as LocalizationConfigWithNoLabels).locales,\n      ]\n\n      // is string[], so convert to Locale[]\n      config.localization.locales = (\n        config.localization as unknown as LocalizationConfigWithNoLabels\n      ).locales.map((locale) => ({\n        code: locale,\n        label: locale,\n        rtl: false,\n        toString: () => locale,\n      }))\n    } else {\n      // is Locale[], so convert to string[] for localeCodes\n      config.localization.localeCodes = config.localization.locales.reduce((locales, locale) => {\n        locales.push(locale.code)\n        return locales\n      }, [] as string[])\n\n      config.localization.locales = (\n        config.localization as LocalizationConfigWithLabels\n      ).locales.map((locale) => ({\n        ...locale,\n        toString: () => locale.code,\n      }))\n    }\n  }\n\n  configWithDefaults.collections.push(getPreferencesCollection(configWithDefaults))\n  configWithDefaults.collections.push(migrationsCollection)\n\n  config.collections = config.collections.map((collection) =>\n    sanitizeCollection(configWithDefaults, collection),\n  )\n  checkDuplicateCollections(config.collections)\n\n  if (config.globals.length > 0) {\n    config.globals = sanitizeGlobals(config as SanitizedConfig)\n  }\n\n  if (config.serverURL !== '') {\n    config.csrf.push(config.serverURL)\n  }\n\n  return config as SanitizedConfig\n}\n"],"names":["sanitizeConfig","sanitizeAdminConfig","configToSanitize","sanitizedConfig","admin","user","firstCollectionWithAuth","collections","find","auth","Boolean","slug","defaultUserCollection","push","InvalidConfiguration","incomingConfig","configWithDefaults","merge","defaults","isMergeableObject","isPlainObject","serverURL","config","localization","locales","length","firstLocale","localeCodes","map","locale","code","label","rtl","toString","reduce","getPreferencesCollection","migrationsCollection","collection","sanitizeCollection","checkDuplicateCollections","globals","sanitizeGlobals","csrf"],"mappings":"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"}