Generate javascript models from a self-documenting Swagger API.
$ npm install -g node-swagger-models
node-swagger-models nsmconfig.json
nsmconfig.json
{
"fileOutput": "./tmp",
"filePrefix": "",
"api": "http://localhost:1802/api-docs/v1/swagger.json",
"format": "backbone|vanilla|classout|typescript|typescript_interface"
}
node-swagger-models
package.json
...
node-swagger-models : {
"fileOutput": "./tmp",
"filePrefix": "",
"api": "http://localhost:1802/api-docs/v1/swagger.json",
"format": "backbone"
}
...
node-swagger-models nsmconfig.js
nsmconfig.js
// Using a js config allows for custom formatters
module.exports = {
"fileOutput": "./tmp",
"filePrefix": "",
"api": "http://localhost:1802/api-docs/v1/swagger.json",
"format": function(type, urlRoot, modelName, model, scriptModel, scriptValidation) {
return ['module.exports = {', scriptModel.join('\n'), '};']
}
}
- backbone models (backbone)
- plain json (vanilla)
- typescript models (typescript)
- js class (classout)
- typescript interfaces (typescript_interface)
There is support for a vender extension on the swagger schemadefintion.
x-key to denote the primary key of the model.
For the backbone models this will translate to the idAttribute.
For an example of a venderextension with swashbuckle (dotnet) see the extra folder.
(If you know better ways to create a venderextension, please let me know)
Other models can be generated by creating a template in lib/formatters/.
Typescript will generate .ts files, all others will be .js