OpenAPI (Swagger)
Thanks to GraphQL’s Type System Sofa is able to generate OpenAPI (Swagger) definitions out of it. Possibilities are endless here. You get all the information you need in order to write your own definitions or create a plugin that follows any specification.
import { useSofa } from 'sofa-api';
useSofa({
schema,
basePath: '/api',
openAPI: {
info: {
title: 'Example API',
version: '3.0.0',
}
endpoint: '/openapi.json',
},
swaggerUI: {
path: '/docs',
}
})
You can find swagger definitions in
/api/openapi.json
route.
Extending OpenAPI
If you want to extend your OpenAPI document with security schemes etc.
You can use openAPI
option like below;
import { useSofa } from 'sofa-api';
useSofa({
schema,
basePath: '/api',
openAPI: {
info: {
title: 'Example API',
version: '3.0.0',
}
endpoint: '/openapi.json',
servers: [{ url: 'https://my-production.com', description: 'Production' }],
components: {
securitySchemes: {
bearerAuthorization: {
type: 'http',
scheme: 'bearer',
bearerFormat: 'JWT',
name: 'Authorization',
},
},
},
},
swaggerUI: {
path: '/docs',
}
})