DocumentationRecipesOpenAPI (Swagger)

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',
  }
})