Skip to content

yiisoft/file-router

Yii

Yii File Router


Latest Stable Version Total Downloads Build status Code Coverage Mutation testing badge static analysis type-coverage psalm-level

The package provides a convention-based router middleware that chooses controller based on its namespace and class name.

Requirements

  • PHP 8.1 or higher.

Installation

The package could be installed with Composer:

composer require yiisoft/file-router

General usage

  1. Add \Yiisoft\FileRouter\FileRouter to the list of middlewares in your application configuration, web/params.php:

    return [
        'middlewares' => [
            // ...
            \Yiisoft\FileRouter\FileRouter::class,
            // or
            [
                'class' => FileRouter::class,
                'withNamespace()' => ['App'],
                'withBaseControllerDirectory()' => ['Controller'],
            ],
            // ...
        ]
    ];
  2. Configure the router for your needs.

By default, the following structure of the app could be used assuming App points to src directory:

src
  Controller
    User
      Profile
        IndexController.php
      BlogController.php
    UserController.php
    IndexController.php

Here's how it works:

  • GET /IndexController::index()
  • GET /userUserController::index()
  • POST /userUserController::create()
  • GET /user/blog/viewUser/BlogController::view()
  • GET /user/profileUser/Profile/IndexController::index()

Documentation

For additional information, check the following docs:

If you need help or have a question, the Yii Forum is a good place for that. You may also check out other Yii Community Resources.

License

The Yii File Router is free software. It is released under the terms of the BSD License. Please see LICENSE for more information.

Maintained by Yii Software.

Support the project

Open Collective

Follow updates

Official website Twitter Telegram Facebook Slack