ะั, ััะฐััะฝะธะบะธ Laminas, ัะพะดะธะปะธัั ะธ ะถะธะฒะตะผ ะฒ ัะฐะทะฝัั ัััะฐะฝะฐั . ะฃ ะผะฝะพะณะธั ะธะท ะฝะฐั ะตััั ะดััะทัั, ัะพะดััะฒะตะฝะฝะธะบะธ ะธ ะบะพะปะปะตะณะธ ะบะฐะบ ะฒ ะ ะพััะธะธ, ัะฐะบ ะธ ะฒ ะฃะบัะฐะธะฝะต. ะะตะบะพัะพััะต ะธะท ะฝะฐั ัะพะดะธะปะธัั ะฒ ะ ะพััะธะธ. ะะตะบะพัะพััะต ะธะท ะฝะฐั ะถะธะฒัั ะฒ ะ ะพััะธะธ. ะฃ ะฝะตะบะพัะพััั ะฑะฐะฑััะบะธ ะธ ะดะตะดััะบะธ ััะฐะถะฐะปะธัั ั ัะฐัะธััะฐะผะธ ะฒะพ ะัะพัะพะน ะผะธัะพะฒะพะน ะฒะพะนะฝะต. ะะดะตัั ะฝะธะบัะพ ะฝะต ะฟะพะดะดะตัะถะธะฒะฐะตั ัะฐัะธะทะผ.
ะฃ ะพะดะฝะพะณะพ ะธะท ะฝะฐั ะตััั ัะบัะฐะธะฝัะบะฐั ัะพะดััะฒะตะฝะฝะธัะฐ, ะบะพัะพัะฐั ัะฟะฐัะปะฐัั ะธะท ะดะพะผะฐ ะฒะผะตััะต ั ััะฝะพะผ. ะะพะตะทะด ะทะฐะดะตัะถะฐะปัั ะธะท-ะทะฐ ะฑะพะผะฑะตะถะบะธ ะฝะฐ ะดะพัะพะณะต ะฒะฟะตัะตะดะธ. ะฃ ะฝะฐั ะตััั ะดััะทัั, ะบะพัะพััะต ะฟััััััั ะฒ ะฑะพะผะฑะพัะฑะตะถะธัะฐั . ะั ั ััะตะฒะพะณะพะน ะถะดะตะผ ะฒะตััะพัะบะธ ะพั ะฝะธั ะฟะพัะปะต ะฒะพะทะดััะฝัั ะฝะฐะปะตัะพะฒ, ะบะพัะพััะต ะฑะตัะฟะพััะดะพัะฝะพ ะฝะฐะฝะพััั ัะดะฐัั ะธ ะฟะพะฟะฐะดะฐัั ะฟะพ ะฑะพะปัะฝะธัะฐะผ, ัะบะพะปะฐะผ, ะดะตััะบะธะผ ัะฐะดะฐะผ ะธ ะดะพะผะฐะผ. ะั ะฝะต ะฑะตัะตะผ ััะพ ะธะท ะบะฐะบะธั -ะปะธะฑะพ ะกะะ. ะั ะฝะฐะฑะปัะดะฐะตะผ ััะพ ะฝะฐะฟััะผัั.
ะั ะดะพะฒะตััะตัะต ะฝะฐะผ ะดะพััะฐัะพัะฝะพ, ััะพะฑ ะธัะฟะพะปัะทะพะฒะฐัั ะฝะฐัะธ ะฟัะพะณัะฐะผะผั, ะธ ะผั ะฟัะพัะธะผ ะฒะฐั ะดะพะฒะตัะธัััั ะฝะฐะผ ะฒะฝะพะฒั. ะั ะฝัะถะดะฐะตะผัั ะฒ ะฟะพะผะพัะธ. ะัั ะพะดะธัะต ะธ ะฟัะพัะตัััะนัะต ะฟัะพัะธะฒ ััะพะน ะฑะตัะฟะพะปะตะทะฝะพะน ะฒะพะนะฝั. ะััะฐะฝะพะฒะธัะต ะบัะพะฒะพะฟัะพะปะธัะธะต. ะกะบะฐะถะธัะต "ะะตั ะฒะพะนะฝะต!"
We at Laminas come from all over the world. Many of us have friends, family and colleagues in both Russia and Ukraine. Some of us were born in Russia. Some of us currently live in Russia. Some have grandparents who fought Nazis in World War II. Nobody here supports fascism.
One team member has a Ukrainian relative who fled her home with her son. The train was delayed due to bombing on the road ahead. We have friends who are hiding in bomb shelters. We anxiously follow up on them after the air raids, which indiscriminately fire at hospitals, schools, kindergartens and houses. We're not taking this from any media. These are our actual experiences.
You trust us enough to use our software. We ask that you trust us to say the truth on this. We need your help. Go out and protest this unnecessary war. Stop the bloodshed. Say "stop the war!"
This module provides Laminas API Tools the ability to show API documentation through a Swagger UI.
The Swagger UI is immediately accessible after enabling this module at the URI path /api-tools/swagger
.
In addition to providing the HTML UI, this module also plugs into the main Laminas API Tools documentation
resource (at the path /api-tools/documentation
) in order to allow returning a documentation
payload in the application/vnd.swagger+json
media type; this resource is what feeds the Swagger
UI. You can access this representation by passing the media type application/vnd.swagger+json
for
the Accept
header via the path /api-tools/documentation/:module/:service
.
Please see the composer.json file.
Run the following composer
command:
$ composer require laminas-api-tools/api-tools-documentation-swagger
Alternately, manually add the following to your composer.json
, in the require
section:
"require": {
"laminas-api-tools/api-tools-documentation-swagger": "^1.2"
}
And then run composer update
to ensure the module is installed.
Finally, add the module name to your project's config/application.config.php
under the modules
key:
return [
/* ... */
'modules' => [
/* ... */
'Laminas\ApiTools\Documentation\Swagger',
],
/* ... */
];
If you use laminas-component-installer, that plugin will install api-tools-documentation-swagger as a module for you.
Shows the Swagger UI JavaScript application.
Various CSS, images, and JavaScript libraries required to deliver the Swagger UI client application.
The following is required to ensure the module works within a Laminas and/or Laminas API Tools-enabled application:
namespace Laminas\ApiTools\Documentation\Swagger;
return [
'router' => [
'routes' => [
'api-tools' => [
'child_routes' => [
'swagger' => [
'type' => 'segment',
'options' => [
'route' => '/swagger',
'defaults' => [
'controller' => SwaggerUi::class,
'action' => 'list',
],
],
'may_terminate' => true,
'child_routes' => [
'api' => [
'type' => 'segment',
'options' => [
'route' => '/:api',
'defaults' => [
'action' => 'show',
],
],
'may_terminate' => true,
],
],
],
],
],
],
],
'service_manager' => [
'factories' => [
SwaggerViewStrategy::class => SwaggerViewStrategyFactory::class,
],
],
'controllers' => [
'factories' => [
SwaggerUi::class => SwaggerUiControllerFactory::class,
],
],
'view_manager' => [
'template_path_stack' => [
'api-tools-documentation-swagger' => __DIR__ . '/../view',
],
],
'asset_manager' => [
'resolver_configs' => [
'paths' => [
__DIR__ . '/../asset',
],
],
],
'api-tools-content-negotiation' => [
'accept_whitelist' => [
'Laminas\ApiTools\Documentation\Controller' => [
0 => 'application/vnd.swagger+json',
],
],
'selectors' => [
'Documentation' => [
ViewModel::class => [
'application/vnd.swagger+json',
],
],
],
],
];
This listener is attached to the MvcEvent::EVENT_RENDER
event at priority 100
. Its purpose is
to conditionally attach a view strategy to the view system in cases where the controller response is
a Laminas\ApiTools\Documentation\Swagger\ViewModel
view model (likely selected as the
content-negotiated view model based off of Accept
media types).
This view model is responsible for translating the available Laminas\ApiTools\Documentation
models
into Swagger-specific models, and further casting them to arrays for later rendering as JSON.