- Add filtering model properties by route area to
JMSModelDescriber
- Added new optional parameter
$context
toPropertyDescriberInterface::supports()
- Deprecated
null
type from$options
inNelmio\ApiDocBundle\Attribute\Model::__construct()
. Pass an empty array ([]
) instead. - Deprecated
null
type from$options
inNNelmio\ApiDocBundle\Attribute\Model::__construct()
. Pass an empty array ([]
) instead.
- Bumped swagger-ui files from
5.18.1
to5.18.2
- Bumped redoc files to
2.2.0
- Fixed incorrect directory updated for swagger-ui files from version
4.33.2
- Bumped swagger-ui files to
5.18.1
- Fixed explicitly set default values defined in
#[OA\Property]
being overwritten
- Fixed custom JMS enum type handling
- Added support for name based serialisation of JMS enums
- Deprecated
Nelmio\ApiDocBundle\Annotation
namespace in favor ofNelmio\ApiDocBundle\Attribute
namespace in preparation for 5.x. Consider upgrading to the new attribute syntax.
- use Nelmio\ApiDocBundle\Annotation\Areas;
- use Nelmio\ApiDocBundle\Annotation\Model;
- use Nelmio\ApiDocBundle\Annotation\Operation;
- use Nelmio\ApiDocBundle\Annotation\Security;
+ use Nelmio\ApiDocBundle\Attribute\Areas;
+ use Nelmio\ApiDocBundle\Attribute\Model;
+ use Nelmio\ApiDocBundle\Attribute\Operation;
+ use Nelmio\ApiDocBundle\Attribute\Security;
- Added support to configure
options
andserializationContext
vianelmio_api_doc.models.names
. - Fixed
serializationContext
not being applied to nested models.
- Added support to opt out of JMS serializer usage per endpoint by setting
useJms
in the serializationContext.#[OA\Response(response: 200, content: new Model(type: UserDto::class, serializationContext: ["useJms" => false]))]
- Create top level OpenApi Tag from Tags top level annotations/attributes
- Calling
DocumentationExtension::getExtendedType()
has been deprecated in favor ofDocumentationExtension::getExtendedTypes()
to align with the deprecation introduced withsymfony/symfony
version4.2
.
- Add ability to configure UI through configuration
nelmio_api_doc:
html_config:
assets_mode: bundle
redocly_config:
expandResponses: '200,201'
hideDownloadButton: true
swagger_ui_config:
deepLinking: true
- Added support for JMS @Discriminator annotation/attribute
#[\JMS\Serializer\Annotation\Discriminator(field: 'type', map: ['car' => Car::class, 'plane' => Plane::class])] abstract class Vehicle { } class Car extends Vehicle { } class Plane extends Vehicle { }
- Added support for some integer ranges (https://phpstan.org/writing-php-code/phpdoc-types#integer-ranges).
Annotations attached to integer properties like:
will be interpreted as appropriate
/** * @var int<6, 11> * @var int<min, 11> * @var int<6, max> * @var positive-int * @var negative-int */
minimum
andmaximum
properties in the generated OpenAPI specification.
Dropped support for PHP 7.2 and PHP 7.3. PHP 7.4 is the minimum required version now.
- Cache configuration option
nelmio_api_doc.cache.item_id
now automatically gets the area appended.Result in cache keys:nelmio_api_doc: cache: pool: app.cache item_id: nelmio_api_doc.docs areas: default: ... area1: ...
nelmio_api_doc.docs.default
&nelmio_api_doc.docs.area1
to be used respectively. - Added cache configuration option per area.
Non-configured options will be inherited from
nelmio_api_doc: areas: default: # Manual cache configuration cache: pool: app.cache item_id: nelmio_api_doc.docs.default ... area1: cache: pool: app.cache item_id: nelmio_api_doc.docs.area1 ...
nelmio_api_doc.cache
. - Fixed vendor extensions (
x-*
) from configuration not being outputted in the generated specification.Now results in JSON specification:nelmio_api_doc: documentation: info: title: 'My API' description: 'My API description' x-foo: 'bar'
{ ... "info": { "title": "API", "version": "1.0", "x-foo": "bar" }, ... }
- Updated nullable enum handling to align with the behaviour of other object types. It now uses wraps nullable enums with
oneOf
instead ofallOf
.
-
Updated bundle directory structure to recommended file structure as described in https://symfony.com/doc/7.0/bundles/best_practices.html.
It might be necessary to reinstall the assets:
bin/console assets:install
If your codebase mentions a file or directory by path then an update to this path is necessary. For example to following configuration:
doc-api:
resource: "@NelmioApiDocBundle/Resources/config/routing/swaggerui.xml"
prefix: /api/doc
Becomes:
doc-api:
resource: "@NelmioApiDocBundle/config/routing/swaggerui.xml"
prefix: /api/doc
- Added bundle configuration options
nelmio_api_doc.cache.pool
andnelmio_api_doc.cache.item_id
.nelmio_api_doc: cache: pool: app.cache item_id: nelmio_api_doc.docs
- Added Redocly as an alternative to Swagger UI. https://github.com/Redocly/redoc.
- Added support for describing dictionary types in OpenAPI 3.0.
- Passing groups to
PropertyDescriberInterface::describe()
via the$groups
parameter is deprecated, the parameter will get removed in a future version. Pass groups via$context['groups']
instead.
- Added support of OpenAPI 3.0. The internals were completely reworked and this version introduces BC breaks.
- Added
@SerializedName
annotation support and name converters when using Symfony >= 4.2. - Removed pattern added from the Expression Violation message.
- Added FOSRestBundle 3.x support
- Added
@SWG
annotations support at methods level in models
-
Usage of Google Fonts was removed. System fonts
serif
/sans
will be used instead. This can lead to a different look on different operating systems. You can re-add Google Fonts again manually by overriding the template. -
The Twig template for the Swagger UI now contains blocks to make it easier to overwrite certain parts. See the official documentation how to do this.
-
Add a documentation form extension. Use the
documentation
option to define how a form field is documented. -
Allow references to config definitions in controllers.
-
Using
@Model
implicitly in@SWG\Schema
,@SWG\Items
and@SWG\Property
is deprecated. Useref=@Model()
instead.Before:
/** * This was considered as an array of models. * * @SWG\Property(@Model(type=FooClass::class)) */
After:
/** * For an individual object: * @SWG\Property(ref=@Model(type=FooClass::class)) * * For an array: * @SWG\Property(type="array", @SWG\Items(ref=@Model(type=FooClass::class))) */
Config
-
nelmio_api_doc.areas
added support to filter by host patterns.nelmio_api_doc: areas: [ host_patterns: [ ^api\. ] ]
-
Added dependency for "symfony/options-resolver:^3.4.4|^4.0"
- Added Symfony Validator constraints support
Symfony Forms
- Support for boolean checkbox
- Support for integer
JMS Serializer
- Support JMS
int
(alias forinteger
) - Also process phpdoc annotations
SwaggerPHP
- Handle
enum
anddefault
properties from SwaggerPHP annotation - Support
@Security
annotations
Config
-
nelmio_api_doc.routes
has been replaced bynelmio_api_doc.areas
. Please update your config accordingly.Before:
nelmio_api_doc: routes: [ path_patterns: [ /api ] ]
After:
nelmio_api_doc: areas: [ path_patterns: [ /api ] ]
Large refactoring introducing zircote/swagger-php
for swagger annotations.
See UPGRADE-3.0.md for upgrading instructions.