vite-plugin-open-client
TypeScript icon, indicating that this package has built-in type declarations

0.0.6 • Public • Published

open-client

npm

Provides a fully typed HTTP client based on a OpenAPI specification

 

install

pnpm i -D vite-plugin-open-client

use it

vite.config.ts
import OpenClient from 'vite-plugin-open-client'

export default {
    plugins: [
        OpenClient({
            definition: 'https://petstore.swagger.io/v2/swagger.json',
            apiName: 'petstore'
        })
    ]
}
main.ts
import { defineClient } from 'api:petstore'
import type { APISchema } from 'api:petstore'

const client = defineClient({
    baseUrl: 'https://api.petstore.com/',
    headers: {
        Apikey: 'my-api-key'
    }
})

// You can either alias the operations
const getPetById = client('/pet/{petId}', 'get')
const createPet = client('/pet', 'post')
console.log(
  await getPetById({ 
    path: { petId: 1 } 
  })
)

// You can borrow type definitions from the specification
const pet: APISchema<'Pet'> = {
  name: 'dog',
  photoUrls: ['https://example.com/dog.jpg'],
}
await createPet({ body: { body: pet }})

// Or call them directly through path
await client('/pet/{petId}', 'delete')({ 
  path: { petId: 1 } 
})

Readme

Keywords

Package Sidebar

Install

npm i vite-plugin-open-client

Weekly Downloads

3

Version

0.0.6

License

MIT

Unpacked Size

25.8 kB

Total Files

12

Last publish

Collaborators

  • henrykunh