name: config description: How to author a kubb.config.ts and pick the right @kubb/plugin-* packages when generating TypeScript from an OpenAPI/Swagger spec. Use whenever setting up Kubb, adding a generator, or debugging codegen output.
Config Skill
This skill instructs agents on authoring a kubb.config.ts and picking the right
@kubb/plugin-* packages. Generation runs through the kubb CLI (kubb generate), and the same
build powers the bundled MCP server.
When to Use
- Setting up Kubb in a project
- Adding or swapping a generator plugin
- Debugging why generated output is missing or wrong
What It Does
- Shows the shape of a
kubb.config.ts - Lists the generator plugins and how to combine them
- Points at each plugin's
Optionstype and kubb.dev docs page for authoritative options - Describes the validate, init and generate workflow
Shape of a config
import { defineConfig } from 'kubb'
import { pluginTs } from '@kubb/plugin-ts'
import { pluginAxios } from '@kubb/plugin-axios'
export default defineConfig({
root: '.',
input: {
path: './petstore.yaml', // local file path or a remote URL
},
output: {
path: './src/gen',
clean: true, // wipe the output dir before each run
barrel: { type: 'named' }, // generate index.ts barrels with named exports
},
plugins: [
pluginTs({ output: { path: 'models' } }),
pluginAxios({ output: { path: 'clients' } }),
],
})
Rules that matter:
- Set adapter options only when you need them, through a top-level
adapter: adapterOas({ ... })from@kubb/adapter-oas(forvalidate,serverIndex,serverVariables,discriminatororcontentType). pluginTsis the base. The client plugins (pluginAxios,pluginFetch) need it, the framework plugins (pluginReactQuery,pluginVueQuery,pluginSwr) needpluginTsand a client plugin, andpluginMswneedspluginTsandpluginFaker. Check the plugin's docs page on kubb.dev (https://kubb.dev/plugins/plugin-<name>) for the full dependency list.- Each generator plugin takes its own
output.path, resolved relative to the top-leveloutput.path. Keep generated kinds in separate folders (models,clients,hooks, ...). inputaccepts{ path }for a file or URL. Validate untrusted specs withkubb validatebefore generating.- Generation is destructive when
output.cleanistrue. Never pointoutput.pathat hand-written source. - Set
output.formatoroutput.lintto'auto'to format and lint generated files with whatever tool the project already has (oxfmt, Biome, Prettier, oxlint or ESLint).
Available generator plugins
Pick plugins by what the consumer needs, then install kubb plus each package.
| Need | Package | Import |
|---|---|---|
| TypeScript types (recommended base) | @kubb/plugin-ts |
pluginTs |
| Axios client | @kubb/plugin-axios |
pluginAxios |
| Fetch client | @kubb/plugin-fetch |
pluginFetch |
| TanStack React Query hooks | @kubb/plugin-react-query |
pluginReactQuery |
| Vue Query hooks | @kubb/plugin-vue-query |
pluginVueQuery |
| SWR hooks | @kubb/plugin-swr |
pluginSwr |
| Zod schemas | @kubb/plugin-zod |
pluginZod |
| Faker.js mock factories | @kubb/plugin-faker |
pluginFaker |
| MSW request handlers | @kubb/plugin-msw |
pluginMsw |
| Cypress fixtures | @kubb/plugin-cypress |
pluginCypress |
| MCP server from the spec | @kubb/plugin-mcp |
pluginMcp |
| ReDoc documentation | @kubb/plugin-redoc |
pluginRedoc |
For an installed plugin's exact options, read its Options type from the installed package
(node_modules/@kubb/plugin-<name>/src/types.ts or the published type declarations) and the
plugin's docs page (https://kubb.dev/plugins/plugin-<name>), which lists every option with
defaults, the plugin dependencies, and the default output.path. Use those as the source of
truth instead of guessing an option name.
Common combinations:
- Types only:
pluginTs(). - Typed data fetching: add
pluginAxios()orpluginFetch(), or a framework plugin (pluginReactQuery,pluginVueQueryorpluginSwr) which pulls in client generation. - Runtime validation: add
pluginZod()and point the client at it for typed, validated responses. - Testing and mocks: add
pluginFaker()andpluginMsw().
Workflow
The commands wrap the kubb CLI, so the same steps work from a terminal.
- Validate the spec with
kubb validate --input <spec>before anything else. - Scaffold and install with
kubb init. Pass--input,--outputand--pluginsto skip the prompts, or writekubb.config.tsby hand using the shape above. - Generate with
kubb generate. Pass--verbosewhen diagnosing why a file is missing or malformed, and--watchto regenerate on spec changes. - Typecheck the generated output and wire it into the app.
Related Skills
| Skill | Use For |
|---|---|
| ../output/SKILL.md | Importing and using the generated code |