Orval OpenAPI TypeScript Client Generator

8.8.0 · active · verified Sun Apr 19

Orval is a robust TypeScript client generator for OpenAPI/Swagger specifications, designed to automate the creation of type-safe API clients. It supports generating clients with various data fetching libraries, including React Query, Svelte Query, Axios, and Fetch, and can also generate mock data using Faker.js. The current stable version is 8.8.0, with minor and patch releases occurring frequently to incorporate new features (like `useSetQueryData` helpers), address bugs, and maintain compatibility with evolving ecosystem standards. Orval distinguishes itself through extensive customization options via its configuration file, allowing developers to precisely tailor the generated output for specific frameworks and architectural patterns, and by deeply integrating with OpenAPI schema validation and TypeScript type checking workflows to ensure high-quality, maintainable code.

Common errors

Warnings

Install

Imports

Quickstart

Demonstrates a basic Orval configuration for generating a React Query client with mock data and a custom Axios mutator, then how to run it via an npm script.

import { defineConfig } from 'orval';

export default defineConfig({
  petstore: {
    input: 'https://petstore.swagger.io/v2/swagger.json',
    output: {
      mode: 'split',
      target: 'src/api/endpoints/petstore.ts',
      schemas: 'src/api/model',
      client: 'react-query', // or 'axios', 'fetch', 'svelte-query', 'vue-query'
      mock: true,
      clean: true,
      override: {
        mutator: {
          path: './src/api/mutator/custom-instance.ts',
          name: 'customInstance',
        },
        operations: {
          listPets: {
            mutation: true,
            query: true,
          },
        },
      },
    },
    hooks: {
      afterAllFilesWrite: 'prettier --write',
    },
  },
});

// src/api/mutator/custom-instance.ts
import Axios, { AxiosRequestConfig } from 'axios';

export const AXIOS_INSTANCE = Axios.create({ baseURL: 'https://petstore.swagger.io/v2' });

export const customInstance = <T>(config: AxiosRequestConfig, options?: AxiosRequestConfig): Promise<T> => {
  return AXIOS_INSTANCE({ ...config, ...options }).then((res) => res.data);
};

export default customInstance;

// package.json (scripts)
// {
//   "scripts": {
//     "generate-api": "orval"
//   }
// }
//
// To run: `npm run generate-api` or `npx orval`

view raw JSON →