payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
144 lines (143 loc) • 18.3 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _deepmerge = /*#__PURE__*/ _interop_require_default(require("deepmerge"));
const _isplainobject = require("is-plain-object");
const _accountLock = /*#__PURE__*/ _interop_require_default(require("../../auth/baseFields/accountLock"));
const _apiKey = /*#__PURE__*/ _interop_require_default(require("../../auth/baseFields/apiKey"));
const _auth = /*#__PURE__*/ _interop_require_default(require("../../auth/baseFields/auth"));
const _verification = /*#__PURE__*/ _interop_require_default(require("../../auth/baseFields/verification"));
const _TimestampsRequired = /*#__PURE__*/ _interop_require_default(require("../../errors/TimestampsRequired"));
const _sanitize = require("../../fields/config/sanitize");
const _types = require("../../fields/config/types");
const _mergeBaseFields = /*#__PURE__*/ _interop_require_default(require("../../fields/mergeBaseFields"));
const _extractTranslations = require("../../translations/extractTranslations");
const _getBaseFields = /*#__PURE__*/ _interop_require_default(require("../../uploads/getBaseFields"));
const _formatLabels = require("../../utilities/formatLabels");
const _baseFields = /*#__PURE__*/ _interop_require_default(require("../../versions/baseFields"));
const _defaults = require("./defaults");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const translations = (0, _extractTranslations.extractTranslations)([
'general:createdAt',
'general:updatedAt'
]);
const sanitizeCollection = (config, collection)=>{
// /////////////////////////////////
// Make copy of collection config
// /////////////////////////////////
const sanitized = (0, _deepmerge.default)(_defaults.defaults, collection, {
isMergeableObject: _isplainobject.isPlainObject
});
if (sanitized.timestamps !== false) {
// add default timestamps fields only as needed
let hasUpdatedAt = null;
let hasCreatedAt = null;
sanitized.fields.some((field)=>{
if ((0, _types.fieldAffectsData)(field)) {
if (field.name === 'updatedAt') hasUpdatedAt = true;
if (field.name === 'createdAt') hasCreatedAt = true;
}
return hasCreatedAt && hasUpdatedAt;
});
if (!hasUpdatedAt) {
sanitized.fields.push({
name: 'updatedAt',
admin: {
disableBulkEdit: true,
hidden: true
},
label: translations['general:updatedAt'],
type: 'date'
});
}
if (!hasCreatedAt) {
sanitized.fields.push({
name: 'createdAt',
admin: {
disableBulkEdit: true,
hidden: true
},
// The default sort for list view is createdAt. Thus, enabling indexing by default, is a major performance improvement, especially for large or a large amount of collections.
index: true,
label: translations['general:createdAt'],
type: 'date'
});
}
}
sanitized.labels = sanitized.labels || (0, _formatLabels.formatLabels)(sanitized.slug);
if (sanitized.versions) {
if (sanitized.versions === true) sanitized.versions = {
drafts: false
};
if (sanitized.timestamps === false) {
throw new _TimestampsRequired.default(collection);
}
if (sanitized.versions.drafts) {
if (sanitized.versions.drafts === true) {
sanitized.versions.drafts = {
autosave: false
};
}
if (sanitized.versions.drafts.autosave === true) {
sanitized.versions.drafts.autosave = {
interval: 2000
};
}
sanitized.fields = (0, _mergeBaseFields.default)(sanitized.fields, _baseFields.default);
}
}
if (sanitized.upload) {
if (sanitized.upload === true) sanitized.upload = {};
sanitized.upload.staticDir = sanitized.upload.staticDir || sanitized.slug;
sanitized.upload.staticURL = sanitized.upload.staticURL || `/${sanitized.slug}`;
sanitized.admin.useAsTitle = sanitized.admin.useAsTitle && sanitized.admin.useAsTitle !== 'id' ? sanitized.admin.useAsTitle : 'filename';
const uploadFields = (0, _getBaseFields.default)({
collection: sanitized,
config
});
sanitized.fields = (0, _mergeBaseFields.default)(sanitized.fields, uploadFields);
}
if (sanitized.auth) {
sanitized.auth = (0, _deepmerge.default)(_defaults.authDefaults, typeof sanitized.auth === 'object' ? sanitized.auth : {}, {
isMergeableObject: _isplainobject.isPlainObject
});
let authFields = [];
if (sanitized.auth.useAPIKey) {
authFields = authFields.concat(_apiKey.default);
}
if (!sanitized.auth.disableLocalStrategy) {
authFields = authFields.concat(_auth.default);
if (sanitized.auth.verify) {
if (sanitized.auth.verify === true) sanitized.auth.verify = {};
authFields = authFields.concat(_verification.default);
}
if (sanitized.auth.maxLoginAttempts > 0) {
authFields = authFields.concat(_accountLock.default);
}
}
sanitized.fields = (0, _mergeBaseFields.default)(sanitized.fields, authFields);
}
// /////////////////////////////////
// Sanitize fields
// /////////////////////////////////
const validRelationships = config.collections.map((c)=>c.slug) || [];
sanitized.fields = (0, _sanitize.sanitizeFields)({
config,
fields: sanitized.fields,
validRelationships
});
return sanitized;
};
const _default = sanitizeCollection;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/config/sanitize.ts"],"sourcesContent":["import merge from 'deepmerge'\nimport { isPlainObject } from 'is-plain-object'\n\nimport type { Config } from '../../config/types'\nimport type { CollectionConfig, SanitizedCollectionConfig } from './types'\n\nimport baseAccountLockFields from '../../auth/baseFields/accountLock'\nimport baseAPIKeyFields from '../../auth/baseFields/apiKey'\nimport baseAuthFields from '../../auth/baseFields/auth'\nimport baseVerificationFields from '../../auth/baseFields/verification'\nimport TimestampsRequired from '../../errors/TimestampsRequired'\nimport { sanitizeFields } from '../../fields/config/sanitize'\nimport { fieldAffectsData } from '../../fields/config/types'\nimport mergeBaseFields from '../../fields/mergeBaseFields'\nimport { extractTranslations } from '../../translations/extractTranslations'\nimport getBaseUploadFields from '../../uploads/getBaseFields'\nimport { formatLabels } from '../../utilities/formatLabels'\nimport baseVersionFields from '../../versions/baseFields'\nimport { authDefaults, defaults } from './defaults'\n\nconst translations = extractTranslations(['general:createdAt', 'general:updatedAt'])\n\nconst sanitizeCollection = (\n  config: Config,\n  collection: CollectionConfig,\n): SanitizedCollectionConfig => {\n  // /////////////////////////////////\n  // Make copy of collection config\n  // /////////////////////////////////\n\n  const sanitized: CollectionConfig = merge(defaults, collection, {\n    isMergeableObject: isPlainObject,\n  })\n\n  if (sanitized.timestamps !== false) {\n    // add default timestamps fields only as needed\n    let hasUpdatedAt = null\n    let hasCreatedAt = null\n    sanitized.fields.some((field) => {\n      if (fieldAffectsData(field)) {\n        if (field.name === 'updatedAt') hasUpdatedAt = true\n        if (field.name === 'createdAt') hasCreatedAt = true\n      }\n      return hasCreatedAt && hasUpdatedAt\n    })\n    if (!hasUpdatedAt) {\n      sanitized.fields.push({\n        name: 'updatedAt',\n        admin: {\n          disableBulkEdit: true,\n          hidden: true,\n        },\n        label: translations['general:updatedAt'],\n        type: 'date',\n      })\n    }\n    if (!hasCreatedAt) {\n      sanitized.fields.push({\n        name: 'createdAt',\n        admin: {\n          disableBulkEdit: true,\n          hidden: true,\n        },\n        // The default sort for list view is createdAt. Thus, enabling indexing by default, is a major performance improvement, especially for large or a large amount of collections.\n        index: true,\n        label: translations['general:createdAt'],\n        type: 'date',\n      })\n    }\n  }\n\n  sanitized.labels = sanitized.labels || formatLabels(sanitized.slug)\n\n  if (sanitized.versions) {\n    if (sanitized.versions === true) sanitized.versions = { drafts: false }\n\n    if (sanitized.timestamps === false) {\n      throw new TimestampsRequired(collection)\n    }\n\n    if (sanitized.versions.drafts) {\n      if (sanitized.versions.drafts === true) {\n        sanitized.versions.drafts = {\n          autosave: false,\n        }\n      }\n\n      if (sanitized.versions.drafts.autosave === true) {\n        sanitized.versions.drafts.autosave = {\n          interval: 2000,\n        }\n      }\n\n      sanitized.fields = mergeBaseFields(sanitized.fields, baseVersionFields)\n    }\n  }\n\n  if (sanitized.upload) {\n    if (sanitized.upload === true) sanitized.upload = {}\n\n    sanitized.upload.staticDir = sanitized.upload.staticDir || sanitized.slug\n    sanitized.upload.staticURL = sanitized.upload.staticURL || `/${sanitized.slug}`\n    sanitized.admin.useAsTitle =\n      sanitized.admin.useAsTitle && sanitized.admin.useAsTitle !== 'id'\n        ? sanitized.admin.useAsTitle\n        : 'filename'\n\n    const uploadFields = getBaseUploadFields({\n      collection: sanitized,\n      config,\n    })\n\n    sanitized.fields = mergeBaseFields(sanitized.fields, uploadFields)\n  }\n\n  if (sanitized.auth) {\n    sanitized.auth = merge(authDefaults, typeof sanitized.auth === 'object' ? sanitized.auth : {}, {\n      isMergeableObject: isPlainObject,\n    })\n\n    let authFields = []\n\n    if (sanitized.auth.useAPIKey) {\n      authFields = authFields.concat(baseAPIKeyFields)\n    }\n\n    if (!sanitized.auth.disableLocalStrategy) {\n      authFields = authFields.concat(baseAuthFields)\n\n      if (sanitized.auth.verify) {\n        if (sanitized.auth.verify === true) sanitized.auth.verify = {}\n        authFields = authFields.concat(baseVerificationFields)\n      }\n\n      if (sanitized.auth.maxLoginAttempts > 0) {\n        authFields = authFields.concat(baseAccountLockFields)\n      }\n    }\n\n    sanitized.fields = mergeBaseFields(sanitized.fields, authFields)\n  }\n\n  // /////////////////////////////////\n  // Sanitize fields\n  // /////////////////////////////////\n\n  const validRelationships = config.collections.map((c) => c.slug) || []\n  sanitized.fields = sanitizeFields({\n    config,\n    fields: sanitized.fields,\n    validRelationships,\n  })\n\n  return sanitized as SanitizedCollectionConfig\n}\n\nexport default sanitizeCollection\n"],"names":["translations","extractTranslations","sanitizeCollection","config","collection","sanitized","merge","defaults","isMergeableObject","isPlainObject","timestamps","hasUpdatedAt","hasCreatedAt","fields","some","field","fieldAffectsData","name","push","admin","disableBulkEdit","hidden","label","type","index","labels","formatLabels","slug","versions","drafts","TimestampsRequired","autosave","interval","mergeBaseFields","baseVersionFields","upload","staticDir","staticURL","useAsTitle","uploadFields","getBaseUploadFields","auth","authDefaults","authFields","useAPIKey","concat","baseAPIKeyFields","disableLocalStrategy","baseAuthFields","verify","baseVerificationFields","maxLoginAttempts","baseAccountLockFields","validRelationships","collections","map","c","sanitizeFields"],"mappings":"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"}