data:image/s3,"s3://crabby-images/8e6b4/8e6b45bc19a5c1f090e93d99afcd9d83983ce900" alt=""
Crud Swagger
For Document the API-REST paths on swagger, you need to make use of CrudDoc
decorator or CrudApi
decorator.
Installation
npm i @nest-excalibur/common-api --save-dev
npm i @nest-excalibur/crud-swagger
Example:
For every CRUD method you should make a configuration. The follwing example shows a configuration object:
In another file (if you want), make the configuration as a constant.
import {CrudApiConfig} from '@nest-excalibur/crud-swagger/lib';
export const PRODUCT_SWAGGER_CONFIG: CrudApiConfig = {
createOne: {
apiBody: {
type: ProductCrearDto
},
headers: [
{
name: 'X-MyHeader',
description: 'Custom header',
},
],
responses: [
{
type: ProductCreateDto,
status: HttpStatus.CREATED,
description: 'Created Product'
},
{
status: HttpStatus.BAD_REQUEST,
description: 'Data not valid',
}
]
},
updateOne: {
apiBody: {
type: ProductUpdateDto,
},
responses: [
{
type: ProductCreateDto,
status: HttpStatus.OK,
description: 'Updated product'
}
]
},
findAll: {
headers: [
{
name: 'X-MyHeader',
description: 'Custom header',
},
],
responses: [
{
type: ProductFindResponse,
status: HttpStatus.OK,
description: 'Fetched Products'
}
]
}
}
import {CrudDoc} from '@nest-excalibur/crud-swagger/lib';
@CrudDoc(
PRODUCT_SWAGGER_CONFIG,
)
@Controller('product')
export class ProductController extends CrudController<PostEntity>(options){
}