Git Product home page Git Product logo

open-swagger-ui's Introduction

open-swagger-ui

An easy CLI to open swagger.json or .yaml files in Swagger UI.

$ open-swagger-ui ./swagger.json --open # done !

Install

Requires Node >=10.

From npm,

npm i -g open-swagger-ui

From Github Package Registry. (Guide).

Type definitions are bundled with this package.

CLI Usage

$ open-swagger-ui ./swagger.json
# => starts the server.

$ open-swagger-ui ./swagger.json --open # or -O for short
# => starts server, opens it in browser.

$ open-swagger-ui <absolute-path-to-swagger.json> --port 8899
# => you can put absolute/relative path for swagger.json
# => if the requested port is not available, a random port is chosen.

# Oh yes! You can put urls too..
$ open-swagger-ui https://petstore.swagger.io/v2/swagger.json

--help for help

$ open-swagger-ui --help
Usage: open-swagger-ui [options] <swagger-file>

An easy CLI tool to open swagger.json or .yaml files in Swagger UI.

Options:
  -V, --version      output the version number
  -O, --open         Open stuff in browser
  -P, --port <port>  Preferred port. If not available, a random port is selected
  -h, --help         output usage information

APIs

You can use this as a module too, just in case you want.

const { startServerWithSwaggerFile } = require('open-swagger-ui');
// or
import { startServerWithSwaggerFile } from 'open-swagger-ui';

startServerWithSwaggerFile('./path/to/swagger.json', port)
  .then(({ app, port, swagFilePath, server }) => {
    console.log(`app started on port ${port}`);
    // app is the express server underneath
    // you may freely add routes to it like
    // app.use(stuff);
  })
  .catch(err => console.error('something went wrong', err));

The startServerWithSwaggerFile function returns express app, the HTTP server instance, port in which the file is open and the reference swagFilePath.

Licence

MIT © Vajahath Ahmed

open-swagger-ui's People

Contributors

dependabot[bot] avatar vajahath avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar

Forkers

xuxiaoahang2018

open-swagger-ui's Issues

I am getting the following error when running `--help`

internal/util.js:257
throw new ERR_INVALID_ARG_TYPE('original', 'Function', original);
^

TypeError [ERR_INVALID_ARG_TYPE]: The "original" argument must be of type Function. Received type undefined
at promisify (internal/util.js:257:11)
at Object. (/usr/local/lib/node_modules/open-swagger-ui/node_modules/compress-brotli/src/index.js:9:18)
at Module._compile (internal/modules/cjs/loader.js:707:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:718:10)
at Module.load (internal/modules/cjs/loader.js:605:32)
at tryModuleLoad (internal/modules/cjs/loader.js:544:12)
at Function.Module._load (internal/modules/cjs/loader.js:536:3)
at Module.require (internal/modules/cjs/loader.js:643:17)
at require (internal/modules/cjs/helpers.js:22:18)
at Object. (/usr/local/lib/node_modules/open-swagger-ui/node_modules/keyv/src/index.js:5:24)

Unable to find file Given As CLI Argument

I get following error. How to go about fixing/debugging it? I tried test.json, .\test.json and ./test.json, but none of them works.

C:\Users\XXXX\Desktop\Specification>open-swagger-ui .\test.json
× Loading file ..
Error: The given swagger file (C:/Users/jarajput/Desktop/Specification/test.json) could not be found.
    at C:\Users\jarajput\AppData\Roaming\npm\node_modules\open-swagger-ui\dist\app.js:126:27
    at step (C:\Users\jarajput\AppData\Roaming\npm\node_modules\open-swagger-ui\dist\app.js:33:23)
    at Object.throw (C:\Users\jarajput\AppData\Roaming\npm\node_modules\open-swagger-ui\dist\app.js:14:53)
    at rejected (C:\Users\jarajput\AppData\Roaming\npm\node_modules\open-swagger-ui\dist\app.js:6:65)

Error: The given swagger file could not be found

❯ open-swagger-ui ./open-api-v2.yaml --open
Error: The given swagger file (/home/dsun/workspace/.../open-api-v2.yaml) could not be found.
    at /usr/local/lib/node_modules/open-swagger-ui/dist/app.js:126:27
    at step (/usr/local/lib/node_modules/open-swagger-ui/dist/app.js:33:23)
    at Object.throw (/usr/local/lib/node_modules/open-swagger-ui/dist/app.js:14:53)
    at rejected (/usr/local/lib/node_modules/open-swagger-ui/dist/app.js:6:65)
    at processTicksAndRejections (internal/process/task_queues.js:93:5)
❯ open-swagger-ui -V
1.0.1
❯ node -v
v14.15.5
❯ npm -v
7.6.3

Doesn't work out of box

Observed behavior on MacOS, node version 14.13.0.:

npm i -g open-swagger-ui
open-swagger-ui https://raw.githubusercontent.com/vajahath/open-swagger-ui/master/tests/swagger.json
# ---->
# ✔ Loading file https://raw.githubusercontent.com/vajahath/open-swagger-ui/master/tests/swagger.json
# Swagger open on port 49887
# Open localhost:49887 in browser and get "404 not found" error

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.