We use OpenAPI Generator with version 7.0.1
to generate SDKs for different languages.
Our template aka mustache files are located in ./mustache-templates
directory.
Are slightly modified from the original ones for our needs.
- Node.js ^16 || ^18 and npm
- docker (optional)
- java runtime v18 or higher
npm install
(if you have not already installed)npm run generate-sdk-ruby
/generate-sdk-python
/generate-sdk-java
/generate-sdk-php
SDK will be generated in ./sdks
directory in associated language folder.
- build-update-md-tables-from-openapi - creating and updates docs in
./docs/reference-docs
directory - remove-stoplight-tags-from-openapi - spotlight is gui software for editing openapi files. Each usage added some tags to openapi file. This command removes them.
- prepare-open-api-for-sdk - scripts in the basic form are not ready for generating sdks without errors or bugs. This command make bunch of actions which mostly language specific.
- (all) removing not supported endpoints (deprecated or those wasn't refactored to the newest versions of the API)
- (all) removing not used schemas and parameters
- (all) removing
additional properties
from schemas - (java / python) removing
required
property from schema's parameters that is assigned asnullable
- (java) merging multiple response schemas with 2xx status code into one schema
- (php) merging oneOf schemas into one schema
- (php) associating each element into object
- create-clean-project - running
build-update-md-tables-from-openapi
command and uploading openapi file to the server - fix-schemas-with-refs - script for fixing
oneOf
schemas with$ref
- fix-schemas-properties-with-single-enum - script for adding default value to schemas with single enum
- readme-upload-missing-images - script for uploading images to the server
- count-important-statistics-about-openapi - script for counting occurrences and counting statistics which are important for openapi correctness
- build-production-openapi - creating openapi snapshot file which was uploaded to openapi server
- fix-zero-level-schemas - script generating openapi with correct zero level schemas for requests and responses consistent with the arrangements from CONTRIBUTING.md
- generate-endpoints-coverage-docs - script for generating readme file with endpoints coverage
- generate-sdk-xxx - script for generating sdk in associated language
- generate-sdks - script for concurrently generating all sdks
- test - tests are used to check openapi schema didn't change after scripts refactoring
- Init all submodules
git submodule update --init --recursive
. - Create a new branch:
git checkout -b MY_BRANCH_NAME
- Add changes (sticking to the rules from CONTRIBUTING.md)
- Generate SDKs
- Create new ones for Your changes and ensure everything run without errors
- Commit all changes to main repo and submodules
- Push your branch and create a pull request against
main
branch - When the changes are merged, publish new version to remote repositories.
Easiest way for running tests is to use docker-compose
file.
- Ensure that you have installed
docker
. - Ensure that You have init submodules
git submodule update --init --recursive
docker-compose build
- build docker images for containersdocker-compose up
- run containers (running commands separately for better readability of logs)
For running SDK separately or on Your local machine without docker go in to the directory of the SDK and read README.md
file.
Note that running tests will affect your Voucherify project data. Run tests only on development projects.
Manual steps checklist:
- Ensure that all SDKs were generated without error.
- Ensure new tests were created for changes.
- Ensure that all SDKs tests passed.
- Decide whether the changes concern the minor, major or patch version.
- Commit all generated changes to submodules and main module.
- Publish new version of the SDKs to repositories manager
- patch - backward compatible changes - bug fixes, small changes, refactoring
- minor - backward compatible changes - new endpoints or properties
- major - breaking changes - new schemas, naming changes, removing endpoints or properties, changes in the mustache logic