Generating OpenAPI documents
Using the command line
swagger-php includes a command line tool ./vendor/bin/openapi. This can be used to generate OpenAPI documents.
> ./vendor/bin/openapi app -o openapi.yamlOutput Format
By default the output format is YAML. If a filename is given (via --output or -o) the tool will use the file extension to determine the format.
The --format option can be used to force a specific format.
Bootstrap
The bootstrap option -b is useful when trying to use swagger-php without proper autoloading.
For example, you might want to evaluate the library using a single file with just a few annotations. In this case telling swagger-php to bootstrap (pre-load) the file prior to processing it will ensure PHP's reflection code will be able to inspect your code.
> ./vendor/bin/openapi -b my_file.php my_file.phpFor a list of all available options use the -h option
> ./vendor/bin/openapi -h
Usage: openapi [--option value] [/path/to/project ...]
Options:
--config (-c) Generator config
ex: -c operationId.hash=false
--output (-o) Path to store the generated documentation.
ex: --output openapi.yaml
--exclude (-e) Exclude path(s).
ex: --exclude vendor,library/Zend
--pattern (-n) Pattern of files to scan.
ex: --pattern "*.php" or --pattern "/\.(phps|php)$/"
--bootstrap (-b) Bootstrap a php file for defining constants, etc.
ex: --bootstrap config/constants.php
--processor (-p) Register an additional processor.
--format (-f) Force yaml or json.
--debug (-d) Show additional error information.
--version The OpenAPI version; defaults to 3.0.0.
--help (-h) Display this help message.Using PHP
Depending on your use case PHP code can also be used to generate OpenAPI documents in a more dynamic way.
In its simplest form this may look something like
<?php
require("vendor/autoload.php");
$openapi = \OpenApi\Generator::scan(['/path/to/project']);
header('Content-Type: application/x-yaml');
echo $openapi->toYaml();Programming API
Details about the swagger-php API can be found in the reference.