adonis5-swagger
Swagger, AdonisJS, SwaggerUI
data:image/s3,"s3://crabby-images/f9bb9/f9bb9de7ab1ec7906b318b164ee28af2d63bbed4" alt="license-image"
Create API documentation easily in Adonis 5 using Swagger
Table of contents
Installation
npm i --save adonis5-swagger
Compile your code:
node ace serve --watch
Connect all dependences:
node ace invoke adonis5-swagger
- For other configuration, please update the
config/swagger.ts
.
Sample Usage
-
Add new route:
Route.get('/api/hello', 'TestController.hello')
-
Create TestController
using node ace make:controller Test
command:
import { HttpContextContract } from '@ioc:Adonis/Core/HttpContext'
export default class TestController {
public async hello({ request, response }: HttpContextContract) {
const name = request.input('name', 'Guess')
return response.send({ message: 'Hello ' + name })
}
}
-
You can also define the schema in the Models:
import { BaseModel } from '@ioc:Adonis/Lucid/Orm'
export default class User extends BaseModel {
}
-
Or create a separate file containing documentation from the APIs in either TS or YAML formats, sample structure:
project
├── app
├── config
├── docs
│ ├── controllers
│ │ ├── **/*.ts
│ │ ├── **/*.yml
│ └── models
│ ├── **/*.ts
│ ├── **/*.yml
Best usage
- Create files into docs/swagger, for example docs/swagger/auth.yml may contains:
/api/auth/login:
post:
tags:
- Auth
security: []
description: Login
parameters:
- name: credentials
in: body
required: true
schema:
properties:
phone:
type: string
example: '1234567890'
required: true
produces:
- application/json
responses:
200:
description: Success
- You can change default settings in config/swagger.ts
- For other sample in YAML and JS format, please refer to this link.
Open http://localhost:3333/docs in your browser
For detail usage, please check the Swagger specification in this SwaggerSpec