Créer un module (tutoriel)
Il s'agit d'un tutoriel étape par étape qui montre comment créer un module frontal Zabbix simple. Vous pouvez télécharger tous les fichiers de ce module sous forme d'archive ZIP : MyAddress.zip.
Ce que vous allez construire
Au cours de ce tutoriel, vous allez d'abord créer un module frontend qui ajoute une nouvelle section de menu Mon adresse puis convertit en un module frontal plus avancé qui envoie une requête HTTP à https://api.seeip.org et affiche la réponse - l'adresse IP de votre ordinateur - sur une nouvelle page dans la section de menu Mon adresse nouvellement créée. Voici à quoi ressemblera le module terminé :

Partie I - Nouvelle section de menu
Ajouter un module vide au frontend Zabbix
-
Créez un répertoire MyAddress dans le répertoire modules de votre installation du frontend Zabbix (par exemple, zabbix/ui/modules).
-
Créez un fichier manifest.json avec les métadonnées de base du module (voir la description des paramètres pris en charge).
ui/modules/MyAddress/manifest.json
{
"manifest_version": 2.0,
"id": "my-address",
"name": "My IP Address",
"version": "1.0",
"namespace": "MyAddress",
"description": "My External IP Address."
}
- Dans le frontend Zabbix, accédez à la section Administration → Général → Modules et cliquez sur le bouton Scan directory.

- Repérez le nouveau module My IP Address dans la liste et cliquez sur l’hyperlien "Disabled" pour changer le statut du module de "Disabled" à "Enabled" (si le module n’est pas répertorié, consultez la section résolution des problèmes).

Le module est maintenant enregistré dans le frontend. Cependant, il n’est pas encore visible, car vous devez encore définir la fonctionnalité du module. Une fois que vous aurez ajouté du contenu au répertoire du module, vous verrez immédiatement les changements dans le frontend Zabbix après avoir actualisé la page.
Créer une section de menu
- Créez un fichier Module.php dans le répertoire MonAdresse.
Ce fichier implémente une nouvelle classe Module qui étend la classe CModule par défaut. La classe Module insérera une nouvelle section de menu My Address dans le menu principal.
La méthode setAction() spécifie une action à exécuter en cliquant sur la section de menu. Pour commencer, vous pouvez utiliser l'action prédéfinie userprofile.edit, qui ouvrira la page Profil utilisateur. Dans la partie III de ce didacticiel, vous apprendrez à créer une action personnalisée.
ui/modules/MonAdresse/Module.php
<?php
namespace Modules\MonAdresse ;
use Zabbix\Core\CModule,
APP,
CMenuItem ;
class Module extends CModule {
public function init(): void {
APP::Component()->get('menu.main')
-->add((new CMenuItem(_('Mon adresse')))
->setAction('userprofile.edit'));
}
}
Vous pouvez remplacer userprofile.edit'` par d'autres actions, par exemple,charts.view'(ouvre des graphiques personnalisés), ``problems.view' (ouvre Surveillance → Problèmes) ou `report .status' (ouvre le rapport Informations système).
- Actualisez l'interface Zabbix. Il y a maintenant une nouvelle section Mon adresse en bas du menu principal de Zabbix. Cliquez sur Mon adresse pour ouvrir la page Profil utilisateur.

Partie II - Changement d'emplacement de la section de menu
Dans cette partie, vous allez déplacer la section du menu Mon adresse vers la section Surveillance. En conséquence, les utilisateurs pourront accéder à deux pages de sous-menu à partir de la section de menu Surveillance → Mon adresse.
- Ouvrez et modifiez le fichier Module.php.
ui/modules/MonAdresse/Module.php
<?php
namespace Modules\MyAddress;
APP,
CMenuItem ;
class Module extends CModule {
class Module extends CModule {
APP::Component()->get('menu.main')
->findOrAdd(_('Surveillance'))
->getSous-menu()
->insertAfter(_('Discovery'),
(new CMenuItem(_('My Address')))->setAction('userprofile.edit')
);
}
}
- Actualisez l'interface Zabbix. Développez la section du menu Surveillance et observez que la section Mon adresse se trouve désormais sous la section Découverte.

Partie III - Action du module
Une action est implémentée dans deux fichiers - actions/MyAddress.php et views/my.address.php. Le fichier actions/MyAddress.php s'occupe de l'implémentation de la logique métier, tandis que le fichier views/my.address.php est responsable de la vue.
-
Créez un répertoire actions dans le répertoire MyAddress.
-
Créez un fichier MyAddress.php dans le répertoire actions.
La logique de l'action sera définie dans la classe MyAddress. Cette classe d'action implémentera quatre fonctions : init(), checkInput(), checkPermissions() et doAction(). Le frontend Zabbix appelle la fonction doAction() lorsque l'action est demandée. Cette fonction est responsable de la logique métier du module.
Les données doivent être organisées sous forme de tableau associatif. Le tableau peut être multidimensionnel et peut contenir toutes les données attendues par la vue.
ui/modules/MyAddress/actions/MyAddress.php
<?php
namespace Modules\MyAddress\Actions;
use CController,
CControllerResponseData;
class MyAddress extends CController {
public function init(): void {
$this->disableCsrfValidation();
}
protected function checkInput(): bool {
return true;
}
protected function checkPermissions(): bool {
return true;
}
protected function doAction(): void {
$data = ['my-ip' => file_get_contents("https://api.seeip.org")];
$response = new CControllerResponseData($data);
$this->setResponse($response);
}
}
-
Créez un nouveau répertoire views dans le répertoire MyAddress.
-
Créez un fichier my.address.php dans le répertoire views et définissez la vue du module.
Notez que la variable $data est disponible dans la vue sans la définir spécifiquement.
Le framework passe automatiquement le tableau associatif à la vue.
ui/modules/MyAddress/views/my.address.php
<?php
(new CHtmlPage())
->setTitle(_('The HTML Title of My Address Page'))
->addItem(new CDiv($data['my-ip']))
->show();
- L'action du module doit être enregistrée dans le fichier manifest.json. Ouvrez manifest.json et ajoutez un nouvel objet
actionsqui contient :
- la clé d'action avec le nom de l'action écrit en minuscules (a-z) et avec des mots séparés par des points (par exemple,
my.address) ; - le nom de la classe d'action (
MyAddress) comme valeur pour la cléclassde l'objetmy.address; - le nom de la vue d'action (
my.address) comme valeur pour la cléviewde l'objetmy.address.
ui/modules/MyAddress/manifest.json
{
"manifest_version": 2.0,
"id": "my-address",
"name": "My IP Address",
"version": "1.0",
"namespace": "MyAddress",
"description": "My External IP Address.",
"actions": {
"my.address": {
"class": "MyAddress",
"view": "my.address"
}
}
}
- Actualisez l'interface Zabbix. Cliquez sur Mon adresse → IP externe pour voir l'adresse IP de votre ordinateur.
