Skip to content

Latest commit

 

History

History
64 lines (50 loc) · 8.77 KB

0020-generator-options.md

File metadata and controls

64 lines (50 loc) · 8.77 KB

Generator (OpenAPI + OData) API

Status

decided

Context 1

When generating only from one spec (either generator), which is probably the most common use case, when doing this mannually, the resulting folder structure is <outputDir>/serviceDir, which in turn is unexpected. The name of the generator command is: generate-X-client indicating that only one client will be generated.

Decision 1

  1. Different behavior if only one specification is found vs. multiple. For one specification, put client directly into <outputDir>, for multiple make subdirectories.
  2. generate-openapi-client batch -i <inputFile> -o <outputDir> Generate only the first matched input file found by default. Show a log message in case there are multiple inputs found, that batch argument is required to nest the APIs.
  3. generate-openapi-client -i <inputFile> -o <outputDir> --flat Flatten the directory to be <outputDir>. Throw an error if input is a directory (with multiple files).
  4. Keep it as is. (decided)
  5. Rename the client:
    1. openapi-generator (decided)
    2. sap-cloud-sdk-openapi-generator

Consequences 1

The given outputDir is the actual output directory. Depending on the decided option, the behavior might be considered inconsistent by default.

Context 2

The option naming is slighly inconsistent and quite long at times. Some of the defaults might lead to many files being generated and transpiled by default - potentially more than necessary. We should discuss the details of those defaults and make a concious decision on whether to keep or adjust them.

Decision 2

Current Name, Aliases Future Name, Aliases Current Behavior Future Behavior
--inputDir, -i (required) --input, -i (required) Input directory/file same
--outputDir, -o (required) --outputDir, -o (required) Output directory same
--clearOutputDir --clearOutputDir Delete all files in output directory same
--generateJs --transpile, -t Transpiles, default true Transpiles, default false. If set if tsconfig is enabled with default (unless configured). This should be explicitly stated in the documentation.
--generatePackageJson --[no]-packageJson Writes a default package.json, default true. Writes a default package.json, default true (needs core dependency). Optionally in the future: Writes a custom package.json if passed. Keep boolean for now.
--serviceMapping --optionsPerService Considers a per service configuration file. Shows a warning if none is given (differs from OData behavior). Only generates a per service configuration, if a file path is provided. No warning if it is not provided. If provided, packageName and directoryName will be generated, but are not required to be set. *
--tsConfig --tsConfig tsconfig.json file to overwrite the default "tsconfig.json". Writes a custom tsconfig.json if passed. Document that this should be used in combination with transpile.
--versionInPackageJson --packageVersion Version in package.json, default is generator version. Version in package.json, default is 1.0.0. Hide it.
Options in OData, but not (yet in OpenAPI) generator
--forceOverwrite --overwrite Overwrite files even it they exist, default false. same
--generateTypedocJson --typedocJson Writes a default typedoc.json, default true. Remove/deprecate, use files instead.
Currently hidden options
--additionalFiles --include Copy additional files, identified by glob. Hidden. same Expose it.
--writeReadme --readme Writes a default README.md, default false. same
New options
- --skipValidation Duplicate names are renamed by default. Duplicate names throw an error by default. Disable validation to rename duplicates.
- --verbose Logs everything that happens during generation by default. Log only success / error per service by default. Enable verbosity through this flag.
- --version, -v - Prints the version of the generator.

Consequences 2

Naming is clearer, shorter and consistent. Only minor implementation needed for a first version.