从 Servicestack api metadata/swagger 生成 javascript 客户端

Generate javascript client from Servicestack api metadata/swagger

有什么方法可以基于metadata/Swagger 自动生成ServiceStack javascript(无打字稿)客户端?以某种方式将其与 webpack 集成会很好。

我不确定是否可以使用 swagger-js-codegen(此包从 swagger 规范文件生成 nodejs 或 angularjs class).

实际上 swagger 插件不共享服务来访问 swagger.json 以获得完整的模式(模式被拆分)。是否有任何解决方法可以为 javascript 使用 swagger codegen?

通过访问http://localhost:12116/resources你可以获得

{"swaggerVersion":"1.2","apis":[{"path":"/resource/assignroles"},{"path":"/resource/auth"},{"path":"/resource/authenticate"},{"path":"/resource/criteria"},{"path":"/resource/import"},{"path":"/resource/tenders"},{"path":"/resource/unassignroles"}],"apiVersion":"1.0","basePath":"http://localhost:12116","info":{"title":"App"}}

并使用 http://localhost:12116/resource/import

{"swaggerVersion":"1.2","apiVersion":"1.0","basePath":"http://localhost:12116","resourcePath":"/import","apis":[{"path":"/import/stats","operations":[{"method":"GET","nickname":"BrowseImportStats","parameters":[],"errorResponses":[]}]},{"path":"/import/tenders/changes/apply","operations":[{"method":"GET","nickname":"ApplyChanges","parameters":[],"errorResponses":[]},{"method":"POST","nickname":"ApplyChanges","parameters":[{"paramType":"body","name":"body","required":false,"allowMultiple":false,"type":"ApplyChanges"}],"errorResponses":[]},{"method":"PUT","nickname":"ApplyChanges","parameters":[{"paramType":"body","name":"body","required":false,"allowMultiple":false,"type":"ApplyChanges"}],"errorResponses":[]},{"method":"DELETE","nickname":"ApplyChanges","parameters":[],"errorResponses":[]}]},{"path":"/import/tenders/sync","description":"summary","operations":[{"method":"GET","summary":"summary","nickname":"ImportTenders","parameters":[],"errorResponses":[]}]}],"models":{"ImportTenders":{"id":"ImportTenders","properties":{}},"ApplyChanges":{"id":"ApplyChanges","properties":{}},"BrowseImportStats":{"id":"BrowseImportStats","description":"BrowseImportStats","properties":{}}}}

更新2016-11-26 我能够生成文档

C:\git\testapp>java -jar swagger-codegen-cli-2.2.1.jar generate -i http
://localhost:12116/resources -l javascript -o ./node_modules/testapp_api --additi
onal-properties emitJSDoc=false,usePromises=true

鉴于您拥有 OpenAPI/Swagger 规范,您可以利用 Swagger Codegen 不仅生成 JS API 客户端,还可以生成其他语言的 API 客户端(C#、Ruby、PHP、Python 等)、服务器存根(Spring、NodeJS 等)和 API 文档。

这是一个很好的起点:https://github.com/swagger-api/swagger-codegen#getting-started

(如果你不想安装任何东西,也可以在线生成代码:https://github.com/swagger-api/swagger-codegen#online-generators)