OpenAPI Router
Simple router and validator for ExpressJs and OpenAPI 2.0
Quick Start
- Construct a router from an Express
app
and the OpenAPI file. - Add route handlers using the OpenAPI
operationId
and a standard Express handler function.
(Note that all examples use the Pet Store example: http://petstore.swagger.io/v2/swagger.json)
const express = ;const Router = Router;const spec = ; const app = ;const router = spec app; router;
In this example, router.use
finds the HTTP method and path from the OpenAPI file (GET
and /pet/{petId}
) and these values are used internally to call app.get('/pet/:petId', handlerFn)
. Additionally, the router validates both the request and response based on the OpenAPI file. (see Validation Errors below)
Parameters
Validated and type-cast request parameters are accessible on the request from the added 'openapi.params' property:
// GET /pet/:petIdrouter;
Parameters from the query string, path, body, and headers are all aggregated in req.openapi.params
:
// GET /user/loginrouter;
Note: you will still need to run the body-parser
middleware in order to access body parameters.
Validation Errors
Requests
If an incoming request is invalid, validation errors are pushed to the req.openapi.errors
array and next()
is called with {code: 'OPENAPI_ERRORS': scope: 'request'}
.
Responses
Outgoing responses are also validated and validation errors are pushed to res.openapi.errors
. The next()
function is called with {code: 'OPENAPI_ERRORS': scope: 'response'}
. An options
parameter can be passed to the Router constructor to control which (if any) types of responses errors are ignored:
ignoreInvalidHeaders
- When set totrue
, responses will be returned as-is even if the header values do not validate per the OpenAPI file. Errors will be returned if the header is missing entirely. (Default isfalse
)ignoreMissingHeaders
- When set totrue
, responses will be returned as-is even if defined headers are missing. Errors will be returned if the header is present, but invalid. (Default isfalse
)ignoreInvalidBody
- When set totrue
, responses will be returned as-is even if the response body does not validate per the OpenAPI file. (Default isfalse
)ignoreInvalidStatus
- When set totrue
, responses will be returned as-is even if a response is not defined for the current HTTP status code and no default response is defined. (Default isfalse
)
(Setting each values to true
disables all response validation)
Error Handler
A convenience error handler is included that returns JsonAPI-style error responses:
const express = ;const errorHandler = errorHandler; const app = ; // Implement routes here app;
Catch-All Routes
The router exposes a method to add various catch-all routes:
router;
Not-implemented routes
Because the router is aware of which routes are defined in the OpenAPI file as well as the routes that have been defined in code, it is able add routes to the Express app that handle operations that have not been implemented with the router.
Method-not-allowed routes
The router adds a catch all route for each path defined in the OpenAPI file that pushes a Not Implemented error to req.openapi.errors
. Calls to the API with an HTTP method not defined in the OpenAPI file fall through to this route and are returned the appropriate error.
Not-found route
Lastly, the router adds a '*' catch-all route that catches any request to a path not defined in the OpenAPI file.
Please note that any routes defined after these catch-all routes are added will never be hit. This is true for both routes added via the router as well as routes added directly via the Express app
object.
Prior Art
This project is heavily based on:
- Gangplank - https://github.com/DriveTimeInc/gangplank, MIT license
- SwaggerOps - https://github.com/skonves/swagger-ops, MIT license