Decorate method for create a resource in your controller.
Example:
import * as express from "express";
import { injectable } from "inversify";
import { controller, interfaces, requestParam, httpPost } from "inversify-express-utils";
import { ApiPath, ApiOperationPost, SwaggerDefinitionConstant } from "swagger-express-ts";
import "reflect-metadata";
@ApiPath( {
path : "/versions",
name : "Version"
} )
@controller( "/versions" )
@injectable()
export class VersionController implements interfaces.Controller {
public static TARGET_NAME: string = "VersionController";
private data: [any] = [
{
id : "1",
name : "Version 1",
description : "Description Version 1",
version : "1.0.0"
},
{
id : "2",
name : "Version 2",
description : "Description Version 2",
version : "2.0.0"
}
];
@ApiOperationPost( {
description : "Post version object",
summary : "Post new version",
parameters : {
body : { description : "New version", required : true, model : "Version" }
},
responses : {
200 : { description : "Success" },
400 : { description : "Parameters fail" }
}
} )
@httpPost( "/" )
public postVersion( request: express.Request, response: express.Response, next: express.NextFunction ): void {
if ( ! request.body ) {
return response.status( 400 ).end();
}
this.data.push( request.body );
response.json( request.body );
}
}
Define particular path of operation. Default is path parameter in @ApiPath.
- Optional
Define description of operation.
- Optional
Define summary of operation.
- Optional
parameters: IApiOperationArgsBaseParameters
Define parameters in path, body, query and formData.
- Required
responses: {[key: string]: IApiOperationArgsBaseResponse}
Define all responses.
- Required
Define type list that resource produce.
- Optional
- Default is global type list defined in ISwaggerBuildDefinition when execute .express(options: ISwaggerExpressOptions)
Define security
- Optional
Example:
...
@ApiOperationPost( {
description : "Post version object",
summary : "Post new version",
parameters : {
body : { description : "New version", required : true, model : "Version" }
},
responses : {
200 : { description : "Success" },
400 : { description : "Parameters fail" }
},
security : {
basicAuth : []
}
} )
...
}
Example:
app.use( swagger.express(
{
definition : {
...
securityDefinitions : {
basicAuth : {
type : SwaggerDefinitionConstant.Security.Type.BASIC_AUTHENTICATION
},
apiKeyHeader : {
type: SwaggerDefinitionConstant.Security.Type.API_KEY,
in: SwaggerDefinitionConstant.Security.In.HEADER,
name: "apiHeader"
}
}
}
}
) );
Define deprecated
- Optional