diff --git a/README.md b/README.md index ad1c374..f5797b9 100644 --- a/README.md +++ b/README.md @@ -10,12 +10,12 @@ https://github.com/ScottLogic/openapi-forge To run this generator, you also need to have [OpenAPI Forge] installed, or the repository checked out. Assuming you have it installed as a global module, you can run this generator as follows: -~~~ +``` $ openapi-forge forge \ https://petstore3.swagger.io/api/v3/openapi.json \ . \ -o api -~~~ +``` This generates an API from the Pet Store swagger definition, using the generator within the current folder (`.`), outputting the results to the `api` folder. diff --git a/formatter.js b/formatter.js new file mode 100644 index 0000000..432feae --- /dev/null +++ b/formatter.js @@ -0,0 +1,18 @@ +// there are issues with running prettier as a CLI command +// see: https://github.com/ScottLogic/openapi-forge/issues/133 +// this is a workaround to run the prettier CLI as a node module +const cli = require("prettier/cli.js"); + +// map forge log levels to prettier log levels +const logLevels = [ + /* quiet */ + "silent", + /* standard */ + "warn", + /* verbose */ + "debug", +]; + +module.exports = (folder, logLevel) => { + cli.run(["--write", folder, "--loglevel", logLevels[logLevel]]); +}; diff --git a/package.json b/package.json index b8a6878..72ede02 100644 --- a/package.json +++ b/package.json @@ -11,7 +11,6 @@ "test:generators": "\"./node_modules/.bin/cucumber-js\" -p generators", "format:check:all": "prettier --check .", "format:write:all": "prettier --write .", - "format:write": "prettier --write", "lint:check:all": "eslint .", "lint:write:all": "eslint --fix ." }, diff --git a/partials/modelIncludes.handlebars b/partials/modelIncludes.handlebars index 531a268..eab439f 100644 --- a/partials/modelIncludes.handlebars +++ b/partials/modelIncludes.handlebars @@ -1,4 +1,4 @@ -{{#if models}} +{{#if models }} const { {{#each models}}{{@key}}, {{/each}} } = require("./model");