I recently built a tool called Swaggymnia to generate Swagger documentation for an existing API in Insomnia REST client. So brace yourself for a short but interesting quick tip read.
Start by downloading Swaggymnia, find the appropriate package for your system and download it. For linux:
1 | wget https://s3.amazonaws.com/swaggymnia/1.0.0-beta/linux/swaggymnia |
After downloading Swaggymnia. Add the execution permission to the binary:
1 | chmod +x swaggymnia |
data:image/s3,"s3://crabby-images/b7054/b7054b771a1223e4afae9610e0922bd9dc1812f9" alt=""
Note: For Windows make sure that swaggymnia binary is available on the PATH. This page contains instructions for setting the PATH on Windows.
After installing, verify the installation worked, by opening a new terminal session and checking if swaggymnia is available :
data:image/s3,"s3://crabby-images/8cd85/8cd856ab06e240f21b2a03e919efbb5dc3dbad10" alt=""
Once done, export your API from Insomnia:
data:image/s3,"s3://crabby-images/b109b/b109b6d531a3ae96e8b0c6abf0faa3a9ab19daae" alt=""
Next, create a configuration file with the format below:
1 | { |
Then, issue the following command:
1 | swaggymnia generate -i watchnow.json -c config.json -o yaml |
As result, you should see a new file called swagger.yml generated:
data:image/s3,"s3://crabby-images/3d26c/3d26c49cf5fe51354acd2ed7c8eeeef865ad03f9" alt=""
Now our Swagger spec is generated, you can publish your Swagger spec as customer-facing documentation.
data:image/s3,"s3://crabby-images/02a7b/02a7bb22cd1fb79f92942a86921a0f02c06301c8" alt=""
For this purpose you can use Swagger UI, which converts your Swagger spec into a beautiful, interactive API documentation.
You can download Swagger UI from here. It is just a bundle of HTML, CSS and JS files, which doesn’t require a framework or anything, so they can be installed in a directory on any HTTP server.
Once you have downloaded it, you put your swagger.yaml file into the dist directory — and open index.html and change it to point at your swagger file instead of http://petstore.swagger.io/v2/swagger.json.
Then you can open index.html in your browser, and see your new beautiful, interactive API documentation:
data:image/s3,"s3://crabby-images/1c8a4/1c8a4574698640e47a380bb7d7c2cab03cf41fc2" alt=""
Make sure to drop your comments, feedback, or suggestions below — or connect with me directly on Twitter @mlabouardy