mirror of
https://github.com/retailcrm/NelmioApiDocBundle.git
synced 2025-02-02 15:51:48 +03:00
Add Api-Platform 3.x support
This commit is contained in:
parent
cfb2800402
commit
383fb78360
@ -168,7 +168,7 @@ final class NelmioApiDocExtension extends Extension implements PrependExtensionI
|
||||
}
|
||||
|
||||
// ApiPlatform support
|
||||
if (isset($bundles['ApiPlatformBundle']) && class_exists('ApiPlatform\Core\Documentation\Documentation')) {
|
||||
if (isset($bundles['ApiPlatformBundle']) && class_exists('ApiPlatform\Documentation\Documentation')) {
|
||||
$loader->load('api_platform.xml');
|
||||
}
|
||||
|
||||
|
@ -11,14 +11,17 @@
|
||||
|
||||
namespace Nelmio\ApiDocBundle\Describer;
|
||||
|
||||
use ApiPlatform\Core\Documentation\Documentation;
|
||||
use ApiPlatform\Documentation\DocumentationInterface;
|
||||
use ApiPlatform\Core\Swagger\Serializer\DocumentationNormalizer;
|
||||
use ApiPlatform\OpenApi\Factory\OpenApiFactoryInterface;
|
||||
use Symfony\Component\Serializer\Normalizer\NormalizerInterface;
|
||||
|
||||
final class ApiPlatformDescriber extends ExternalDocDescriber
|
||||
{
|
||||
public function __construct(Documentation $documentation, NormalizerInterface $normalizer)
|
||||
public function __construct(DocumentationInterface $documentation, NormalizerInterface $normalizer)
|
||||
{
|
||||
// var_dump(get_class($documentation));
|
||||
// die();
|
||||
if (!$normalizer->supportsNormalization($documentation, 'json')) {
|
||||
throw new \InvalidArgumentException(sprintf('Argument 2 passed to %s() must implement %s and support normalization of %s. The normalizer provided is an instance of %s.', __METHOD__, NormalizerInterface::class, Documentation::class, get_class($normalizer)));
|
||||
}
|
||||
@ -27,7 +30,7 @@ final class ApiPlatformDescriber extends ExternalDocDescriber
|
||||
$documentation = (array) $normalizer->normalize(
|
||||
$documentation,
|
||||
null,
|
||||
[DocumentationNormalizer::SPEC_VERSION => 3]
|
||||
class_exists(DocumentationNormalizer::class) ? [DocumentationNormalizer::SPEC_VERSION => 3] : []
|
||||
);
|
||||
|
||||
// TODO: remove this
|
||||
|
@ -5,18 +5,17 @@
|
||||
|
||||
<services>
|
||||
<service id="nelmio_api_doc.describers.api_platform" class="Nelmio\ApiDocBundle\Describer\ApiPlatformDescriber" public="false">
|
||||
<argument type="service" id="nelmio_api_doc.describers.api_platform.documentation" />
|
||||
<argument type="service" id="api_platform.swagger.normalizer.documentation" />
|
||||
<argument type="service" id="nelmio_api_doc.describers.api_platform.openapi" />
|
||||
<argument type="service" id="api_platform.openapi.normalizer" />
|
||||
|
||||
<tag name="nelmio_api_doc.describer" priority="-100" />
|
||||
</service>
|
||||
|
||||
<service id="nelmio_api_doc.describers.api_platform.documentation" class="ApiPlatform\Core\Documentation\Documentation" public="false">
|
||||
<factory service="api_platform.action.documentation" method="__invoke" />
|
||||
<argument type="service">
|
||||
<service class="Symfony\Component\HttpFoundation\Request" />
|
||||
</argument>
|
||||
<service id="nelmio_api_doc.describers.api_platform.openapi" class="ApiPlatform\OpenApi\OpenApi" public="false">
|
||||
<factory service="api_platform.openapi.factory" method="__invoke" />
|
||||
</service>
|
||||
|
||||
|
||||
</services>
|
||||
|
||||
</container>
|
||||
|
@ -11,7 +11,7 @@
|
||||
|
||||
namespace Nelmio\ApiDocBundle\Tests\Describer;
|
||||
|
||||
use ApiPlatform\Core\Documentation\Documentation;
|
||||
use ApiPlatform\Documentation\Documentation;
|
||||
use ApiPlatform\Metadata\Resource\ResourceNameCollection;
|
||||
use Nelmio\ApiDocBundle\Describer\ApiPlatformDescriber;
|
||||
use OpenApi\Annotations\OpenApi;
|
||||
|
@ -12,48 +12,9 @@
|
||||
namespace Nelmio\ApiDocBundle\Tests\Functional\Entity;
|
||||
|
||||
use ApiPlatform\Core\Annotation\ApiProperty;
|
||||
use ApiPlatform\Core\Annotation\ApiResource;
|
||||
use Symfony\Component\Validator\Constraints as Assert;
|
||||
|
||||
/**
|
||||
* @author Guilhem N. <egetick@gmail.com>
|
||||
*
|
||||
* @ApiResource(
|
||||
* collectionOperations={
|
||||
* "get"={"method"="GET"},
|
||||
* "custom2"={"path"="/foo", "method"="GET"},
|
||||
* "custom"={"path"="/foo", "method"="POST"},
|
||||
* },
|
||||
* itemOperations={"get"={"method"="GET"}})
|
||||
* )
|
||||
*/
|
||||
class Dummy
|
||||
{
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $id;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*
|
||||
* @Assert\NotBlank
|
||||
* @ApiProperty(iri="http://schema.org/name")
|
||||
*/
|
||||
private $name;
|
||||
|
||||
public function getId(): int
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
public function setName(string $name)
|
||||
{
|
||||
$this->name = $name;
|
||||
}
|
||||
|
||||
public function getName(): string
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
}
|
||||
if (!class_exists(ApiProperty::class)) {
|
||||
class_alias(Dummy81::class, Dummy::class);
|
||||
} else {
|
||||
class_alias(Dummy71::class, Dummy::class);
|
||||
}
|
60
Tests/Functional/Entity/Dummy71.php
Normal file
60
Tests/Functional/Entity/Dummy71.php
Normal file
@ -0,0 +1,60 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the NelmioApiDocBundle package.
|
||||
*
|
||||
* (c) Nelmio
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Nelmio\ApiDocBundle\Tests\Functional\Entity;
|
||||
|
||||
use ApiPlatform\Metadata\ApiProperty;
|
||||
use ApiPlatform\Metadata\ApiResource;
|
||||
use Symfony\Component\Validator\Constraints as Assert;
|
||||
|
||||
/**
|
||||
* @author Guilhem N. <egetick@gmail.com>
|
||||
*
|
||||
* @ApiResource(
|
||||
* shortName="Dummy",
|
||||
* collectionOperations={
|
||||
* "get"={"method"="GET"},
|
||||
* "custom2"={"path"="/foo", "method"="GET"},
|
||||
* "custom"={"path"="/foo", "method"="POST"},
|
||||
* },
|
||||
* itemOperations={"get"={"method"="GET"}})
|
||||
* )
|
||||
*/
|
||||
class Dummy71
|
||||
{
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $id;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*
|
||||
* @Assert\NotBlank
|
||||
* @ApiProperty(iri="http://schema.org/name")
|
||||
*/
|
||||
private $name;
|
||||
|
||||
public function getId(): int
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
public function setName(string $name)
|
||||
{
|
||||
$this->name = $name;
|
||||
}
|
||||
|
||||
public function getName(): string
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
}
|
64
Tests/Functional/Entity/Dummy81.php
Normal file
64
Tests/Functional/Entity/Dummy81.php
Normal file
@ -0,0 +1,64 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the NelmioApiDocBundle package.
|
||||
*
|
||||
* (c) Nelmio
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Nelmio\ApiDocBundle\Tests\Functional\Entity;
|
||||
|
||||
use ApiPlatform\Metadata\ApiProperty;
|
||||
use ApiPlatform\Metadata\ApiResource;
|
||||
use ApiPlatform\Metadata\Get;
|
||||
use ApiPlatform\Metadata\GetCollection;
|
||||
use ApiPlatform\Metadata\Post;
|
||||
use Symfony\Component\Validator\Constraints as Assert;
|
||||
|
||||
/**
|
||||
* @author Guilhem N. <egetick@gmail.com>
|
||||
*/
|
||||
#[
|
||||
ApiResource(
|
||||
shortName: "Dummy",
|
||||
operations: [
|
||||
new Get(name: "get"),
|
||||
new Get(name: "custom2", uriTemplate: "/foo"),
|
||||
new Post(name: "custom", uriTemplate: "/foo"),
|
||||
new GetCollection(),
|
||||
],
|
||||
)
|
||||
]
|
||||
class Dummy81
|
||||
{
|
||||
/**
|
||||
* @var int
|
||||
*/
|
||||
private $id;
|
||||
|
||||
/**
|
||||
* @var string
|
||||
*
|
||||
* @Assert\NotBlank
|
||||
*/
|
||||
#[ApiProperty(iris: ["http://schema.org/name"])]
|
||||
private $name;
|
||||
|
||||
public function getId(): int
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
public function setName(string $name)
|
||||
{
|
||||
$this->name = $name;
|
||||
}
|
||||
|
||||
public function getName(): string
|
||||
{
|
||||
return $this->name;
|
||||
}
|
||||
}
|
@ -11,7 +11,7 @@
|
||||
|
||||
namespace Nelmio\ApiDocBundle\Tests\Functional;
|
||||
|
||||
use ApiPlatform\Core\Bridge\Symfony\Bundle\ApiPlatformBundle;
|
||||
use ApiPlatform\Symfony\Bundle\ApiPlatformBundle;
|
||||
use Bazinga\Bundle\HateoasBundle\BazingaHateoasBundle;
|
||||
use FOS\RestBundle\FOSRestBundle;
|
||||
use Hateoas\Configuration\Embedded;
|
||||
|
@ -48,7 +48,7 @@
|
||||
"symfony/twig-bundle": "^4.4|^5.2|^6.0",
|
||||
"symfony/validator": "^4.4|^5.2|^6.0",
|
||||
|
||||
"api-platform/core": "^2.7.0",
|
||||
"api-platform/core": "^2.7.0|^3@dev",
|
||||
"symfony/deprecation-contracts": "^2.1|^3",
|
||||
|
||||
"friendsofsymfony/rest-bundle": "^2.8|^3.0",
|
||||
|
Loading…
x
Reference in New Issue
Block a user