我已经通过Java Command使用https://github.com/swagger-api/swagger-codegen生成了我的客户端打字稿/ angular2语言。
但我想使用npm命令而不是java命令生成我的客户端typescript / angular2。
示例:
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
我正在使用Windows 8.1操作系统。 我没有找到使用npm安装的swagger-codegen命令。
答案 0 :(得分:0)
我找到了一个解决方案,可以在没有java命令但使用node命令的情况下为angular 2 typescript生成客户端API。
示例节点脚本,用于从swagger.yaml生成typescript angular客户端。请注意,我们使用http。如果使用https(在撰写本文时),请求无法验证第一个证书
这是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'}));
});
});
我只使用typescript-angular2来使用变量语言。
之后node app.js
可用客户语言列表只需访问http://generator.swagger.io/api/gen/clients
有关详细信息:https://github.com/swagger-api/swagger-codegen/wiki/FAQ 部分发电机服务
答案 1 :(得分:0)
您是否正在寻找类似的东西?
npm install @openapitools/openapi-generator-cli -g