payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
267 lines (266 loc) • 37.2 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
function _export(target, all) {
for(var name in all)Object.defineProperty(target, name, {
enumerable: true,
get: all[name]
});
}
_export(exports, {
BasePayload: function() {
return BasePayload;
},
getPayload: function() {
return getPayload;
}
});
const _crypto = /*#__PURE__*/ _interop_require_default(require("crypto"));
const _path = /*#__PURE__*/ _interop_require_default(require("path"));
const _crypto1 = require("./auth/crypto");
const _local = /*#__PURE__*/ _interop_require_default(require("./collections/operations/local"));
const _find = /*#__PURE__*/ _interop_require_default(require("./config/find"));
const _build = /*#__PURE__*/ _interop_require_default(require("./email/build"));
const _defaults = require("./email/defaults");
const _sendEmail = /*#__PURE__*/ _interop_require_default(require("./email/sendEmail"));
const _local1 = /*#__PURE__*/ _interop_require_default(require("./globals/operations/local"));
const _registerSchema = /*#__PURE__*/ _interop_require_default(require("./graphql/registerSchema"));
const _logger = /*#__PURE__*/ _interop_require_default(require("./utilities/logger"));
const _serverInit = require("./utilities/telemetry/events/serverInit");
function _interop_require_default(obj) {
return obj && obj.__esModule ? obj : {
default: obj
};
}
class BasePayload {
Mutation = {
name: 'Mutation',
fields: {}
};
Query = {
name: 'Query',
fields: {}
};
authenticate;
collections = {};
config;
/**
* @description Performs create operation
* @param options
* @returns created document
*/ create = async (options)=>{
const { create } = _local.default;
return create(this, options);
};
db;
decrypt = _crypto1.decrypt;
email;
emailOptions;
encrypt = _crypto1.encrypt;
errorHandler;
express;
extensions;
/**
* @description Find documents with criteria
* @param options
* @returns documents satisfying query
*/ find = async (options)=>{
const { find } = _local.default;
return find(this, options);
};
findByID = async (options)=>{
const { findByID } = _local.default;
return findByID(this, options);
};
findGlobal = async (options)=>{
const { findOne } = _local1.default;
return findOne(this, options);
};
/**
* @description Find global version by ID
* @param options
* @returns global version with specified ID
*/ findGlobalVersionByID = async (options)=>{
const { findVersionByID } = _local1.default;
return findVersionByID(this, options);
};
/**
* @description Find global versions with criteria
* @param options
* @returns versions satisfying query
*/ findGlobalVersions = async (options)=>{
const { findVersions } = _local1.default;
return findVersions(this, options);
};
/**
* @description Find version by ID
* @param options
* @returns version with specified ID
*/ findVersionByID = async (options)=>{
const { findVersionByID } = _local.default;
return findVersionByID(this, options);
};
/**
* @description Find versions with criteria
* @param options
* @returns versions satisfying query
*/ findVersions = async (options)=>{
const { findVersions } = _local.default;
return findVersions(this, options);
};
forgotPassword = async (options)=>{
const { forgotPassword } = _local.default.auth;
return forgotPassword(this, options);
};
getAPIURL = ()=>`${this.config.serverURL}${this.config.routes.api}`;
getAdminURL = ()=>`${this.config.serverURL}${this.config.routes.admin}`;
globals;
local;
logger;
login = async (options)=>{
const { login } = _local.default.auth;
return login(this, options);
};
/**
* @description Find document by ID
* @param options
* @returns document with specified ID
*/ resetPassword = async (options)=>{
const { resetPassword } = _local.default.auth;
return resetPassword(this, options);
};
/**
* @description Restore global version by ID
* @param options
* @returns version with specified ID
*/ restoreGlobalVersion = async (options)=>{
const { restoreVersion } = _local1.default;
return restoreVersion(this, options);
};
/**
* @description Restore version by ID
* @param options
* @returns version with specified ID
*/ restoreVersion = async (options)=>{
const { restoreVersion } = _local.default;
return restoreVersion(this, options);
};
router;
schema;
secret;
sendEmail;
types;
unlock = async (options)=>{
const { unlock } = _local.default.auth;
return unlock(this, options);
};
updateGlobal = async (options)=>{
const { update } = _local1.default;
return update(this, options);
};
validationRules;
verifyEmail = async (options)=>{
const { verifyEmail } = _local.default.auth;
return verifyEmail(this, options);
};
versions = {};
delete(options) {
const { deleteLocal } = _local.default;
return deleteLocal(this, options);
}
/**
* @description Initializes Payload
* @param options
*/ // @ts-expect-error // TODO: TypeScript hallucinating again. fix later
async init(options) {
this.logger = options.logger ?? (0, _logger.default)('payload', options.loggerOptions, options.loggerDestination);
if (!options.secret) {
throw new Error('Error: missing secret key. A secret key is needed to secure Payload.');
}
this.secret = _crypto.default.createHash('sha256').update(options.secret).digest('hex').slice(0, 32);
this.local = options.local;
if (options.config) {
this.config = await options.config;
const configPath = (0, _find.default)();
this.config = {
...this.config,
paths: {
config: configPath,
configDir: _path.default.dirname(configPath),
rawConfig: configPath
}
};
} else {
// eslint-disable-next-line @typescript-eslint/no-var-requires, global-require
const loadConfig = require('./config/load').default;
this.config = await loadConfig(this.logger);
}
this.globals = {
config: this.config.globals
};
this.config.collections.forEach((collection)=>{
this.collections[collection.slug] = {
config: collection
};
});
this.db = this.config.db({
payload: this
});
this.db.payload = this;
if (this.db?.init) {
await this.db.init(this);
}
if (!options.disableDBConnect && this.db.connect) {
await this.db.connect(this);
}
this.logger.info('Starting Payload...');
// Configure email service
const emailOptions = options.email ? {
...options.email
} : this.config.email;
if (options.email && this.config.email) {
this.logger.warn('Email options provided in both init options and config. Using init options.');
}
this.emailOptions = emailOptions ?? _defaults.defaults;
this.email = (0, _build.default)(this.emailOptions, this.logger);
this.sendEmail = _sendEmail.default.bind(this);
if (!this.config.graphQL.disable) {
(0, _registerSchema.default)(this);
}
(0, _serverInit.serverInit)(this);
if (!options.disableOnInit) {
if (typeof options.onInit === 'function') await options.onInit(this);
if (typeof this.config.onInit === 'function') await this.config.onInit(this);
}
return this;
}
update(options) {
const { update } = _local.default;
return update(this, options);
}
}
let cached = global._payload;
if (!cached) {
// eslint-disable-next-line no-multi-assign
cached = global._payload = {
payload: null,
promise: null
};
}
const getPayload = async (options)=>{
if (cached.payload) {
return cached.payload;
}
if (!cached.promise) {
cached.promise = new BasePayload().init(options);
}
try {
cached.payload = await cached.promise;
} catch (e) {
cached.promise = null;
throw e;
}
return cached.payload;
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/payload.ts"],"sourcesContent":["import type { Express, Router } from 'express'\nimport type { ExecutionResult, GraphQLSchema, ValidationRule } from 'graphql'\n// @ts-expect-error // TODO Fix this - moduleResolution 16 breaks this import\nimport type { OperationArgs, Request as graphQLRequest } from 'graphql-http/lib/handler'\nimport type { SendMailOptions } from 'nodemailer'\nimport type pino from 'pino'\n\nimport crypto from 'crypto'\nimport path from 'path'\n\nimport type { DatabaseAdapter, GeneratedTypes } from './' // Must import from Payload to support declare module\nimport type { Result as ForgotPasswordResult } from './auth/operations/forgotPassword'\nimport type { Options as ForgotPasswordOptions } from './auth/operations/local/forgotPassword'\nimport type { Options as LoginOptions } from './auth/operations/local/login'\nimport type { Options as ResetPasswordOptions } from './auth/operations/local/resetPassword'\nimport type { Options as UnlockOptions } from './auth/operations/local/unlock'\nimport type { Options as VerifyEmailOptions } from './auth/operations/local/verifyEmail'\nimport type { Result as LoginResult } from './auth/operations/login'\nimport type { Result as ResetPasswordResult } from './auth/operations/resetPassword'\nimport type { BulkOperationResult, Collection } from './collections/config/types'\nimport type { Options as CreateOptions } from './collections/operations/local/create'\nimport type {\n  ByIDOptions as DeleteByIDOptions,\n  ManyOptions as DeleteManyOptions,\n  Options as DeleteOptions,\n} from './collections/operations/local/delete'\nimport type { Options as FindOptions } from './collections/operations/local/find'\nimport type { Options as FindByIDOptions } from './collections/operations/local/findByID'\nimport type { Options as FindVersionByIDOptions } from './collections/operations/local/findVersionByID'\nimport type { Options as FindVersionsOptions } from './collections/operations/local/findVersions'\nimport type { Options as RestoreVersionOptions } from './collections/operations/local/restoreVersion'\nimport type {\n  ByIDOptions as UpdateByIDOptions,\n  ManyOptions as UpdateManyOptions,\n  Options as UpdateOptions,\n} from './collections/operations/local/update'\nimport type { EmailOptions, InitOptions, SanitizedConfig } from './config/types'\nimport type { PaginatedDocs } from './database/types'\nimport type { BuildEmailResult } from './email/types'\nimport type { PayloadAuthenticate } from './express/middleware/authenticate'\nimport type { ErrorHandler } from './express/middleware/errorHandler'\nimport type { Globals } from './globals/config/types'\nimport type { Options as FindGlobalOptions } from './globals/operations/local/findOne'\nimport type { Options as FindGlobalVersionByIDOptions } from './globals/operations/local/findVersionByID'\nimport type { Options as FindGlobalVersionsOptions } from './globals/operations/local/findVersions'\nimport type { Options as RestoreGlobalVersionOptions } from './globals/operations/local/restoreVersion'\nimport type { Options as UpdateGlobalOptions } from './globals/operations/local/update'\nimport type { TypeWithVersion } from './versions/types'\n\nimport { decrypt, encrypt } from './auth/crypto'\nimport localOperations from './collections/operations/local'\nimport findConfig from './config/find'\nimport buildEmail from './email/build'\nimport { defaults as emailDefaults } from './email/defaults'\nimport sendEmail from './email/sendEmail'\nimport localGlobalOperations from './globals/operations/local'\nimport registerGraphQLSchema from './graphql/registerSchema'\nimport Logger from './utilities/logger'\nimport { serverInit as serverInitTelemetry } from './utilities/telemetry/events/serverInit'\n\n/**\n * @description Payload\n */\nexport class BasePayload<TGeneratedTypes extends GeneratedTypes> {\n  Mutation: { fields: { [key: string]: any }; name: string } = { name: 'Mutation', fields: {} }\n\n  Query: { fields: { [key: string]: any }; name: string } = { name: 'Query', fields: {} }\n\n  authenticate: PayloadAuthenticate\n\n  collections: {\n    [slug: number | string | symbol]: Collection\n  } = {}\n\n  config: SanitizedConfig\n\n  /**\n   * @description Performs create operation\n   * @param options\n   * @returns created document\n   */\n  create = async <T extends keyof TGeneratedTypes['collections']>(\n    options: CreateOptions<T>,\n  ): Promise<TGeneratedTypes['collections'][T]> => {\n    const { create } = localOperations\n    return create<T>(this, options)\n  }\n\n  db: DatabaseAdapter\n\n  decrypt = decrypt\n\n  email: BuildEmailResult\n\n  emailOptions: EmailOptions\n\n  encrypt = encrypt\n\n  errorHandler: ErrorHandler\n\n  express?: Express\n\n  extensions: (args: {\n    args: OperationArgs<any>\n    req: graphQLRequest<unknown, unknown>\n    result: ExecutionResult\n  }) => Promise<any>\n\n  /**\n   * @description Find documents with criteria\n   * @param options\n   * @returns documents satisfying query\n   */\n  find = async <T extends keyof TGeneratedTypes['collections']>(\n    options: FindOptions<T>,\n  ): Promise<PaginatedDocs<TGeneratedTypes['collections'][T]>> => {\n    const { find } = localOperations\n    return find<T>(this, options)\n  }\n\n  findByID = async <T extends keyof TGeneratedTypes['collections']>(\n    options: FindByIDOptions<T>,\n  ): Promise<TGeneratedTypes['collections'][T]> => {\n    const { findByID } = localOperations\n    return findByID<T>(this, options)\n  }\n\n  findGlobal = async <T extends keyof TGeneratedTypes['globals']>(\n    options: FindGlobalOptions<T>,\n  ): Promise<TGeneratedTypes['globals'][T]> => {\n    const { findOne } = localGlobalOperations\n    return findOne<T>(this, options)\n  }\n\n  /**\n   * @description Find global version by ID\n   * @param options\n   * @returns global version with specified ID\n   */\n  findGlobalVersionByID = async <T extends keyof TGeneratedTypes['globals']>(\n    options: FindGlobalVersionByIDOptions<T>,\n  ): Promise<TypeWithVersion<TGeneratedTypes['globals'][T]>> => {\n    const { findVersionByID } = localGlobalOperations\n    return findVersionByID<T>(this, options)\n  }\n\n  /**\n   * @description Find global versions with criteria\n   * @param options\n   * @returns versions satisfying query\n   */\n  findGlobalVersions = async <T extends keyof TGeneratedTypes['globals']>(\n    options: FindGlobalVersionsOptions<T>,\n  ): Promise<PaginatedDocs<TypeWithVersion<TGeneratedTypes['globals'][T]>>> => {\n    const { findVersions } = localGlobalOperations\n    return findVersions<T>(this, options)\n  }\n\n  /**\n   * @description Find version by ID\n   * @param options\n   * @returns version with specified ID\n   */\n  findVersionByID = async <T extends keyof TGeneratedTypes['collections']>(\n    options: FindVersionByIDOptions<T>,\n  ): Promise<TypeWithVersion<TGeneratedTypes['collections'][T]>> => {\n    const { findVersionByID } = localOperations\n    return findVersionByID<T>(this, options)\n  }\n\n  /**\n   * @description Find versions with criteria\n   * @param options\n   * @returns versions satisfying query\n   */\n  findVersions = async <T extends keyof TGeneratedTypes['collections']>(\n    options: FindVersionsOptions<T>,\n  ): Promise<PaginatedDocs<TypeWithVersion<TGeneratedTypes['collections'][T]>>> => {\n    const { findVersions } = localOperations\n    return findVersions<T>(this, options)\n  }\n\n  forgotPassword = async <T extends keyof TGeneratedTypes['collections']>(\n    options: ForgotPasswordOptions<T>,\n  ): Promise<ForgotPasswordResult> => {\n    const { forgotPassword } = localOperations.auth\n    return forgotPassword<T>(this, options)\n  }\n\n  getAPIURL = (): string => `${this.config.serverURL}${this.config.routes.api}`\n\n  getAdminURL = (): string => `${this.config.serverURL}${this.config.routes.admin}`\n\n  globals: Globals\n\n  local: boolean\n\n  logger: pino.Logger\n\n  login = async <T extends keyof TGeneratedTypes['collections']>(\n    options: LoginOptions<T>,\n  ): Promise<LoginResult & { user: TGeneratedTypes['collections'][T] }> => {\n    const { login } = localOperations.auth\n    return login<T>(this, options)\n  }\n\n  /**\n   * @description Find document by ID\n   * @param options\n   * @returns document with specified ID\n   */\n\n  resetPassword = async <T extends keyof TGeneratedTypes['collections']>(\n    options: ResetPasswordOptions<T>,\n  ): Promise<ResetPasswordResult> => {\n    const { resetPassword } = localOperations.auth\n    return resetPassword<T>(this, options)\n  }\n\n  /**\n   * @description Restore global version by ID\n   * @param options\n   * @returns version with specified ID\n   */\n  restoreGlobalVersion = async <T extends keyof TGeneratedTypes['globals']>(\n    options: RestoreGlobalVersionOptions<T>,\n  ): Promise<TGeneratedTypes['globals'][T]> => {\n    const { restoreVersion } = localGlobalOperations\n    return restoreVersion<T>(this, options)\n  }\n\n  /**\n   * @description Restore version by ID\n   * @param options\n   * @returns version with specified ID\n   */\n  restoreVersion = async <T extends keyof TGeneratedTypes['collections']>(\n    options: RestoreVersionOptions<T>,\n  ): Promise<TGeneratedTypes['collections'][T]> => {\n    const { restoreVersion } = localOperations\n    return restoreVersion<T>(this, options)\n  }\n\n  router?: Router\n\n  schema: GraphQLSchema\n\n  secret: string\n\n  sendEmail: (message: SendMailOptions) => Promise<unknown>\n\n  types: {\n    arrayTypes: any\n    blockInputTypes: any\n    blockTypes: any\n    fallbackLocaleInputType?: any\n    groupTypes: any\n    localeInputType?: any\n  }\n\n  unlock = async <T extends keyof TGeneratedTypes['collections']>(\n    options: UnlockOptions<T>,\n  ): Promise<boolean> => {\n    const { unlock } = localOperations.auth\n    return unlock(this, options)\n  }\n\n  updateGlobal = async <T extends keyof TGeneratedTypes['globals']>(\n    options: UpdateGlobalOptions<T>,\n  ): Promise<TGeneratedTypes['globals'][T]> => {\n    const { update } = localGlobalOperations\n    return update<T>(this, options)\n  }\n\n  validationRules: (args: OperationArgs<any>) => ValidationRule[]\n\n  verifyEmail = async <T extends keyof TGeneratedTypes['collections']>(\n    options: VerifyEmailOptions<T>,\n  ): Promise<boolean> => {\n    const { verifyEmail } = localOperations.auth\n    return verifyEmail(this, options)\n  }\n\n  versions: {\n    [slug: string]: any // TODO: Type this\n  } = {}\n\n  delete<T extends keyof TGeneratedTypes['collections']>(\n    options: DeleteOptions<T>,\n  ): Promise<BulkOperationResult<T> | TGeneratedTypes['collections'][T]> {\n    const { deleteLocal } = localOperations\n    return deleteLocal<T>(this, options)\n  }\n\n  /**\n   * @description delete one or more documents\n   * @param options\n   * @returns Updated document(s)\n   */\n  delete<T extends keyof TGeneratedTypes['collections']>(\n    options: DeleteByIDOptions<T>,\n  ): Promise<TGeneratedTypes['collections'][T]>\n\n  delete<T extends keyof TGeneratedTypes['collections']>(\n    options: DeleteManyOptions<T>,\n  ): Promise<BulkOperationResult<T>>\n\n  /**\n   * @description Initializes Payload\n   * @param options\n   */\n  // @ts-expect-error // TODO: TypeScript hallucinating again. fix later\n  async init(options: InitOptions): Promise<Payload> {\n    this.logger =\n      options.logger ?? Logger('payload', options.loggerOptions, options.loggerDestination)\n\n    if (!options.secret) {\n      throw new Error('Error: missing secret key. A secret key is needed to secure Payload.')\n    }\n\n    this.secret = crypto.createHash('sha256').update(options.secret).digest('hex').slice(0, 32)\n\n    this.local = options.local\n\n    if (options.config) {\n      this.config = await options.config\n      const configPath = findConfig()\n\n      this.config = {\n        ...this.config,\n        paths: {\n          config: configPath,\n          configDir: path.dirname(configPath),\n          rawConfig: configPath,\n        },\n      }\n    } else {\n      // eslint-disable-next-line @typescript-eslint/no-var-requires, global-require\n      const loadConfig = require('./config/load').default\n      this.config = await loadConfig(this.logger)\n    }\n\n    this.globals = {\n      config: this.config.globals,\n    }\n    this.config.collections.forEach((collection) => {\n      this.collections[collection.slug] = {\n        config: collection,\n      }\n    })\n\n    this.db = this.config.db({ payload: this })\n    this.db.payload = this\n\n    if (this.db?.init) {\n      await this.db.init(this)\n    }\n\n    if (!options.disableDBConnect && this.db.connect) {\n      await this.db.connect(this)\n    }\n\n    this.logger.info('Starting Payload...')\n\n    // Configure email service\n    const emailOptions = options.email ? { ...options.email } : this.config.email\n    if (options.email && this.config.email) {\n      this.logger.warn(\n        'Email options provided in both init options and config. Using init options.',\n      )\n    }\n\n    this.emailOptions = emailOptions ?? emailDefaults\n    this.email = buildEmail(this.emailOptions, this.logger)\n    this.sendEmail = sendEmail.bind(this)\n\n    if (!this.config.graphQL.disable) {\n      registerGraphQLSchema(this)\n    }\n\n    serverInitTelemetry(this)\n\n    if (!options.disableOnInit) {\n      if (typeof options.onInit === 'function') await options.onInit(this)\n      if (typeof this.config.onInit === 'function') await this.config.onInit(this)\n    }\n\n    return this\n  }\n\n  update<T extends keyof TGeneratedTypes['collections']>(\n    options: UpdateManyOptions<T>,\n  ): Promise<BulkOperationResult<T>>\n\n  /**\n   * @description Update one or more documents\n   * @param options\n   * @returns Updated document(s)\n   */\n  update<T extends keyof TGeneratedTypes['collections']>(\n    options: UpdateByIDOptions<T>,\n  ): Promise<TGeneratedTypes['collections'][T]>\n\n  update<T extends keyof TGeneratedTypes['collections']>(\n    options: UpdateOptions<T>,\n  ): Promise<BulkOperationResult<T> | TGeneratedTypes['collections'][T]> {\n    const { update } = localOperations\n    return update<T>(this, options)\n  }\n}\n\nexport type Payload = BasePayload<GeneratedTypes>\n\nlet cached = global._payload\n\nif (!cached) {\n  // eslint-disable-next-line no-multi-assign\n  cached = global._payload = { payload: null, promise: null }\n}\n\nexport const getPayload = async (options: InitOptions): Promise<Payload> => {\n  if (cached.payload) {\n    return cached.payload\n  }\n\n  if (!cached.promise) {\n    cached.promise = new BasePayload<GeneratedTypes>().init(options)\n  }\n\n  try {\n    cached.payload = await cached.promise\n  } catch (e) {\n    cached.promise = null\n    throw e\n  }\n\n  return cached.payload\n}\n"],"names":["BasePayload","getPayload","Mutation","name","fields","Query","authenticate","collections","config","create","options","localOperations","db","decrypt","email","emailOptions","encrypt","errorHandler","express","extensions","find","findByID","findGlobal","findOne","localGlobalOperations","findGlobalVersionByID","findVersionByID","findGlobalVersions","findVersions","forgotPassword","auth","getAPIURL","serverURL","routes","api","getAdminURL","admin","globals","local","logger","login","resetPassword","restoreGlobalVersion","restoreVersion","router","schema","secret","sendEmail","types","unlock","updateGlobal","update","validationRules","verifyEmail","versions","delete","deleteLocal","init","Logger","loggerOptions","loggerDestination","Error","crypto","createHash","digest","slice","configPath","findConfig","paths","configDir","path","dirname","rawConfig","loadConfig","require","default","forEach","collection","slug","payload","disableDBConnect","connect","info","warn","emailDefaults","buildEmail","bind","graphQL","disable","registerGraphQLSchema","serverInitTelemetry","disableOnInit","onInit","cached","global","_payload","promise","e"],"mappings":"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"}