payload
Version:
Node, React and MongoDB Headless CMS and Application Framework
26 lines (25 loc) • 31.3 kB
JavaScript
;
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, {
hasTransport: function() {
return hasTransport;
},
hasTransportOptions: function() {
return hasTransportOptions;
}
});
function hasTransport(emailConfig) {
return emailConfig.transport !== undefined;
}
function hasTransportOptions(emailConfig) {
return emailConfig.transportOptions !== undefined;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/config/types.ts"],"sourcesContent":["import type { Express, NextFunction, Response } from 'express'\nimport type { Options as ExpressFileUploadOptions } from 'express-fileupload'\nimport type GraphQL from 'graphql'\nimport type { InitOptions as i18nInitOptions } from 'i18next'\nimport type { Transporter } from 'nodemailer'\nimport type SMTPConnection from 'nodemailer/lib/smtp-connection'\nimport type { DestinationStream, LoggerOptions } from 'pino'\nimport type React from 'react'\nimport type { DeepRequired } from 'ts-essentials'\n// @ts-expect-error\nimport type { InlineConfig } from 'vite'\nimport type { Configuration } from 'webpack'\n\nimport type { DocumentTab } from '../admin/components/elements/DocumentHeader/Tabs/types'\nimport type { RichTextAdapter } from '../admin/components/forms/field-types/RichText/types'\nimport type { ContextType } from '../admin/components/utilities/DocumentInfo/types'\nimport type { User } from '../auth/types'\nimport type { PayloadBundler } from '../bundlers/types'\nimport type {\n  AfterErrorHook,\n  CollectionConfig,\n  SanitizedCollectionConfig,\n} from '../collections/config/types'\nimport type { BaseDatabaseAdapter } from '../database/types'\nimport type { PayloadRequest } from '../express/types'\nimport type { GlobalConfig, SanitizedGlobalConfig } from '../globals/config/types'\nimport type { Payload } from '../payload'\nimport type { Where } from '../types'\nimport type { PayloadLogger } from '../utilities/logger'\n\ntype Prettify<T> = {\n  [K in keyof T]: T[K]\n} & NonNullable<unknown>\n\ntype Email = {\n  fromAddress: string\n  fromName: string\n  logMockCredentials?: boolean\n}\n\n// eslint-disable-next-line no-use-before-define\nexport type Plugin = (config: Config) => Config | Promise<Config>\n\nexport type LivePreviewConfig = {\n  /**\n   Device breakpoints to use for the `iframe` of the Live Preview window.\n   Options are displayed in the Live Preview toolbar.\n   The `responsive` breakpoint is included by default.\n   */\n  breakpoints?: {\n    height: number | string\n    label: string\n    name: string\n    width: number | string\n  }[]\n  /**\n   The URL of the frontend application. This will be rendered within an `iframe` as its `src`.\n   Payload will send a `window.postMessage()` to this URL with the document data in real-time.\n   The frontend application is responsible for receiving the message and updating the UI accordingly.\n   Use the `useLivePreview` hook to get started in React applications.\n   */\n  url?:\n    | ((args: {\n        data: Record<string, any>\n        documentInfo: ContextType\n        locale: Locale\n      }) => Promise<string> | string)\n    | string\n}\n\ntype GeneratePreviewURLOptions = {\n  locale: string\n  token: string\n}\n\nexport type GeneratePreviewURL = (\n  doc: Record<string, unknown>,\n  options: GeneratePreviewURLOptions,\n) => Promise<null | string> | null | string\n\nexport type EmailTransport = Email & {\n  transport: Transporter\n  transportOptions?: SMTPConnection.Options\n}\n\nexport type EmailTransportOptions = Email & {\n  transport?: Transporter\n  transportOptions: SMTPConnection.Options\n}\n\nexport type EmailOptions = Email | EmailTransport | EmailTransportOptions\n\n/**\n * type guard for EmailOptions\n * @param emailConfig\n */\nexport function hasTransport(emailConfig: EmailOptions): emailConfig is EmailTransport {\n  return (emailConfig as EmailTransport).transport !== undefined\n}\n\n/**\n * type guard for EmailOptions\n * @param emailConfig\n */\nexport function hasTransportOptions(\n  emailConfig: EmailOptions,\n): emailConfig is EmailTransportOptions {\n  return (emailConfig as EmailTransportOptions).transportOptions !== undefined\n}\n\nexport type GraphQLExtension = (\n  graphQL: typeof GraphQL,\n  payload: Payload,\n) => Record<string, unknown>\n\nexport type InitOptions = {\n  /**\n   * Sometimes, with the local API, you might need to pass a config file directly, for example, serverless on Vercel\n   * The passed config should match the config file, and if it doesn't, there could be mismatches between the admin UI\n   * and the backend functionality\n   */\n  config?: Promise<SanitizedConfig>\n\n  /**\n   * Disable connect to the database on init\n   */\n  disableDBConnect?: boolean\n\n  /**\n   * Disable running of the `onInit` function\n   */\n  disableOnInit?: boolean\n\n  /**\n   * Configuration for Payload's email functionality\n   *\n   * @see https://payloadcms.com/docs/email/overview\n   */\n  email?: EmailOptions\n\n  /** Express app for Payload to use */\n  express?: Express\n\n  /**\n   * Make Payload start in local-only mode.\n   *\n   * This will bypass setting up REST and GraphQL API routes.\n   * Express will not be required if set to `true`.\n   */\n  local?: boolean\n\n  loggerDestination?: DestinationStream\n  /**\n   * Specify options for the built-in Pino logger that Payload uses for internal logging.\n   *\n   * See Pino Docs for options: https://getpino.io/#/docs/api?id=options\n   */\n  loggerOptions?: LoggerOptions\n  /**\n   * A previously instantiated logger instance. Must conform to the PayloadLogger interface which uses Pino\n   * This allows you to bring your own logger instance and let payload use it\n   */\n  logger?: PayloadLogger\n\n  /**\n   * A function that is called immediately following startup that receives the Payload instance as it's only argument.\n   */\n  onInit?: (payload: Payload) => Promise<void> | void\n\n  /** Secure string that Payload will use for any encryption workflows */\n  secret: string\n}\n\n/**\n * This result is calculated on the server\n * and then sent to the client allowing the dashboard to show accessible data and actions.\n *\n * If the result is `true`, the user has access.\n * If the result is an object, it is interpreted as a MongoDB query.\n *\n * @example `{ createdBy: { equals: id } }`\n *\n * @example `{ tenant: { in: tenantIds } }`\n *\n * @see https://payloadcms.com/docs/access-control/overview\n */\nexport type AccessResult = Where | boolean\n\nexport type AccessArgs<T = any, U = any> = {\n  /**\n   * The relevant resource that is being accessed.\n   *\n   * `data` is null when a list is requested\n   */\n  data?: T\n  /** ID of the resource being accessed */\n  id?: number | string\n  /** The original request that requires an access check */\n  req: PayloadRequest<U>\n}\n\n/**\n * Access function runs on the server\n * and is sent to the client allowing the dashboard to show accessible data and actions.\n *\n * @see https://payloadcms.com/docs/access-control/overview\n */\nexport type Access<T = any, U = any> = (\n  args: AccessArgs<T, U>,\n) => AccessResult | Promise<AccessResult>\n\n/** Equivalent to express middleware, but with an enhanced request object */\nexport interface PayloadHandler {\n  (req: PayloadRequest, res: Response, next: NextFunction): void\n}\n\n/**\n * Docs: https://payloadcms.com/docs/rest-api/overview#custom-endpoints\n */\nexport type Endpoint = {\n  /** Extension point to add your custom data. */\n  custom?: Record<string, any>\n  /**\n   * Middleware that will be called when the path/method matches\n   *\n   * Compatible with Express middleware\n   */\n  handler: PayloadHandler | PayloadHandler[]\n  /** HTTP method (or \"all\") */\n  method: 'connect' | 'delete' | 'get' | 'head' | 'options' | 'patch' | 'post' | 'put'\n  /**\n   * Pattern that should match the path of the incoming request\n   *\n   * Compatible with the Express router\n   */\n  path: string\n  /**\n   * Set to `true` to disable the Payload middleware for this endpoint\n   * @default false\n   */\n  root?: boolean\n}\n\nexport type AdminViewConfig = {\n  Component: AdminViewComponent\n  /** Whether the path should be matched exactly or as a prefix */\n  exact?: boolean\n  path: string\n  sensitive?: boolean\n  strict?: boolean\n}\n\nexport type AdminViewProps = {\n  canAccessAdmin?: boolean\n  user: User | null | undefined\n}\n\nexport type AdminViewComponent = React.ComponentType<AdminViewProps>\n\nexport type AdminView = AdminViewComponent | AdminViewConfig\n\nexport type EditViewConfig =\n  | {\n      /**\n       * Add a new Edit view to the admin panel\n       * i.e. you can render a custom view that has no tab, if desired\n       * Or override a specific properties of an existing one\n       * i.e. you can customize the `Default` view tab label, if desired\n       */\n      Tab?: DocumentTab\n      path?: string\n    }\n  | {\n      Component: AdminViewComponent\n      path: string\n    }\n  | {\n      actions?: React.ComponentType<any>[]\n    }\n\n/**\n * Override existing views\n * i.e. Dashboard, Account, API, LivePreview, etc.\n * Path is not available here\n * All Tab properties become optional\n * i.e. you can change just the label, if desired\n */\nexport type EditView = AdminViewComponent | EditViewConfig\n\nexport type Locale = {\n  /**\n   * value of supported locale\n   * @example \"en\"\n   */\n  code: string\n  /**\n   * Code of another locale to use when reading documents with fallback, if not specified defaultLocale is used\n   */\n  fallbackLocale?: string\n  /**\n   * label of supported locale\n   * @example \"English\"\n   */\n  label: Record<string, string> | string\n  /**\n   * if true, defaults textAligmnent on text fields to RTL\n   */\n  rtl?: boolean\n}\n\nexport type BaseLocalizationConfig = {\n  /**\n   * Locale for users that have not expressed their preference for a specific locale\n   * @example `\"en\"`\n   */\n  defaultLocale: string\n  /** Set to `true` to let missing values in localised fields fall back to the values in `defaultLocale` */\n  fallback?: boolean\n}\n\nexport type LocalizationConfigWithNoLabels = Prettify<\n  BaseLocalizationConfig & {\n    /**\n     * List of supported locales\n     * @example `[\"en\", \"es\", \"fr\", \"nl\", \"de\", \"jp\"]`\n     */\n    locales: string[]\n  }\n>\n\nexport type LocalizationConfigWithLabels = Prettify<\n  BaseLocalizationConfig & {\n    /**\n     * List of supported locales with labels\n     * @example {\n     *  label: 'English',\n     *  value: 'en',\n     *  rtl: false\n     * }\n     */\n    locales: Locale[]\n  }\n>\n\nexport type SanitizedLocalizationConfig = Prettify<\n  LocalizationConfigWithLabels & {\n    /**\n     * List of supported locales\n     * @example `[\"en\", \"es\", \"fr\", \"nl\", \"de\", \"jp\"]`\n     */\n    localeCodes: string[]\n  }\n>\n\n/**\n * @see https://payloadcms.com/docs/configuration/localization#localization\n */\nexport type LocalizationConfig = Prettify<\n  LocalizationConfigWithLabels | LocalizationConfigWithNoLabels\n>\n\n/**\n * This is the central configuration\n *\n * @see https://payloadcms.com/docs/configuration/overview\n */\nexport type Config = {\n  /** Configure admin dashboard */\n  admin?: {\n    /** Automatically log in as a user when visiting the admin dashboard. */\n    autoLogin?:\n      | {\n          /**\n           * The email address of the user to login as\n           *\n           */\n          email: string\n          /** The password of the user to login as */\n          password: string\n          /**\n           * If set to true, the login credentials will be prefilled but the user will still need to click the login button.\n           *\n           * @default false\n           */\n          prefillOnly?: boolean\n        }\n      | false\n\n    /** Set account profile picture. Options: gravatar, default or a custom React component. */\n    avatar?: 'default' | 'gravatar' | React.ComponentType<any>\n    /**\n     * Specify an absolute path for where to store the built Admin panel bundle used in production.\n     *\n     * @default \"/build\"\n     * */\n    buildPath?: string\n    /** Customize the bundler used to run your admin panel. */\n    bundler?: PayloadBundler\n    /**\n     * Add extra and/or replace built-in components with custom components\n     *\n     * @see https://payloadcms.com/docs/admin/components\n     */\n    components?: {\n      /**\n       * Replace the navigation with a custom component\n       */\n      Nav?: React.ComponentType<any>\n      /**\n       * Add custom components to the top right of the Admin Panel\n       */\n      actions?: React.ComponentType<any>[]\n      /**\n       * Add custom components after the collection overview\n       */\n      afterDashboard?: React.ComponentType<any>[]\n      /**\n       * Add custom components after the email/password field\n       */\n      afterLogin?: React.ComponentType<any>[]\n      /**\n       * Add custom components after the navigation links\n       */\n      afterNavLinks?: React.ComponentType<any>[]\n      /**\n       * Add custom components before the collection overview\n       */\n      beforeDashboard?: React.ComponentType<any>[]\n      /**\n       * Add custom components before the email/password field\n       */\n      beforeLogin?: React.ComponentType<any>[]\n      /**\n       * Add custom components before the navigation links\n       */\n      beforeNavLinks?: React.ComponentType<any>[]\n      /** Replace graphical components */\n      graphics?: {\n        /** Replace the icon in the navigation */\n        Icon?: React.ComponentType<any>\n        /** Replace the logo on the login page */\n        Logo?: React.ComponentType<any>\n      }\n      /** Replace logout related components */\n      logout?: {\n        /** Replace the logout button  */\n        Button?: React.ComponentType<any>\n      }\n      /**\n       * Wrap the admin dashboard in custom context providers\n       */\n      providers?: React.ComponentType<{ children: React.ReactNode }>[]\n      /**\n       * Replace or modify top-level admin routes, or add new ones:\n       * + `Account` - `/admin/account`\n       * + `Dashboard` - `/admin`\n       * + `:path` - `/admin/:path`\n       */\n      views?: {\n        /** Add custom admin views */\n        [key: string]: AdminView\n        /** Replace the account screen */\n        Account?: AdminView\n        /** Replace the admin homepage */\n        Dashboard?: AdminView\n      }\n    }\n    /** Absolute path to a stylesheet that you can use to override / customize the Admin panel styling. */\n    css?: string\n    /** Global date format that will be used for all dates in the Admin panel. Any valid date-fns format pattern can be used. */\n    dateFormat?: string\n    /** If set to true, the entire Admin panel will be disabled. */\n    disable?: boolean\n    /** The route the user will be redirected to after being inactive for too long. */\n    inactivityRoute?: string\n    /** Replace the entirety of the index.html file used by the Admin panel. Reference the base index.html file to ensure your replacement has the appropriate HTML elements. */\n    indexHTML?: string\n    livePreview?: LivePreviewConfig & {\n      collections?: string[]\n      globals?: string[]\n    }\n    /** The route for the logout page. */\n    logoutRoute?: string\n    /** Base meta data to use for the Admin panel. Included properties are titleSuffix, ogImage, and favicon. */\n    meta?: {\n      /**\n       * Public path to an icon\n       *\n       * This image may be displayed in the browser next to the title of the page\n       */\n      favicon?: string\n      /**\n       * Public path to an image\n       *\n       * This image may be displayed as preview when the link is shared on social media\n       */\n      ogImage?: string\n      /**\n       * String to append to the <title> of admin pages\n       * @example `\" - My Brand\"`\n       */\n      titleSuffix?: string\n    }\n    /** The slug of a Collection that you want be used to log in to the Admin dashboard. */\n    user?: string\n    /** Customize the Vite config that's used to generate the Admin panel. */\n    vite?: (config: InlineConfig) => InlineConfig\n    /** Customize the Webpack config that's used to generate the Admin panel. */\n    webpack?: (config: Configuration) => Configuration\n  }\n  /**\n   * Manage the datamodel of your application\n   *\n   * @see https://payloadcms.com/docs/configuration/collections#collection-configs\n   */\n  collections?: CollectionConfig[]\n  /**\n   * Replace the built-in components with custom ones\n   */\n  components?: { [key: string]: (() => JSX.Element) | JSX.Element }\n  /**\n   * Prefix a string to all cookies that Payload sets.\n   *\n   * @default \"payload\"\n   */\n  cookiePrefix?: string\n  /** Either a whitelist array of URLS to allow CORS requests from, or a wildcard string ('*') to accept incoming requests from any domain. */\n  cors?: '*' | string[]\n\n  /** A whitelist array of URLs to allow Payload cookies to be accepted from as a form of CSRF protection. */\n  csrf?: string[]\n\n  /** Extension point to add your custom data. */\n  custom?: Record<string, any>\n  /** Pass in a database adapter for use on this project. */\n  db: (args: { payload: Payload }) => BaseDatabaseAdapter\n  /** Enable to expose more detailed error information. */\n  debug?: boolean\n  /**\n   * If a user does not specify `depth` while requesting a resource, this depth will be used.\n   *\n   * @see https://payloadcms.com/docs/getting-started/concepts#depth\n   *\n   * @default 2\n   */\n  defaultDepth?: number\n  /**\n   * The maximum allowed depth to be permitted application-wide. This setting helps prevent against malicious queries.\n   *\n   * @default 40000\n   */\n  defaultMaxTextLength?: number\n  /** Default richtext editor to use for richText fields */\n  editor: RichTextAdapter<any, any, any>\n  /**\n   * Email configuration options. This value is overridden by `email` in Payload.init if passed.\n   *\n   * @see https://payloadcms.com/docs/email/overview\n   */\n  email?: EmailOptions\n  /** Custom REST endpoints */\n  endpoints?: Endpoint[]\n  /**\n   * Express-specific middleware options such as compression and JSON parsing.\n   *\n   * @see https://payloadcms.com/docs/configuration/express\n   */\n  express?: {\n    /** Control the way responses are compressed */\n    compression?: {\n      [key: string]: unknown\n    }\n    /** Control the way JSON is parsed */\n    json?: {\n      /** Defaults to 2MB  */\n      limit?: number\n    }\n    /**\n     * @deprecated express.middleware will be removed in a future version. Please migrate to express.postMiddleware.\n     */\n    middleware?: any[]\n    postMiddleware?: any[]\n    preMiddleware?: any[]\n  }\n  /**\n   * @see https://payloadcms.com/docs/configuration/globals#global-configs\n   */\n  globals?: GlobalConfig[]\n  /**\n   * Manage the GraphQL API\n   *\n   * You can add your own GraphQL queries and mutations to Payload, making use of all the types that Payload has defined for you.\n   *\n   * @see https://payloadcms.com/docs/access-control/overview\n   */\n  graphQL?: {\n    disable?: boolean\n    disablePlaygroundInProduction?: boolean\n    maxComplexity?: number\n    /**\n     * Function that returns an object containing keys to custom GraphQL mutations\n     *\n     * @see https://payloadcms.com/docs/access-control/overview\n     */\n    mutations?: GraphQLExtension\n    /**\n     * Function that returns an object containing keys to custom GraphQL queries\n     *\n     * @see https://payloadcms.com/docs/access-control/overview\n     */\n    queries?: GraphQLExtension\n    schemaOutputFile?: string\n  }\n  /**\n   * Tap into Payload-wide hooks.\n   *\n   * @see https://payloadcms.com/docs/hooks/overview\n   */\n  hooks?: {\n    afterError?: AfterErrorHook\n  }\n  /**\n   * Control the behaviour of the admin internationalisation.\n   *\n   * See i18next options.\n   *\n   * @default\n   * {\n   *   fallbackLng: 'en',\n   *   debug: false,\n   *   supportedLngs: Object.keys(translations),\n   *   resources: translations,\n   * }\n   */\n  i18n?: i18nInitOptions\n  /** Automatically index all sortable top-level fields in the database to improve sort performance and add database compatibility for Azure Cosmos and similar. */\n  indexSortableFields?: boolean\n  /**\n   * Translate your content to different languages/locales.\n   *\n   * @default false // disable localization\n   */\n  localization?: LocalizationConfig | false\n  /**\n   * The maximum allowed depth to be permitted application-wide. This setting helps prevent against malicious queries.\n   *\n   * @see https://payloadcms.com/docs/getting-started/concepts#depth\n   *\n   * @default 10\n   */\n  maxDepth?: number\n  /** A function that is called immediately following startup that receives the Payload instance as its only argument. */\n  onInit?: (payload: Payload) => Promise<void> | void\n  /**\n   * An array of Payload plugins.\n   *\n   * @see https://payloadcms.com/docs/plugins/overview\n   */\n  plugins?: Plugin[]\n  /**\n   * Limit heavy usage\n   *\n   * @default\n   * {\n   *   window: 15 * 60 * 1000, // 15 minutes,\n   *   max: 500,\n   * }\n   */\n  rateLimit?: {\n    max?: number\n    skip?: (req: PayloadRequest) => boolean\n    trustProxy?: boolean\n    window?: number\n  }\n  /** Control the routing structure that Payload binds itself to. */\n  routes?: {\n    /** @default \"/admin\" */\n    admin?: string\n    /** @default \"/api\"  */\n    api?: string\n    /** @default \"/graphql\"  */\n    graphQL?: string\n    /** @default \"/graphql-playground\" */\n    graphQLPlayground?: string\n  }\n  /**\n   * Define the absolute URL of your app including the protocol, for example `https://example.org`.\n   * No paths allowed, only protocol, domain and (optionally) port.\n   *\n   * @see https://payloadcms.com/docs/configuration/overview#options\n   */\n  serverURL?: string\n  /** Send anonymous telemetry data about general usage. */\n  telemetry?: boolean\n  /** Control how typescript interfaces are generated from your collections. */\n  typescript?: {\n    /** Disable declare block in generated types file */\n    declare?: false\n    /** Filename to write the generated types to */\n    outputFile?: string\n  }\n  /**\n   * Customize the handling of incoming file uploads for collections that have uploads enabled.\n   */\n  upload?: ExpressFileUploadOptions\n}\n\nexport type SanitizedConfig = Omit<\n  DeepRequired<Config>,\n  'collections' | 'endpoint' | 'globals' | 'localization'\n> & {\n  collections: SanitizedCollectionConfig[]\n  endpoints: Endpoint[]\n  globals: SanitizedGlobalConfig[]\n  localization: SanitizedLocalizationConfig | false\n  paths: {\n    config: string\n    configDir: string\n    rawConfig: string\n  }\n}\n\nexport type EntityDescription =\n  | (() => string)\n  | React.ComponentType<any>\n  | Record<string, string>\n  | string\n"],"names":["hasTransport","hasTransportOptions","emailConfig","transport","undefined","transportOptions"],"mappings":";;;;;;;;;;;IAgGgBA,YAAY;eAAZA;;IAQAC,mBAAmB;eAAnBA;;;AART,SAASD,aAAaE,WAAyB;IACpD,OAAO,AAACA,YAA+BC,SAAS,KAAKC;AACvD;AAMO,SAASH,oBACdC,WAAyB;IAEzB,OAAO,AAACA,YAAsCG,gBAAgB,KAAKD;AACrE"}