Search code examples
angulartypescriptclientswagger-codegen

Install swagger-codegen via npm on Windows OS


I've generated my client typescript/angular2 language using https://github.com/swagger-api/swagger-codegen via a Java Command.

But i would like to generate my client typescript/angular2 using an npm command not a java command.

Example :

  npm install swagger-codegen -g
  swagger-codegen generate -i http://petstore.swagger.io/v2/swagger.json -l
  typescript-angular2 -o c:\temp\angular2_api_client

I'am using windows 8.1 OS. I didn't find swagger-codegen command to install with npm.


Solution

  • I've found a solution to generate a client API for Angular 2 TypeScript without java command but using node command.

    Example node script to generate typescript angular client from swagger.yaml. Note that we use http. Request cannot verify the first certificate if using https (at the time of writing this)

    This is app.js

    var fs = require('fs');
    var path = require('path');
    var jsYaml = require('js-yaml');
    var request = require('request');
    var unzip = require('unzip2');
    
    var codeGenEndpoint = 'http://generator.swagger.io/api/gen/clients';
    var language = 'typescript-angular2';
    
    fs.readFile(path.resolve('swagger.yaml'), 'utf8', function (error, yaml) {
        if (error) {
            throw error;
        }
    
        var swaggerObj = jsYaml.load(yaml);
    
        var postBody = {
            spec: swaggerObj,
            options: {
                modelPropertyNaming: 'camelCase',
                apiPackage: 'api.clients.settings',
                modelPackage: 'api.clients.settings'
            }
        };
    
        request.post({
            url: codeGenEndpoint + '/' + language,
            body: JSON.stringify(postBody),
            headers: {
                'Content-Type': 'application/json'
            }
        }, function(error, response, body){
            if (error) {
                throw error;
            }
    
            if (response.statusCode !== 200) {
                throw new Error('Response code was not 200. ' + body)
            }
    
            var responseObj = JSON.parse(body);
    
            request({
                url: responseObj.link,
                encoding: null
            }).pipe(unzip.Extract({ path: 'src/client/js/codegen/settingsApi'}));
        });
    });
    

    I just set variable language to 'typescript-angular2'. After that node app.js

    For the list of available client languages just visit http://generator.swagger.io/api/gen/clients

    And for more details: https://github.com/swagger-api/swagger-codegen/wiki/FAQ section Generator Service