Basically modules in HumHub are identical to Yii2 modules http://www.yiiframework.com/doc-2.0/guide-structure-modules.html.
You can use either the Yii's module base class [[yii\base\Module]] or the enhanced HumHub module base class [[humhub\components\Module]].
The enhanced HumHub module class provides additional features like:
- Dynamic module management (enable / disable / install / uninstall) via administration interface
- Usable as Space or User Profile module
cd /path/to/your/humhub/protected/humhub/modules
git clone https://github.com/humhub/humhub-modules-devtools.git devtools
On the web go to Administration->Modules and you will see the devtools module. Enable it :)
You can use the HumHub module generator to quickly create a basic module for you to build on top of.
The module generator extends Gii, a code generation tool for the Yii framework. As such, you must enable Gii and configure it to use HumHub's generators.
Add the following to your web configuration (/protected/config/web.php) to enable the generator on the Gii web UI.
return [
// ...
'modules' => [
// ...
'gii' => [
'class' => 'humhub\modules\devtools\gii\Module',
'allowedIPs' => ['127.0.0.1', '::1'],
],
// ...
]
];
Info: In order to use Yii default generators alongside HumHub Generators, add the following configuration instead.
return [
// ...
'modules' => [
// ...
'gii' => [
'class' => 'yii\gii\Module',
'allowedIPs' => ['127.0.0.1', '::1'],
'generators' => [
'module' => [
'class' => 'humhub\modules\devtools\gii\generators\ModuleGenerator',
]
],
],
// ...
]
];
You can then access Gii through the following URL:
http://localhost/path/to/index.php?r=gii
Or if you have enabled pretty URLs, you may use the following URL:
http://localhost/path/to/index.php/gii
You can then click the "Start" button for the HumHub Module Generator.
Add the following to your console configuration (/protected/config/console.php) to enable the generator in your console.
return [
// ...
'bootstrap' => ['gii'],
'modules' => [
'gii' => [
'class' => 'yii\gii\Module',
'allowedIPs' => ['127.0.0.1', '::1'],
'generators' => [
'module' => [
'class' => 'humhub\modules\devtools\Generator',
'templates' => [
'humhub' => '@app/modules/devtools/default',
]
]
],
],
],
// ...
];
You can run the HumHub Module Generator via the command line as follows:
cd protected
php yii gii/module --moduleClass="app\modules\example\Module" --moduleID=example --template="humhub"
If the module is placed inside the /protected/modules folder, you can create a config.php in the module directory which provides automatic loading without manually modifing the application config.
The config.php should return an array including following fields:
- id - Unqiue ID of the module (required)
- class - Namespaced classname of the module (required)
- events - Array of Events (optional)
- namespace - Namespace of your module
- urlManagerRules - Array of URL Manager Rules http://www.yiiframework.com/doc-2.0/yii-web-urlmanager.html#addRules()-detail
- modules - Submodules (optional)
Example of a config.php file:
<?php
use johndoe\example\Module;
use humhub\widgets\TopMenu;
return [
'id' => 'example',
'class' => 'johndoe\example\Module',
'namespace' => 'johndoe\example',
'events' => [
array('class' => TopMenu::className(), 'event' => TopMenu::EVENT_INIT, 'callback' => array('johndoe\example\Module', 'onTopMenuInit')),
]
];
?>
Note: Do not execute any code in the config.php - the result will be cached!
This file holds basic information about the module like name, description or current version. Locate this file in the root directory of the module.
{
"id": "example",
"name": "My Example Module",
"description": "My testing module.",
"keywords": ["my", "cool", "module"],
"version": "1.0",
"humhub": {
"minVersion": "0.20"
}
}