Skip to content

Express API with autogenerated OpenAPI doc through Swagger

Published:Β atΒ 08:31 PM

In the past years OpenAPI has arise as the preferred way to document APIs. In this article we will see how easy is document an API created with NodeJS and Express through the Swagger tools.

If you are working in an REST API you more probably will desire to have some API doc where your users could find what are the endpoints of your API, what they do, which parameters they accept and which output they generate.

Swagger

Do not confuse OpenAPI with Swagger. OpenAPI is an specification that says how APIs are documented. Swagger is a collection of tools to implement the specification.

Thanks to Swagger, see the editor example, writing API docs is not difficult, you only need to write a bunch of YAML lines.

Among other tools, swagger offers the swagger-ui, which is nothing more than a collection of HTML, Javascript, and CSS assets that dynamically generate beautiful documentation from a Swagger-compliant API, or in other words, swagger-ui is the beautiful web page ou see in the previous swagger editor link.

To serve the swagger-ui content you only need a web server and the API documentation bundled in a JSON or YAML file.

ExpressJS and API documentation

When developing APIs with ExpressJS I tend to write my API endpoints in route files (usually also stored under a routes folder) which contains the rules to attend requests and, because of this, it is a perfect location to document the endpoints of my API, for example:

/**
 * @swagger
 * /users:
 *    get:
 *      description: This should return all users
 */
app.get("/users", (req, res) => res.end("This sould return all users"));

The problem is swagger-ui requires all my API doc reside in a single file, i.e. swagger.json, to be beautified as a web page.

How to autogenerate swagger doc ?

All the magic resides in the next packages:

So the idea is:

const swaggerJsdoc = require("swagger-jsdoc");

const options = {
  swaggerDefinition: {
    // Like the one described here: https://swagger.io/specification/#infoObject
    info: {
      title: "Test API",
      version: "1.0.0",
      description: "Test Express API with autogenerated swagger doc",
    },
  },
  // List of files to be processes. You can also set globs './routes/*.js'
  apis: ["endpoints.js"],
};

const specs = swaggerJsdoc(options);
const swaggerUi = require("swagger-ui-express");

app.use("/api-docs", swaggerUi.serve, swaggerUi.setup(specs));

That is all the magic. At this point if you start and open your browser at http://localhost:3000/api-docs you will see the Swagger UI web page with the documentation of your endpoint.

Of course you can create much more complex documentations. You can include files which only defines includes type definitions (i.e. about input/output data), group your endpoints by tags, etc.

The important thing is how the convination of swagger-ui-express and swagger-jsdoc can incredible help and simplify the way to have your API documentation always up to date.


Previous Post
How to slice or get symbols from a unicode string with emojis in JavaScript? Lets learn how JavaScript represent strings
Next Post
Using async/await in ExpressJS middlewares