Skip to content

API client generator is a console application capable of generating an API client based on OpenAPI(Swagger) specification.

License

Notifications You must be signed in to change notification settings

DoclerLabs/api-client-generator

Repository files navigation

OpenAPI SDK generator - API client generator

API client generator is a console application capable of auto-generating a PSR18/PSR7 compliant API client based on OpenAPI v3 specification according to PHP best practices and your code style standards.

Build Status Coverage Status PHPStan Level

Requirements

  • OpenAPI >= 3.0
  • PHP >= 7.0

Why using it?

  • With generated client you are always sure that your OpenAPI specification is up-to-date.
  • Work with objects instead of raw data, it is OOP friendly.
  • Saves your time. You don't need to write data mappers yourself to populate those objects with the data from the response.
  • All the basic type validations in the request and the response done automatically.
  • Despite the fact the code is generated it's clear and readable, simple to debug and to reason about.
  • Highly configurable and extensible.
  • Reliable and well tested.
  • Simply, if something can be automated it should be automated. Focus on important stuff.

Features

  • Supports yaml or json specification file formats.
  • Validates your OpenAPI specification.
  • Supports multiple content types:
    • application/json
    • application/x-www-form-urlencoded
    • application/xml
  • Supports new PHP versions syntax features.
  • It is base client independent, you are free to choose any existing PSR-18 compliant client. Just choose the one which you already use, so generated client would not cause any conflicts with your dependencies. Although not recommended, you can also use or build your own PSR-18 implementation, as the generated client depends on PSR interfaces only.
  • Applies code style rules to generated code, you can specify your own.
  • Generates README and composer.json files with possibility to use your own template.
  • Supports allOf, oneOf, anyOf OpenAPI parameters.
  • Supports nullable optional scheme property.

Example

Check out example directory to see the code generated by api-client-generator.

Try it out:

cd example && \
composer install && \
php test-example.php

Usage

With Docker

$ docker run -it \
-v {path-to-specification}/openapi.yaml:/openapi.yaml:ro \
-v {path-to-client}/some-api-client:/client \
-e NAMESPACE=Group\\SomeApiClient \
-e OPENAPI=/openapi.yaml \
-e OUTPUT_DIR=/client \
-e PACKAGE=group/some-api-client \
dhlabs/api-client-generator

if you're running this command on Windows you might need to use single backslash instead in -e NAMESPACE

Without Docker

Preconditions: PHP 7.4

Clone the repository and run:

OPENAPI={path-to-specification}/openapi.yaml NAMESPACE=Group\SomeApiClient PACKAGE=group/some-api-client OUTPUT_DIR={path-to-client}/generated ./bin/api-client-generator generate

Configuration

The following environment variables are available:

Variable Required Default Enum Example Description
NAMESPACE yes Group\SomeApiClient
PACKAGE yes group/some-api-client
OPENAPI yes /api/openapi.yaml
OUTPUT_DIR yes /client
CODE_STYLE no {path-to-repository}/.php-cs-fixer.php.dist /client/myCodeStyle.php
SOURCE_DIR no src src
CLIENT_PHP_VERSION no 7.4 7.0, 7.1, 7.2, 7.3, 7.4, 8.0, 8.1, 8.2, 8.3 7.4
COMPOSER_JSON_TEMPLATE_DIR no {path-to-repository}/template/composer.json.twig /path/composer.json.twig
README_MD_TEMPLATE_DIR no {path-to-repository}/template/README.md.twig /path/README.md.twig
HTTP_MESSAGE no guzzle guzzle, nyholm nyholm
CONTAINER no pimple pimple pimple
INCLUDE_TAGS no tag1,tag2,tag3 tag whitelist to select generated operations
EXCLUDE_TAGS no tag1,tag2,tag3 tag blacklist to select generated operations

Running tests

$ composer install
$ make test

(check make for all available routines).

About

API client generator is a console application capable of generating an API client based on OpenAPI(Swagger) specification.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages