npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

insomswagger

v1.5.0

Published

A command-line tool for converting JSON exported by Insomnia to Swagger format, as well as converting a swagger-formatted json file into a swagger-formatted annotation to facilitate documentation generation.

Downloads

43

Readme

Insomswagger

Introduction

Insomswagger is a versatile Node.js package designed to simplify the process of converting exported JSON from Insomnia into Swagger documentation. This utility offers flexibility by allowing users to generate either Swagger JSON files or PHP annotations based on their specific needs.

Whether you prefer a clean Swagger JSON representation or you're working within a PHP environment using annotations, this package has you covered. Easily create clear and concise API documentation tailored to your project requirements.

Installation

Before using the package, ensure you have Node.js installed on your machine. If not, you can download it here.

Usage

To utilize the package, follow these steps:

  1. Install the package globally:

    npm install -g insomswagger
  2. Navigate to the directory containing your input file.

  3. Run the following command:

    • For Swagger PHP Annotations:

      insomswagger -a [inputFilePath] [outputFilePath]
    • For Swagger JSON:

       insomswagger -j [inputFilePath] [outputFilePath]
    • For Swagger Yaml:

       insomswagger -y [inputFilePath] [outputFilePath]

    If outputFilePath is not provided, the default names (annotations.php for -a ,api-docs.yaml for -y and api-docs.json for -j) will be used.

    • To Update an Existing Installation:
      insomswagger update

    This command will update this package to the latest version.

Tips for Organizing Files in Insomnia

For optimal results when generating annotations, consider organizing your files in Insomnia:

  • Group requests under folders based on their functionality.
  • Use meaningful names for requests and folders.
  • Provide descriptions for requests and folders.

Adding Annotations to Controllers

To incorporate the generated annotations into your controllers, follow these steps:

  1. Open the file containing the generated annotations in your preferred IDE.

  2. Copy the annotations corresponding to each controller and method.

  3. Paste the annotations into the respective controller and method in your codebase.

Annotations with the same tags are placed side by side if you've organized your Insomnia JSON accordingly.

Viewing Swagger Documentation

To view the Swagger documentation in your Laravel project, you can use tools like Darkaonline/L5-Swagger.

  1. If your Laravel project is not using L5-Swagger yet, you have two options:

    a. Follow the manual installation instructions in the L5-Swagger repository.

    b. Alternatively, you can run the following command, which automates the installation of Swagger documentation for your Laravel project using Darkaonline/L5-Swagger:

    insomswagger install
  2. Once L5-Swagger has been installed, it generates an api-docs folder in the storage directory. If this has not yet been generated, create it. 3.copy the api-docs.json file generated by the command bash insomswagger -j [inputFilePath] [outputFilePath] and paste it in storage/api-docs/api-docs.json . NB: If you are told that a file with the same name exists, choose the "replace" option.

Now, when you access the Swagger documentation in your Laravel project, it will reflect the API documentation generated from your Insomnia collection.

Testing with Images and Multipart Support

Insomswagger allows you to test your API endpoints with various data types, including images and multipart requests.

Uploading Images

When testing your API, you can easily upload images by using the multipart/form-data content type. In your Insomnia collection, create a request with the POST method and set the request body type to multipart/form-data. Add a field with the type file to upload an image.

Multipart Requests

Insomswagger supports multipart requests, allowing you to send multiple types of data in a single request. To test with multipart data, configure your request in Insomnia with the appropriate content type (multipart/form-data). Include the necessary fields, such as text and file inputs.

Path Parameters

When testing your API endpoints in Insomnia, make sure to provide values for path parameters. In your API routes, path parameters are represented within curly braces {}. In Insomnia, navigate to the query parameters section and add a parameter with the same name as the one in your route, enclosed in curly braces.

For example, if your route is /api/users/{userId}, add a query parameter named userId with the desired value.

This ensures accurate testing of your API, considering the dynamic nature of path parameters.

Examples

Here are a few examples of how to use the package:

  • For Swagger PHP Annotations:

    insomswagger -a insomnia-export.json my-annotations.php
  • For Swagger JSON:

    insomswagger -j insomnia-export.json my-api-docs.json
  • For Swagger Yaml:

    insomswagger -y insomnia-export.json my-api-docs.json
  • For Darkaonline/l5-swagger installation:

    insomswagger install

License

This package is licensed under the MIT License. See the LICENSE.md file for details.

Author

Magid Ba

Issues and Contributions

If you encounter any issues or want to contribute to the project, please visit the GitHub repository.

Happy documenting!