PHPackages                             mezzio/mezzio-tooling - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [HTTP &amp; Networking](/categories/http)
4. /
5. mezzio/mezzio-tooling

ActiveLibrary[HTTP &amp; Networking](/categories/http)

mezzio/mezzio-tooling
=====================

Migration and development tooling for Mezzio

2.12.0(8mo ago)191.1M—5%15[8 PRs](https://github.com/mezzio/mezzio-tooling/pulls)20BSD-3-ClausePHPPHP ~8.1.0 || ~8.2.0 || ~8.3.0 || ~8.4.1CI passing

Since Dec 31Pushed 2mo ago11 watchersCompare

[ Source](https://github.com/mezzio/mezzio-tooling)[ Packagist](https://packagist.org/packages/mezzio/mezzio-tooling)[ Docs](https://mezzio.dev)[ Fund](https://funding.communitybridge.org/projects/laminas-project)[ RSS](/packages/mezzio-mezzio-tooling/feed)WikiDiscussions 2.13.x Synced 1mo ago

READMEChangelog (10)Dependencies (17)Versions (72)Used By (20)

mezzio-tooling
==============

[](#mezzio-tooling)

[![Build Status](https://github.com/mezzio/mezzio-tooling/actions/workflows/continuous-integration.yml/badge.svg)](https://github.com/mezzio/mezzio-tooling/actions/workflows/continuous-integration.yml)

> ## 🇷🇺 Русским гражданам
>
> [](#-русским-гражданам)
>
> Мы, участники Laminas, родились и живем в разных странах. У многих из нас есть друзья, родственники и коллеги как в России, так и в Украине. Некоторые из нас родились в России. Некоторые из нас живут в России. У некоторых бабушки и дедушки сражались с фашистами во Второй мировой войне. Здесь никто не поддерживает фашизм.
>
> У одного из нас есть украинская родственница, которая спаслась из дома вместе с сыном. Поезд задержался из-за бомбежки на дороге впереди. У нас есть друзья, которые прячутся в бомбоубежищах. Мы с тревогой ждем весточки от них после воздушных налетов, которые беспорядочно наносят удары и попадают по больницам, школам, детским садам и домам. Мы не берем это из каких-либо СМИ. Мы наблюдаем это напрямую.
>
> Вы доверяете нам достаточно, чтоб использовать наши программы, и мы просим вас довериться нам вновь. Мы нуждаемся в помощи. Выходите и протестуйте против этой бесполезной войны. Остановите кровопролитие. Скажите "Нет войне!"
>
> ## 🇺🇸 To Citizens of Russia
>
> [](#-to-citizens-of-russia)
>
> 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!"

*Migration and development tools for Mezzio.*

Installation
------------

[](#installation)

Install via composer:

```
$ composer require --dev mezzio/mezzio-tooling
```

Command line tooling
--------------------

[](#command-line-tooling)

This package exposes commands for [laminas-cli](https://docs.laminas.dev/laminas-cli), and may be invoked via `vendor/bin/laminas`.

- `mezzio:action:create`: Create an action class file; this is an alias for the `mezzio:handler:create` command, listed below.
- `mezzio:factory:create`: Create a factory class file for the named class. The class file is created in the same directory as the class specified.
- `mezzio:handler:create`: Create a PSR-15 request handler class file. Also generates a factory for the generated class, and, if a template renderer is registered with the application container, generates a template and modifies the class to render it into a laminas-diactoros `HtmlResponse`.
- `mezzio:middleware:create`: Create a PSR-15 middleware class file.
- `mezzio:middleware:migrate-from-interop`: Migrate interop middlewares and delegators to PSR-15 middlewares and request handlers.
- `mezzio:middleware:to-request-handler`: Migrate PSR-15 middleware to request handlers.
- `mezzio:module:create`: Create and register a middleware module with the application.
- `mezzio:module:deregister`: Deregister a middleware module from the application.
- `mezzio:module:register`: Register a middleware module with the application.
- `mezzio:routes:list`: List the application's routing table.

### Routes

[](#routes)

#### mezzio:routes:list

[](#mezziorouteslist)

This command lists the application's routing table. For each route, it prints its name, path, middleware, and any additional options, in a tabular format to the terminal. The routes are listed in no particular order, by default.

The command supports several options, listed in the table below.

Command LongCommand ShortDescription`--format``-f`Set the format of the command's output. The supported values are `table`, which is the default, and `json`. If you set the format to json, then we recommend using [jq](https://stedolan.github.io/jq/manual/) to query/filter the command's output.`--sort``-s`Sort the command's output. The supported values are `name` and `path`.`--supports-method``-m`Accepts a comma-separated list of one or more HTTP methods, and filters out routes which don't support those methods.`--has-path``-p`Accepts a comma-separated list of one or more paths, and filters out routes with paths that don't match. The paths can be a regular expression, supported by the `preg_*` functions. For example, "/,/api/ping,\*/ping".`--has-name``-n`Accepts a comma-separated list of one or more names, and filters out routes with names that don't match. The names can be fixed strings, or regular expressions supported by the `preg_*` functions. For example, "user,user.register,*.register,user*".`--has-middleware``-w`Accepts a comma-separated list of one or more middleware classes, and filters out routes that do not require those classes. The classes can be fully-qualified, unqualified, or a regular expression, supported by the preg\_\* functions. For example, "\\Mezzio\\Middleware\\LazyLoadingMiddleware,LazyLoadingMiddleware,\\Mezzio\*".##### Configuration

[](#configuration)

By default, `Mezzio\Tooling\Routes\DefaultRoutesConfigLoaderFactory` registers a `ConfigLoaderInterface` service with the application's DI container, which retrieves the application's routes from two sources:

- `config/routes.php`
- Routes registered by any loaded `ConfigProvider` class

However, this is a default/fallback implementation. If you don't store any routes in `config/routes.php` or need a custom implementation, then you need to do two things:

1. Write a custom loader implementation that implements `Mezzio\Tooling\Routes\ConfigLoaderInterface`
2. Register it with the application's DI container as an alias for `Mezzio\Tooling\Routes\ConfigLoaderInterface`

##### Usage Example

[](#usage-example)

Here is an example of what you can expect from running the command.

```
$ mezzio:routes:list

+----------+-----------+---------+ Routes ---------------------------------+
| Name     | Path      | Methods | Middleware                              |
+----------+-----------+---------+-----------------------------------------+
| api.ping | /api/ping | GET     | Mezzio\Middleware\LazyLoadingMiddleware |
| home     | /         | GET     | Mezzio\Middleware\LazyLoadingMiddleware |
+----------+-----------+---------+-----------------------------------------+
```

Here is an example of what you can expect from running the command and setting the format to `json` (formatted with [jq](https://jqlang.github.io/jq/)).

```
$ mezzio:routes:list --format=json | jq

[
  {
    "name": "api.ping",
    "path": "/api/ping",
    "methods": "GET",
    "middleware": "Mezzio\\Middleware\\LazyLoadingMiddleware"
  },
  {
    "name": "home",
    "path": "/",
    "methods": "GET",
    "middleware": "Mezzio\\Middleware\\LazyLoadingMiddleware"
  }
]
```

Note

Versions of mezzio/mezzio-tooling prior to v2.0 exposed a `vendor/bin/mezzio` binary, and the various commands exposed all lacked the `mezzio:` prefix, with the following more specific changes:

- `mezzio:middleware:migrate-from-interop` was previously `migrate:interop-middleware`
- `mezzio:middleware:to-request-handler` was previously `migrate:middleware-to-request-handler`

Configurable command option values
----------------------------------

[](#configurable-command-option-values)

If the `--modules-path` of your project is not under `src`, you can either provide the path via the `--modules-path` command-line option, or configure it within your application configuration. By adding the changed path to your application configuration, you can omit the need to use the `--modules-path` option during cli execution for the various `mezzio:module:*` commands.

```
// In config/autoload/application.global.php:
