Download the PHP package ronasit/laravel-swagger without Composer
On this page you can find all versions of the php package ronasit/laravel-swagger. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Rated 1.00 based on 1 reviews
Informations about the package laravel-swagger
Laravel Swagger plugin
Comparison to another documentation generators
LaravelSwagger | Scramble | |
---|---|---|
Force developers to write tests | :white_check_mark: | :x: |
Guarantee that API works | :white_check_mark: | :x: |
Works with any route types covered by tests | :white_check_mark: | :x: |
Generate response schema using JSON Resource class | :x: | :white_check_mark: |
Runtime documentation generation | :x: | :white_check_mark: |
Introduction
This plugin is designed to generate documentation for your REST API during the passing PHPUnit tests.
Installation
- Install the package using the following command:
composer require ronasit/laravel-swagger
Note
For Laravel 5.5 or later the package will be auto-discovered. For older versions add the
AutoDocServiceProvider
to the providers array inconfig/app.php
as follow:
- Run
php artisan vendor:publish --provider=RonasIT\\AutoDoc\\AutoDocServiceProvider
-
Add
\RonasIT\AutoDoc\Http\Middleware\AutoDocMiddleware::class
middleware to the global HTTP middleware listbootstrap\app.php
: - Add
\RonasIT\AutoDoc\Traits\AutoDocTestCaseTrait
trait totests/TestCase.php
-
Configure documentation saving using one of the next ways:
-
Add
SwaggerExtension
to the<extensions>
block of yourphpunit.xml
. Please note that this way will be removed after updating PHPUnit up to 10 version (https://github.com/sebastianbergmann/phpunit/issues/4676) - Call
php artisan swagger:push-documentation
console command after thetests
stage in your CI/CD configuration
-
Usage
Basic usage
-
Create request class:
Note
For correct working of plugin you'll have to dispose all the validation rules in the
rules()
method of your request class. Also, your request class must be connected to the controller via dependency injection. Plugin will take validation rules from the request class and generate fields description of input parameter. -
Create a controller and a method for your route:
Note
Dependency injection of request class is optional but if it not presents, the "Parameters" block in the API documentation will be empty.
-
Create test for API endpoint:
- Run tests
- Go to route defined in the
auto-doc.route
config -
Profit!
Annotations
You can use the following annotations in your request classes to customize documentation of your API endpoints:
- @summary - short description of request
- @description - implementation notes
- @_204 - custom description of response code. You can specify any code as you want.
- @some_field - description of the field from the rules method
- @deprecated - mark route as deprecated
Note
If you do not use request class, the summary and description and parameters will be empty.
Configs
auto-doc.route
- route for generated documentationauto-doc.basePath
- root of your API
Custom driver
You can specify the way to collect and view documentation by creating your own custom driver.
You can find example of drivers here.
Viewing OpenAPI documentation
As of version 2.2, the package includes the ability to switch between OpenAPI documentation
viewers. To access different viewers, modify the documentation_viewer
configuration.
This change is reflected immediately, without the need to rebuild the documentation file.
Merging additional documentations
The package supports the integration of the primary documentation with additional valid
OpenAPI files specified in the additional_paths
configuration.
Migration guides
3.0.1-beta
Contributing
Thank you for considering contributing to Laravel Swagger plugin! The contribution guide can be found in the Contributing guide.
License
Laravel Swagger plugin is open-sourced software licensed under the MIT license.
All versions of laravel-swagger with dependencies
laravel/framework Version ^11.20
phpunit/phpunit Version ^10.5
ext-json Version *