A typed fetch client for openapi-typescript
npm install @qdrant/openapi-typescript-fetch
A typed fetch client for openapi-typescript
``bash`
npm install openapi-typescript-fetch
Or
`bash`
yarn add openapi-typescript-fetch
Features
Supports JSON request and responses
- β
OpenAPI 3.0
- β
Swagger 2.0
Generate typescript definition from schema
`bash
npx openapi-typescript https://petstore.swagger.io/v2/swagger.json --output petstore.ts
Typed fetch client
`ts
import 'whatwg-fetch'import { Fetcher } from 'openapi-typescript-fetch'
import { paths } from './petstore'
// declare fetcher for paths
const fetcher = Fetcher.for()
// global configuration
fetcher.configure({
baseUrl: 'https://petstore.swagger.io/v2',
init: {
headers: {
...
},
},
use: [...] // middlewares
})
// create fetch operations
const findPetsByStatus = fetcher.path('/pet/findByStatus').method('get').create()
const addPet = fetcher.path('/pet').method('post').create()
// fetch
const { status, data: pets } = await findPetsByStatus({
status: ['available', 'pending'],
})
console.log(pets[0])
`$3
A non-ok fetch response throws a generic
ApiErrorBut an Openapi document can declare a different response type for each status code, or a default error response type
These can be accessed via a
discriminated union on status, as in code snippet below`ts
const findPetsByStatus = fetcher.path('/pet/findByStatus').method('get').create()
const addPet = fetcher.path('/pet').method('post').create()try {
await findPetsByStatus({ ... })
await addPet({ ... })
} catch(e) {
// check which operation threw the exception
if (e instanceof addPet.Error) {
// get discriminated union { status, data }
const error = e.getActualType()
if (error.status === 400) {
error.data.validationErrors // only available for a 400 response
} else if (error.status === 500) {
error.data.errorMessage // only available for a 500 response
} else {
...
}
}
}
`$3
Middlewares can be used to pre and post process fetch operations (log api calls, add auth headers etc)
`tsimport { Middleware } from 'openapi-typescript-fetch'
const logger: Middleware = async (url, init, next) => {
console.log(
fetching ${url})
const response = await next(url, init)
console.log(fetched ${url})
return response
}fetcher.configure({
baseUrl: 'https://petstore.swagger.io/v2',
init: { ... },
use: [logger],
})
// or
fetcher.use(logger)
`$3
This library can be used server side with node-fetch
Node CommonJS setup
`ts
// install node-fetch v2
npm install node-fetch@2
npm install @types/node-fetch@2// fetch-polyfill.ts
import fetch, { Headers, Request, Response } from 'node-fetch'
if (!globalThis.fetch) {
globalThis.fetch = fetch as any
globalThis.Headers = Headers as any
globalThis.Request = Request as any
globalThis.Response = Response as any
}
// index.ts
import './fetch-polyfill'
`$3
-
OpArgType - Infer argument type of an operation
- OpReturnType - Infer return type of an operation
- OpErrorType - Infer error type of an operation
- FetchArgType - Argument type of a typed fetch operation
- FetchReturnType - Return type of a typed fetch operation
- FetchErrorType - Error type of a typed fetch operation
- TypedFetch - Fetch operation type`ts
import { paths, operations } from './petstore'type Arg = OpArgType
type Ret = OpReturnType
type Err = OpErrorType
type Arg = OpArgType
type Ret = OpReturnType
type Err = OpErrorType
type FindPetsByStatus = TypedFetch
const findPetsByStatus = fetcher
.path('/pet/findByStatus')
.method('get')
.create()
type Arg = FetchArgType
type Ret = FetchReturnType
type Err = FetchErrorType
`$3
-
arrayRequestBody - Helper to merge params when request body is an array see issue`ts
const body = arrayRequestBody([{ item: 1 }], { param: 2 })// body type is { item: number }[] & { param: number }
`$3
Stringifying and parsing big numeric values could be problematic. JSON.parse will coerce large numeric values and JSON.stringify will throw an error:
Uncaught TypeError: Do not know how to serialize a BigInt in such cases.To circumvent this issue, this library will serialize big numeric values to
BigInt using JSON.rawJSON, and equally parse big numeric values from responses via JSON.parse source text access transforming them to BigInt for you.> If you rely on the precision of big number in responses, or are sending big numeric values, make sure your JavaScript environment supports it. Read below...
#### JavaScript engine/environment support
##### TL;DR
- Node 21
- Chrome 112
Support is conditional; the TC39 proposal has reached staged 3 and has even shipped with Chrome by default already, with the rest of modern browsers soon to follow with their corresponding releases.
Regarding Node.js support; at least Node 20 is required to be run with the next harmony flag
node --harmony-json-parse-with-source` (or Node 21 without flag π), until it is switched by default in future versions.---
Happy fetching! π