sheershoff / yii2-module-urlrules
Extension to support module url rules for Yii2.
Installs: 1 914
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 2
Forks: 1
Open Issues: 1
Type:yii2-extension
pkg:composer/sheershoff/yii2-module-urlrules
Requires
- php: >=5.3.0
- yiisoft/yii2: ~2.0.0
Requires (Dev)
- phpunit/phpunit: 4.*
This package is auto-updated.
Last update: 2025-09-29 01:43:39 UTC
README
This extension allows declaring url rules for a module inside a module, making it easy to manage module url rules, e.g. for API modules.
This module is distributed under the MIT License (MIT).
Requirements
Yii >=2.0.0
Installation
The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist sheershoff/yii2-module-urlrules
or add
"sheershoff/yii2-module-urlrules": "~1.0.0"
to the require section of your composer.json.
Configuration
To use this extension, you have to configure the components section in your application configuration and add getUrlRules or urlRules to your modules.
In your main.php for the desired app add the moduleUrlRules component:
'components' => [ // ... 'moduleUrlRules' => [ 'class' => '\sheershoff\ModuleUrlRules\ModuleUrlRules', // allowed modules lists the modules that affect the url rules 'allowedModules' => ['v1'], ], // ...
Check that modules are declared and see the urlManager settings for your API app or at least enable the
enablePrettyUrl option. E.g.:
return [ 'modules' => [ 'v1' => [ 'basePath' => '@api/modules/v1', 'class' => 'api\modules\v1\Module' ] ], 'components' => [ // ... // this config is suitable for an API app 'urlManager' => [ 'enablePrettyUrl' => true, 'enableStrictParsing' => true, 'showScriptName' => false, 'rules' => [], ], ], ];
In your Module.php for the module add the getUrlRules like the following:
<?php namespace api\modules\v1; class Module extends \yii\base\Module { public $controllerNamespace = 'api\modules\v1\controllers'; public function getUrlRules() { return [ [ 'class' => 'yii\rest\UrlRule', 'controller' => [self::getUniqueId().'/city'], ], ]; } }
Enjoy :-)
TODO
- Make tests with different php and yii versions.
- See if bootstrapping process can be optimized in a way that it doesn't bind in apps that do not have
moduleUrlRulescomponent. - Check if the aliases map works to move the module to another slug or implement one in the extension.