Skip to content

Plugin core

Under construction

This section describes the core plugin types and APIs.

Context/this

When calling this. in a plugin, the api of the core plugin will be used.

plugin.ts
ts
import path from 'node:path'

import { createPluginCache } from './utils/cache.ts'

import type { FileManager } from './FileManager.ts'
import type { PluginManager } from './PluginManager.ts'
import type { Plugin, PluginContext, PluginFactoryOptions, UserPluginWithLifeCycle } from './types.ts'

type PluginFactory<T extends PluginFactoryOptions = PluginFactoryOptions> = (options: T['options']) => UserPluginWithLifeCycle<T>

export function createPlugin<T extends PluginFactoryOptions = PluginFactoryOptions>(factory: PluginFactory<T>) {
  return (options: T['options']): ReturnType<PluginFactory<T>> => {
    return factory(options)
  }
}

type Options = {
  config: PluginContext['config']
  fileManager: FileManager
  pluginManager: PluginManager
  resolvePath: PluginContext['resolvePath']
  resolveName: PluginContext['resolveName']
  logger: PluginContext['logger']
  getPlugins: () => Array<Plugin>
  plugin?: PluginContext['plugin']
}

// not publicly exported
export type CorePluginOptions = PluginFactoryOptions<'core', Options, Options, PluginContext, never>

export const pluginName = 'core' satisfies CorePluginOptions['name']
export const pluginKey: CorePluginOptions['key'] = [pluginName] satisfies CorePluginOptions['key']

export const definePlugin = createPlugin<CorePluginOptions>((options) => {
  const { fileManager, pluginManager, resolvePath, resolveName, logger } = options

  return {
    name: pluginName,
    options,
    key: ['core'],

    api() {
      return {
        get config() {
          return options.config
        },
        get plugins() {
          return options.getPlugins()
        },
        get plugin() {
          // see pluginManger.#execute where we override with `.call` the this with the correct plugin
          return options.plugin as NonNullable<Options['plugin']>
        },
        logger,
        fileManager,
        pluginManager,
        async addFile(...files) {
          const resolvedFiles = await fileManager.add(...files)

          if (!Array.isArray(resolvedFiles)) {
            return [resolvedFiles]
          }

          return resolvedFiles
        },
        resolvePath,
        resolveName,
        cache: createPluginCache(),
      }
    },
    resolvePath(baseName) {
      const root = path.resolve(this.config.root, this.config.output.path)

      return path.resolve(root, baseName)
    },
    resolveName(name) {
      return name
    },
  }
})

this.config

For the current config, see kubb.config.ts.

  • Type: KubbConfig

this.plugins

Return all the plugins that are being used.

  • Type: Array<KubbPlugin>

this.plugin

The current plugin.

  • Type: KubbPlugin

this.logger

Instance of the Logger.

  • Type: Logger

this.fileManager

Instance of the fileManager.

  • Type: FileManager

this.pluginManager

Instance of the pluginManager.

  • Type: PluginManager

this.addFile

Add a file to the current fileManager.

  • Type: (...files: Array<KubbFile.File>): Promise<Array<KubbFile.File>>

this.resolvePath

This will be called pluginManager.resolvePath, see Pluginmanager and resolving a path.

  • Type: (params: ResolvePathParams) => KubbFile.OptionalPath

this.resolveName

This will be called pluginManager.resolveName, see Pluginmanager and resolving a name.

  • Type: (params: ResolveNameParams) => string

this.cache

Store something in the cache, this cache can be used in every plugin.

  • Type: Cache<PluginCache>

Released under the MIT License.