payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
287 lines (286 loc) • 34.9 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
Object.defineProperty(exports, "default", {
enumerable: true,
get: function() {
return _default;
}
});
const _crypto = /*#__PURE__*/ _interop_require_default(require("crypto"));
const _fs = /*#__PURE__*/ _interop_require_default(require("fs"));
const _util = require("util");
const _executeAccess = /*#__PURE__*/ _interop_require_default(require("../../auth/executeAccess"));
const _sendVerificationEmail = /*#__PURE__*/ _interop_require_default(require("../../auth/sendVerificationEmail"));
const _register = require("../../auth/strategies/local/register");
const _afterChange = require("../../fields/hooks/afterChange");
const _afterRead = require("../../fields/hooks/afterRead");
const _beforeChange = require("../../fields/hooks/beforeChange");
const _beforeValidate = require("../../fields/hooks/beforeValidate");
const _generateFileData = require("../../uploads/generateFileData");
const _unlinkTempFiles = require("../../uploads/unlinkTempFiles");
const _uploadFiles = require("../../uploads/uploadFiles");
const _commitTransaction = require("../../utilities/commitTransaction");
const _flattenTopLevelFields = /*#__PURE__*/ _interop_require_default(require("../../utilities/flattenTopLevelFields"));
const _initTransaction = require("../../utilities/initTransaction");
const _killTransaction = require("../../utilities/killTransaction");
const _sanitizeInternalFields = /*#__PURE__*/ _interop_require_default(require("../../utilities/sanitizeInternalFields"));
const _saveVersion = require("../../versions/saveVersion");
const _utils = require("./utils");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
const unlinkFile = (0, _util.promisify)(_fs.default.unlink);
async function create(incomingArgs) {
let args = incomingArgs;
try {
const shouldCommit = await (0, _initTransaction.initTransaction)(args.req);
// /////////////////////////////////////
// beforeOperation - Collection
// /////////////////////////////////////
await args.collection.config.hooks.beforeOperation.reduce(async (priorHook, hook)=>{
await priorHook;
args = await hook({
args,
collection: args.collection.config,
context: args.req.context,
operation: 'create',
req: args.req
}) || args;
}, Promise.resolve());
const { autosave = false, collection: { config: collectionConfig }, collection, depth, disableVerificationEmail, draft = false, overrideAccess, overwriteExistingFiles = false, req: { fallbackLocale, locale, payload, payload: { config, emailOptions } }, req, showHiddenFields } = args;
let { data } = args;
const shouldSaveDraft = Boolean(draft && collectionConfig.versions.drafts);
// /////////////////////////////////////
// Access
// /////////////////////////////////////
if (!overrideAccess) {
await (0, _executeAccess.default)({
data,
req
}, collectionConfig.access.create);
}
// /////////////////////////////////////
// Custom id
// /////////////////////////////////////
// @todo: Refactor code to store 'customId' on the collection configuration itself so we don't need to repeat flattenFields
const hasIdField = (0, _flattenTopLevelFields.default)(collectionConfig.fields).findIndex((field)=>field.name === 'id') > -1;
if (hasIdField) {
data = {
_id: data.id,
...data
};
}
// /////////////////////////////////////
// Generate data for all files and sizes
// /////////////////////////////////////
const { data: newFileData, files: filesToUpload } = await (0, _generateFileData.generateFileData)({
collection,
config,
data,
overwriteExistingFiles,
req,
throwOnMissingFile: !shouldSaveDraft && collection.config.upload.filesRequiredOnCreate !== false
});
data = newFileData;
// /////////////////////////////////////
// beforeValidate - Fields
// /////////////////////////////////////
data = await (0, _beforeValidate.beforeValidate)({
collection: collectionConfig,
context: req.context,
data,
doc: {},
global: null,
operation: 'create',
overrideAccess,
req
});
// /////////////////////////////////////
// beforeValidate - Collections
// /////////////////////////////////////
await collectionConfig.hooks.beforeValidate.reduce(async (priorHook, hook)=>{
await priorHook;
data = await hook({
collection: collectionConfig,
context: req.context,
data,
operation: 'create',
req
}) || data;
}, Promise.resolve());
// /////////////////////////////////////
// beforeChange - Collection
// /////////////////////////////////////
await collectionConfig.hooks.beforeChange.reduce(async (priorHook, hook)=>{
await priorHook;
data = await hook({
collection: collectionConfig,
context: req.context,
data,
operation: 'create',
req
}) || data;
}, Promise.resolve());
// /////////////////////////////////////
// beforeChange - Fields
// /////////////////////////////////////
const resultWithLocales = await (0, _beforeChange.beforeChange)({
collection: collectionConfig,
context: req.context,
data,
doc: {},
docWithLocales: {},
global: null,
operation: 'create',
req,
skipValidation: shouldSaveDraft
});
// /////////////////////////////////////
// Write files to local storage
// /////////////////////////////////////
if (!collectionConfig.upload.disableLocalStorage) {
await (0, _uploadFiles.uploadFiles)(payload, filesToUpload, req.t);
}
// /////////////////////////////////////
// Create
// /////////////////////////////////////
let doc;
if (collectionConfig.auth && !collectionConfig.auth.disableLocalStrategy) {
if (data.email) {
resultWithLocales.email = data.email.toLowerCase();
}
if (collectionConfig.auth.verify) {
resultWithLocales._verified = Boolean(resultWithLocales._verified) || false;
resultWithLocales._verificationToken = _crypto.default.randomBytes(20).toString('hex');
}
doc = await (0, _register.registerLocalStrategy)({
collection: collectionConfig,
doc: resultWithLocales,
password: data.password,
payload: req.payload,
req
});
} else {
doc = await payload.db.create({
collection: collectionConfig.slug,
data: resultWithLocales,
req
});
}
const verificationToken = doc._verificationToken;
let result = (0, _sanitizeInternalFields.default)(doc);
// /////////////////////////////////////
// Create version
// /////////////////////////////////////
if (collectionConfig.versions) {
await (0, _saveVersion.saveVersion)({
id: result.id,
autosave,
collection: collectionConfig,
docWithLocales: result,
payload,
req
});
}
// /////////////////////////////////////
// Send verification email if applicable
// /////////////////////////////////////
if (collectionConfig.auth && collectionConfig.auth.verify) {
// eslint-disable-next-line @typescript-eslint/no-floating-promises
(0, _sendVerificationEmail.default)({
collection: {
config: collectionConfig
},
config: payload.config,
disableEmail: disableVerificationEmail,
emailOptions,
req,
sendEmail: payload.sendEmail,
token: verificationToken,
user: result
});
}
// /////////////////////////////////////
// afterRead - Fields
// /////////////////////////////////////
result = await (0, _afterRead.afterRead)({
collection: collectionConfig,
context: req.context,
depth,
doc: result,
fallbackLocale,
global: null,
locale,
overrideAccess,
req,
showHiddenFields
});
// /////////////////////////////////////
// afterRead - Collection
// /////////////////////////////////////
await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook)=>{
await priorHook;
result = await hook({
collection: collectionConfig,
context: req.context,
doc: result,
req
}) || result;
}, Promise.resolve());
// /////////////////////////////////////
// afterChange - Fields
// /////////////////////////////////////
result = await (0, _afterChange.afterChange)({
collection: collectionConfig,
context: req.context,
data,
doc: result,
global: null,
operation: 'create',
previousDoc: {},
req
});
// /////////////////////////////////////
// afterChange - Collection
// /////////////////////////////////////
await collectionConfig.hooks.afterChange.reduce(async (priorHook, hook)=>{
await priorHook;
result = await hook({
collection: collectionConfig,
context: req.context,
doc: result,
operation: 'create',
previousDoc: {},
req: args.req
}) || result;
}, Promise.resolve());
// /////////////////////////////////////
// afterOperation - Collection
// /////////////////////////////////////
result = await (0, _utils.buildAfterOperation)({
args,
collection: collectionConfig,
operation: 'create',
result
});
await (0, _unlinkTempFiles.unlinkTempFiles)({
collectionConfig,
config,
req
});
// /////////////////////////////////////
// Return results
// /////////////////////////////////////
if (shouldCommit) await (0, _commitTransaction.commitTransaction)(req);
return result;
} catch (error) {
await (0, _killTransaction.killTransaction)(args.req);
throw error;
}
}
const _default = create;
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/collections/operations/create.ts"],"sourcesContent":["import type { MarkOptional } from 'ts-essentials'\n\nimport crypto from 'crypto'\nimport fs from 'fs'\nimport { promisify } from 'util'\n\nimport type { GeneratedTypes } from '../../'\nimport type { PayloadRequest } from '../../express/types'\nimport type { Document } from '../../types'\nimport type {\n  AfterChangeHook,\n  BeforeOperationHook,\n  BeforeValidateHook,\n  Collection,\n} from '../config/types'\n\nimport executeAccess from '../../auth/executeAccess'\nimport sendVerificationEmail from '../../auth/sendVerificationEmail'\nimport { registerLocalStrategy } from '../../auth/strategies/local/register'\nimport { afterChange } from '../../fields/hooks/afterChange'\nimport { afterRead } from '../../fields/hooks/afterRead'\nimport { beforeChange } from '../../fields/hooks/beforeChange'\nimport { beforeValidate } from '../../fields/hooks/beforeValidate'\nimport { generateFileData } from '../../uploads/generateFileData'\nimport { unlinkTempFiles } from '../../uploads/unlinkTempFiles'\nimport { uploadFiles } from '../../uploads/uploadFiles'\nimport { commitTransaction } from '../../utilities/commitTransaction'\nimport flattenFields from '../../utilities/flattenTopLevelFields'\nimport { initTransaction } from '../../utilities/initTransaction'\nimport { killTransaction } from '../../utilities/killTransaction'\nimport sanitizeInternalFields from '../../utilities/sanitizeInternalFields'\nimport { saveVersion } from '../../versions/saveVersion'\nimport { buildAfterOperation } from './utils'\n\nconst unlinkFile = promisify(fs.unlink)\n\nexport type CreateUpdateType = { [field: number | string | symbol]: unknown }\n\nexport type Arguments<T extends CreateUpdateType> = {\n  autosave?: boolean\n  collection: Collection\n  data: MarkOptional<T, 'createdAt' | 'id' | 'sizes' | 'updatedAt'>\n  depth?: number\n  disableVerificationEmail?: boolean\n  draft?: boolean\n  overrideAccess?: boolean\n  overwriteExistingFiles?: boolean\n  req: PayloadRequest\n  showHiddenFields?: boolean\n}\n\nasync function create<TSlug extends keyof GeneratedTypes['collections']>(\n  incomingArgs: Arguments<GeneratedTypes['collections'][TSlug]>,\n): Promise<GeneratedTypes['collections'][TSlug]> {\n  let args = incomingArgs\n\n  try {\n    const shouldCommit = await initTransaction(args.req)\n\n    // /////////////////////////////////////\n    // beforeOperation - Collection\n    // /////////////////////////////////////\n\n    await args.collection.config.hooks.beforeOperation.reduce(\n      async (priorHook: BeforeOperationHook | Promise<void>, hook: BeforeOperationHook) => {\n        await priorHook\n\n        args =\n          (await hook({\n            args,\n            collection: args.collection.config,\n            context: args.req.context,\n            operation: 'create',\n            req: args.req,\n          })) || args\n      },\n      Promise.resolve(),\n    )\n\n    const {\n      autosave = false,\n      collection: { config: collectionConfig },\n      collection,\n      depth,\n      disableVerificationEmail,\n      draft = false,\n      overrideAccess,\n      overwriteExistingFiles = false,\n      req: {\n        fallbackLocale,\n        locale,\n        payload,\n        payload: { config, emailOptions },\n      },\n      req,\n      showHiddenFields,\n    } = args\n\n    let { data } = args\n\n    const shouldSaveDraft = Boolean(draft && collectionConfig.versions.drafts)\n\n    // /////////////////////////////////////\n    // Access\n    // /////////////////////////////////////\n\n    if (!overrideAccess) {\n      await executeAccess({ data, req }, collectionConfig.access.create)\n    }\n\n    // /////////////////////////////////////\n    // Custom id\n    // /////////////////////////////////////\n    // @todo: Refactor code to store 'customId' on the collection configuration itself so we don't need to repeat flattenFields\n    const hasIdField =\n      flattenFields(collectionConfig.fields).findIndex((field) => field.name === 'id') > -1\n\n    if (hasIdField) {\n      data = {\n        _id: data.id,\n        ...data,\n      }\n    }\n\n    // /////////////////////////////////////\n    // Generate data for all files and sizes\n    // /////////////////////////////////////\n\n    const { data: newFileData, files: filesToUpload } = await generateFileData({\n      collection,\n      config,\n      data,\n      overwriteExistingFiles,\n      req,\n      throwOnMissingFile:\n        !shouldSaveDraft && collection.config.upload.filesRequiredOnCreate !== false,\n    })\n\n    data = newFileData\n\n    // /////////////////////////////////////\n    // beforeValidate - Fields\n    // /////////////////////////////////////\n\n    data = await beforeValidate({\n      collection: collectionConfig,\n      context: req.context,\n      data,\n      doc: {},\n      global: null,\n      operation: 'create',\n      overrideAccess,\n      req,\n    })\n\n    // /////////////////////////////////////\n    // beforeValidate - Collections\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.beforeValidate.reduce(\n      async (priorHook: BeforeValidateHook | Promise<void>, hook: BeforeValidateHook) => {\n        await priorHook\n\n        data =\n          (await hook({\n            collection: collectionConfig,\n            context: req.context,\n            data,\n            operation: 'create',\n            req,\n          })) || data\n      },\n      Promise.resolve(),\n    )\n\n    // /////////////////////////////////////\n    // beforeChange - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.beforeChange.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      data =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          data,\n          operation: 'create',\n          req,\n        })) || data\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // beforeChange - Fields\n    // /////////////////////////////////////\n\n    const resultWithLocales = await beforeChange<Record<string, unknown>>({\n      collection: collectionConfig,\n      context: req.context,\n      data,\n      doc: {},\n      docWithLocales: {},\n      global: null,\n      operation: 'create',\n      req,\n      skipValidation: shouldSaveDraft,\n    })\n\n    // /////////////////////////////////////\n    // Write files to local storage\n    // /////////////////////////////////////\n\n    if (!collectionConfig.upload.disableLocalStorage) {\n      await uploadFiles(payload, filesToUpload, req.t)\n    }\n\n    // /////////////////////////////////////\n    // Create\n    // /////////////////////////////////////\n\n    let doc\n\n    if (collectionConfig.auth && !collectionConfig.auth.disableLocalStrategy) {\n      if (data.email) {\n        resultWithLocales.email = (data.email as string).toLowerCase()\n      }\n\n      if (collectionConfig.auth.verify) {\n        resultWithLocales._verified = Boolean(resultWithLocales._verified) || false\n        resultWithLocales._verificationToken = crypto.randomBytes(20).toString('hex')\n      }\n\n      doc = await registerLocalStrategy({\n        collection: collectionConfig,\n        doc: resultWithLocales,\n        password: data.password as string,\n        payload: req.payload,\n        req,\n      })\n    } else {\n      doc = await payload.db.create({\n        collection: collectionConfig.slug,\n        data: resultWithLocales,\n        req,\n      })\n    }\n\n    const verificationToken = doc._verificationToken\n    let result: Document = sanitizeInternalFields(doc)\n\n    // /////////////////////////////////////\n    // Create version\n    // /////////////////////////////////////\n\n    if (collectionConfig.versions) {\n      await saveVersion({\n        id: result.id,\n        autosave,\n        collection: collectionConfig,\n        docWithLocales: result,\n        payload,\n        req,\n      })\n    }\n\n    // /////////////////////////////////////\n    // Send verification email if applicable\n    // /////////////////////////////////////\n\n    if (collectionConfig.auth && collectionConfig.auth.verify) {\n      // eslint-disable-next-line @typescript-eslint/no-floating-promises\n      sendVerificationEmail({\n        collection: { config: collectionConfig },\n        config: payload.config,\n        disableEmail: disableVerificationEmail,\n        emailOptions,\n        req,\n        sendEmail: payload.sendEmail,\n        token: verificationToken,\n        user: result,\n      })\n    }\n\n    // /////////////////////////////////////\n    // afterRead - Fields\n    // /////////////////////////////////////\n\n    result = await afterRead({\n      collection: collectionConfig,\n      context: req.context,\n      depth,\n      doc: result,\n      fallbackLocale,\n      global: null,\n      locale,\n      overrideAccess,\n      req,\n      showHiddenFields,\n    })\n\n    // /////////////////////////////////////\n    // afterRead - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.afterRead.reduce(async (priorHook, hook) => {\n      await priorHook\n\n      result =\n        (await hook({\n          collection: collectionConfig,\n          context: req.context,\n          doc: result,\n          req,\n        })) || result\n    }, Promise.resolve())\n\n    // /////////////////////////////////////\n    // afterChange - Fields\n    // /////////////////////////////////////\n\n    result = await afterChange({\n      collection: collectionConfig,\n      context: req.context,\n      data,\n      doc: result,\n      global: null,\n      operation: 'create',\n      previousDoc: {},\n      req,\n    })\n\n    // /////////////////////////////////////\n    // afterChange - Collection\n    // /////////////////////////////////////\n\n    await collectionConfig.hooks.afterChange.reduce(\n      async (priorHook: AfterChangeHook | Promise<void>, hook: AfterChangeHook) => {\n        await priorHook\n\n        result =\n          (await hook({\n            collection: collectionConfig,\n            context: req.context,\n            doc: result,\n            operation: 'create',\n            previousDoc: {},\n            req: args.req,\n          })) || result\n      },\n      Promise.resolve(),\n    )\n\n    // /////////////////////////////////////\n    // afterOperation - Collection\n    // /////////////////////////////////////\n\n    result = await buildAfterOperation<GeneratedTypes['collections'][TSlug]>({\n      args,\n      collection: collectionConfig,\n      operation: 'create',\n      result,\n    })\n\n    await unlinkTempFiles({ collectionConfig, config, req })\n\n    // /////////////////////////////////////\n    // Return results\n    // /////////////////////////////////////\n\n    if (shouldCommit) await commitTransaction(req)\n\n    return result\n  } catch (error: unknown) {\n    await killTransaction(args.req)\n    throw error\n  }\n}\n\nexport default create\n"],"names":["unlinkFile","promisify","fs","unlink","create","incomingArgs","args","shouldCommit","initTransaction","req","collection","config","hooks","beforeOperation","reduce","priorHook","hook","context","operation","Promise","resolve","autosave","collectionConfig","depth","disableVerificationEmail","draft","overrideAccess","overwriteExistingFiles","fallbackLocale","locale","payload","emailOptions","showHiddenFields","data","shouldSaveDraft","Boolean","versions","drafts","executeAccess","access","hasIdField","flattenFields","fields","findIndex","field","name","_id","id","newFileData","files","filesToUpload","generateFileData","throwOnMissingFile","upload","filesRequiredOnCreate","beforeValidate","doc","global","beforeChange","resultWithLocales","docWithLocales","skipValidation","disableLocalStorage","uploadFiles","t","auth","disableLocalStrategy","email","toLowerCase","verify","_verified","_verificationToken","crypto","randomBytes","toString","registerLocalStrategy","password","db","slug","verificationToken","result","sanitizeInternalFields","saveVersion","sendVerificationEmail","disableEmail","sendEmail","token","user","afterRead","afterChange","previousDoc","buildAfterOperation","unlinkTempFiles","commitTransaction","error","killTransaction"],"mappings":"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"}