GithubHelp home page GithubHelp logo

keery / swagger-typescript-api Goto Github PK

View Code? Open in Web Editor NEW

This project forked from acacode/swagger-typescript-api

0.0 1.0 0.0 10.34 MB

TypeScript API generator via Swagger scheme

License: MIT License

TypeScript 90.28% JavaScript 9.72%

swagger-typescript-api's Introduction

swagger-typescript-api

Greenkeeper badge NPM badge Build Status All Contributors

Generate api via swagger scheme.
Supports OA 3.0, 2.0, JSON, yaml
Generated api module use Fetch Api to make requests.



Any questions you can ask here or in our slack(#swagger-typescript-api channel)


πŸ‘€ Examples

All examples you can find here

πŸ›‘ It is new version with ETA templates

Version with mustache templates is >4.0.0

πŸ“„ Usage

Usage: sta [options]
Usage: swagger-typescript-api [options]

Options:
  -v, --version                 output the current version
  -p, --path <path>             path/url to swagger scheme
  -o, --output <output>         output path of typescript api file (default: "./")
  -n, --name <name>             name of output typescript api file (default: "Api.ts")
  -t, --templates <path>        path to folder containing templates
  -d, --default-as-success      use "default" response status code as success response too.
                                some swagger schemas use "default" response status code
                                as success response type by default. (default: false)
  -r, --responses               generate additional information about request responses
                                also add typings for bad responses (default: false)
  --union-enums                 generate all "enum" types as union types (T1 | T2 | TN) (default: false)
  --route-types                 generate type definitions for API routes (default: false)
  --no-client                   do not generate an API class
  --enum-names-as-values        use values in 'x-enumNames' as enum values (not only as keys) (default: false)
  --js                          generate js api module with declaration file (default: false)
  --extract-request-params      extract request params to data contract (default: false)
                                Also combine path params and query params into one object
  --module-name-index <number>  determines which path index should be used for routes separation (default: 0)
                                (example: GET:/fruites/getFruit -> index:0 -> moduleName -> fruites)
  --modular                     generate separated files for http client, data contracts, and routes (default: false)
  --disableStrictSSL            disabled strict SSL (default: false)
  --clean-output                clean output folder before generate api. WARNING: May cause data loss (default: false)
  --single-http-client          Ability to send HttpClient instance to Api constructor (default: false)
  --default-response <type>     default type for empty response schema (default: "void")
  -h, --help                    display help for command

Also you can use npx:

 npx swagger-typescript-api -p ./swagger.json -o ./src -n myApi.ts

You can use this package from nodejs:

const { generateApi } = require('swagger-typescript-api');

// example with url  
generateApi({
  name: "MySuperbApi.ts", // name of output typescript file
  url: 'http://api.com/swagger.json', // url where located swagger schema
})
  .then(({ files, configuration }) => {
    files.forEach(({ content, name }) => {
      fs.writeFile(path, content);
    });
  })
  .catch(e => console.error(e))

// example with local file  
generateApi({
  name: "ApiModule.ts", // name of output typescript file
  input: resolve(process.cwd(), './foo/swagger.json') // path to swagger schema
})
  .then(({ files, configuration }) => {
    files.forEach(({ content, name }) => {
      fs.writeFile(path, content);
    });
  })
  .catch(e => console.error(e))

// example with parsed schema  
generateApi({
  name: "ApiModule.ts", // name of output typescript file
  spec: {
    swagger: "2.0",
    info: {
      version: "1.0.0",
      title: "Swagger Petstore",
    },
    host: "petstore.swagger.io",
    basePath: "/api",
    schemes: ["http"],
    consumes: ["application/json"],
    produces: ["application/json"],
    paths: {
      // ...
    }
    // ...
  }
})
  .then(({ files, configuration }) => {
    files.forEach(({ content, name }) => {
      fs.writeFile(path, content);
    });
  })
  .catch(e => console.error(e))

πŸ’Ž options

--templates

This option needed for cases when you don't want to use default swagger-typescript-api output structure

Templates:

  • api.eta - Api class module
  • data-contracts.eta - all types (data contracts) from swagger schema
  • http-client.eta - HttpClient class module
  • procedure-call.eta - route in Api class
  • route-docs.eta - documentation for route in Api class
  • route-name.eta - route name for route in Api class
  • route-type.eta - (--route-types option)
  • route-types.eta - (--route-types option)

How to use it:

  1. copy swagger-typescript-api templates into your place in project
  2. add --templates PATH_TO_YOUR_TEMPLATES option
  3. modify ETA templates as you like

--module-name-index

This option should be used in cases when you have api with one global prefix like /api
Example:
GET:/api/fruits/getFruits
POST:/api/fruits/addFruits
GET:/api/vegetables/addVegetable
with --module-name-index 0 Api class will have one property api
When we change it to --module-name-index 1 then Api class have two properties fruits and vegetables

πŸ“„ Mass media

πŸ› οΈ Contribution

❗❗❗ Please use the next branch :)

If you need to check your changes at schemas in tests folder before create a PR just run command npm run test-all

Contributors ✨

Thanks goes to these wonderful people (emoji key):


Sergey S. Volkov

πŸ’» πŸ“– 🎨 πŸ’‘ 🚧 πŸ€” πŸ›

Filimonov Andrey

πŸ’» πŸ€” 🎨

Rafael Fakhreev

πŸ’» πŸ€”

Lucas Azzola

πŸ’» πŸ€” 🎨

Jennie

πŸ’» πŸ€”

Jose Enrique Marquez

πŸ’» πŸ›

Benjamin Dobell

πŸ’» πŸ›

Larry Botha

πŸ’» πŸ›

Nikolay Lukinykh

πŸ’» πŸ€” πŸ›

Marius BrΓ₯then

πŸ›‘οΈ

Evgeny Vlasov

πŸ€”

Fabio

πŸ› πŸ’»

Fabien

πŸ›

Rousseau Julien

πŸ›

SebastiΓ‘n Arias

πŸ›

Stijn Lammens

πŸ› πŸ’»

Emile Cantin

πŸ› πŸ’»

Adam Snyder

πŸ’» πŸ›

This project follows the all-contributors specification. Contributions of any kind welcome!

πŸš€ How it looks

πŸ“ License

Licensed under the MIT License.

swagger-typescript-api's People

Contributors

allcontributors[bot] avatar azz avatar emilecantin avatar greenkeeper[bot] avatar js2me avatar kel666 avatar mvbraathen avatar nikalun avatar

Watchers

 avatar

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.