2017 © Pedro Peláez
 

library zf-apigility-documentation-swagger

Apigility API Swagger documentation module

image

zfcampus/zf-apigility-documentation-swagger

Apigility API Swagger documentation module

  • Monday, May 7, 2018
  • by zendframework
  • Repository
  • 8 Watchers
  • 12 Stars
  • 232,045 Installations
  • JavaScript
  • 4 Dependents
  • 0 Suggesters
  • 35 Forks
  • 7 Open issues
  • 18 Versions
  • 5 % Grown

The README.md

Swagger Documentation Provider for Apigility

Repository abandoned 2019-12-31

This repository has moved to laminas-api-tools/api-tools-documentation-swagger., (*1)

Build Status Coverage Status, (*2)

Introduction

This module provides Apigility the ability to show API documentation through a Swagger UI., (*3)

The Swagger UI is immediately accessible after enabling this module at the URI path /apigility/swagger., (*4)

In addition to providing the HTML UI, this module also plugs into the main Apigility documentation resource (at the path /apigility/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 /apigility/documentation/:module/:service., (*5)

Requirements

Please see the composer.json file., (*6)

Installation

Run the following composer command:, (*7)

$ composer require zfcampus/zf-apigility-documentation-swagger

Alternately, manually add the following to your composer.json, in the require section:, (*8)

"require": {
    "zfcampus/zf-apigility-documentation-swagger": "^1.2"
}

And then run composer update to ensure the module is installed., (*9)

Finally, add the module name to your project's config/application.config.php under the modules key:, (*10)

return [
    /* ... */
    'modules' => [
        /* ... */
        'ZF\Apigility\Documentation\Swagger',
    ],
    /* ... */
];

zf-component-installer

If you use zf-component-installer, that plugin will install zf-apigility-documentation-swagger as a module for you., (*11)

Routes

/apigility/swagger

Shows the Swagger UI JavaScript application., (*12)

Assets: /zf-apigility-documentation-swagger/

Various CSS, images, and JavaScript libraries required to deliver the Swagger UI client application., (*13)

Configuration

System Configuration

The following is required to ensure the module works within a ZF2 and/or Apigility-enabled application:, (*14)

namespace ZF\Apigility\Documentation\Swagger;

return [
    'router' => [
        'routes' => [
            'zf-apigility' => [
                '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' => [
            'zf-apigility-documentation-swagger' => __DIR__ . '/../view',
        ],
    ],

    'asset_manager' => [
        'resolver_configs' => [
            'paths' => [
                __DIR__ . '/../asset',
            ],
        ],
    ],

    'zf-content-negotiation' => [
        'accept_whitelist' => [
            'ZF\Apigility\Documentation\Controller' => [
                0 => 'application/vnd.swagger+json',
            ],
        ],
        'selectors' => [
            'Documentation' => [
                ViewModel::class => [
                    'application/vnd.swagger+json',
                ],
            ],
        ],
    ],
];

ZF Events

Listeners

ZF\Apigility\Documentation\Swagger\Module

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 ZF\Apigility\Documentation\Swagger\ViewModel view model (likely selected as the content-negotiated view model based off of Accept media types)., (*15)

ZF Services

View Models

ZF\Apigility\Documentation\Swagger\ViewModel

This view model is responsible for translating the available ZF\Apigility\Documentation models into Swagger-specific models, and further casting them to arrays for later rendering as JSON., (*16)

The Versions

23/04 2014

1.0.0-beta3

1.0.0.0-beta3 http://apigility.org/

Apigility API Swagger documentation module

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

zf2 documentation zend swagger module apigility

21/04 2014

dev-feature/readme-documentation

dev-feature/readme-documentation http://apigility.org/

Apigility API Swagger documentation module

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

zf2 documentation zend swagger module apigility

01/04 2014

1.0.0beta2

1.0.0.0-beta2 http://apigility.org/

Apigility API Swagger documentation module

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

zf2 documentation zend swagger module apigility

18/03 2014

1.0.0beta1

1.0.0.0-beta1 http://apigility.org/

Apigility API Swagger documentation module

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

zf2 documentation zend swagger module apigiltiy

28/02 2014

0.9.0

0.9.0.0 http://apigility.org/

Apigility API Swagger documentation module

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

zf2 documentation zend swagger module apigiltiy

28/02 2014

0.9.1

0.9.1.0 http://apigility.org/

Apigility API Swagger documentation module

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

zf2 documentation zend swagger module apigiltiy