Download the PHP package zfcampus/zf-versioning without Composer

On this page you can find all versions of the php package zfcampus/zf-versioning. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package zf-versioning

ZF Versioning

Repository abandoned 2019-12-31

This repository has moved to laminas-api-tools/api-tools-versioning.

Build Status Coverage Status

Introduction

zf-versioning is a Zend Framework module for automating service versioning through both URIs and Accept or Content-Type header media types. Information extracted from either the URI or header media type that relates to versioning will be made available in the route match object. In situations where a controller service name is utilizing a sub-namespace matching the regexp V(\d), the matched controller service names will be updated with the currently matched version string.

Requirements

Please see the composer.json file.

Installation

Run the following composer command:

Alternately, manually add the following to your composer.json, in the require section:

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:

zf-component-installer

If you use zf-component-installer, that plugin will install zf-versioning as a module for you.

Configuration

User Configuration

The top-level configuration key for user configuration of this module is zf-versioning.

Key: content-type

The content-type key is used for specifying an array of regular expressions that will be used in parsing both Content-Type and Accept headers for media type based versioning information. A default regular expression is provided in the implementation which should also serve as an example of what kind of regex to create for more specific parsing:

This rule will match the following pseudo-code route:

All captured parts should utilize named parameters. A more specific example, with the top-level key would look like:

Key: default_version

The default_version key provides the default version number to use in case a version is not provided by the client. 1 is the default for default_version.

The setting accepts one of the two following possible values:

Full Example:

or

Key: uri

The uri key is responsible for identifying which routes need to be prepended with route matching information for URL based versioning. This key is an array of route names that is used in the ZF2 router.routes configuration. If a particular route is a child route, the chain will happen at the top-most ancestor.

The route matching segment consists of a rule of [/v:version] while specifying a constraint of digits only for the version parameter.

Example:

System Configuration

The following configuration is provided in config/module.config.php to enable the module to function:

ZF2 Events

zf-versioning provides no new events, but does provide 4 distinct listeners:

ZF\Versioning\PrototypeRouteListener

This listener is attached to ModuleEvent::EVENT_MERGE_CONFIG. It is responsible for iterating the routes provided in the zf-versioning.uri configuration to look for corresponding routes in the router.routes configuration. When a match is detected, this listener will apply the versioning route match configuration to the route configuration.

ZF\Versioning\VersionListener

This listener is attached to the MvcEvent::EVENT_ROUTE at a priority of -41. This listener is responsible for updating controller service names that utilize a versioned namespace naming scheme. For example, if the currently matched route provides a controller name such as Foo\V1\Bar, and the currently selected version through URL or media type is 4, then the controller service name will be updated in the route matches to Foo\V4\Bar;

ZF\Versioning\AcceptListener

This listener is attached to the MvcEvent::EVENT_ROUTE at a priority of -40. This listener is responsible for parsing out information from the provided regular expressions (see the content-type configuration key for details) from any Accept header that is present in the request, and assigning that information to the route match, with the regex parameter names as keys.

ZF\Versioning\ContentTypeListener

This listener is attached to the MvcEvent::EVENT_ROUTE at a priority of -40. This listener is responsible for parsing out information from the provided regular expressions (see the content-type configuration key for details) from any Content-Type header that is present in the request, and assigning that information to the route match, with the regex parameter names as keys.

ZF2 Services

zf-versioning provides no unique services other than those that serve the purpose of event listeners, namely:


All versions of zf-versioning with dependencies

PHP Build Version
Package Version
Requires php Version ^5.6 || ^7.0
zendframework/zend-eventmanager Version ^2.6.3 || ^3.0.1
zendframework/zend-http Version ^2.5.4
zendframework/zend-modulemanager Version ^2.7.2
zendframework/zend-mvc Version ^2.7.15 || ^3.0.2
zendframework/zend-servicemanager Version ^2.7.6 || ^3.1
zendframework/zend-stdlib Version ^2.7.7 || ^3.0.1
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package zfcampus/zf-versioning contains the following files

Loading the files please wait ....