manifest.json

Tout module a besoin du fichier manifest.json. Le fichier doit être situé dans le répertoire principal du module (Par exemple, zabbix/ui/modules/module_name/manifest.json).

Au strict minimum, manifest.json doit spécifier ces champs :

{
           "manifest_version": 2.0,
           "id": "mon_adresse_ip",
           "name": "Mon adresse IP",
           "namespace": "MonAdresseIP",
           "version": "1.0"
       }

Paramètres pris en charge dans manifest.json (appuyez sur le nom du paramètre pour une description détaillée) :

Paramètre Description Obligatoire
manifest_version Version manifeste du module. Oui
id ID de module unique.
name Nom du module qui sera affiché dans la section Administration.
namespace Espace de noms PHP pour les classes de modules.
version Version du module.
type Type du module. Pour le widget doit être défini sur widget Oui pour les widgets, sinon non
widget Configuration des widgets. Utilisé uniquement pour les widgets.
actions Actions pour s'inscrire au module.
assets Styles CSS et fichiers JavaScript à inclure. Non
author Auteur du module.
config Valeurs par défaut pour les options de module personnalisées.
description Description du module.
url Un lien vers la description du module.

manifest_version

Version manifeste du module. Actuellement, la version prise en charge est 2.0.

Type : Double

Exemple:

"manifest_version": 2.0

identifiant

ID du module. Doit être unique. Pour éviter de futurs conflits de noms, il est recommandé d'utiliser un préfixe pour les modules (nom de l'auteur ou de l'entreprise, ou tout autre). Par exemple, si un module est un exemple de leçons et que le nom du module est « Mon module », alors l'ID sera « exemple_mon_module ».

Type : Chaîne

Exemple:

"id": "exemple_mon_module"

nom

Nom du module qui sera affiché dans la section Administration.

Type : Chaîne

Exemple:

"name": "Mon module"

namespace

Namespace PHP pour les classes de modules.

Type : Chaîne

Exemple:

"namespace": "ClockWidget"

version

Version du module. La version sera affichée dans la section Administration.

Type : Chaîne

Exemple:

"version": "1.0"

type

Type du module. Obligatoire pour les widgets et doit être égal à « widget ».

Type : Chaîne

Default : "module"

Exemple:

"type": "widget"

Actions

Actions pour s'inscrire avec le module. La définition de la clé d'objet class pour chaque action est requise, les autres clés d'action sont facultatives.

Type : Objet

Clés d'objet prises en charge si type est un module :

  • write.your.action.name (object) - le nom de l'action, doit être écrit en minuscules [a-z], en séparant les mots par des points. Prend en charge les clés :
    • class (string ; obligatoire) - nom de la classe d'action.
    • layout (string) - disposition des actions. Valeurs prises en charge : layout.json, layout.htmlpage (par défaut), null.
    • view (string) - vue des actions.

Exemple:

"Actions": {
           "module.exqmple.list": {
               "class": "ExampleList",
               "view": "example.list",
               "layout": "layout.htmlpage"
               }
           }

Clés d'objet prises en charge si type est un widget :

  • widget.{id}.view (object) - nom de fichier et de classe pour la vue widget. Remplacez {id} par la valeur id du widget (par exemple, widget.example_clock.view). Prend en charge les clés :
    • class (string ; obligatoire) - nom de la classe d'action pour le mode d'affichage du widget afin d'étendre la classe CControllerDashboardWidgetView par défaut. Le fichier source de la classe doit être situé dans le répertoire actions.
    • view (string) - vue widget. Doit être situé dans le répertoire views. Si le fichier de vue est widget.view.php, ce qui est attendu par défaut, ce paramètre peut être omis. Si vous utilisez un nom différent, spécifiez-le ici.
  • widget.{id}.edit (object) - nom de fichier pour la vue de configuration du widget. Remplacez {id} par la valeur id du widget (par exemple, widget.example_clock.edit). Prend en charge les clés :
    • class (string ; obligatoire) - nom de la classe d'action pour le mode d'affichage de la configuration du widget. Le fichier source de la classe doit être situé dans le répertoire actions.
    • view (string) - vue de configuration du widget. Doit être situé dans le répertoire views. Si le fichier de vue est widget.edit.php, ce qui est attendu par défaut, ce paramètre peut être omis. Si vous utilisez un nom différent, spécifiez-le ici.

Exemple:

"Actions": {
           "widget.tophosts.view": {
               "class": "WidgetView"
           },
           "widget.tophosts.column.edit": {
               "class": "ColumnEdit",
               "view": "column.edit",,
               "layout": "layout.json"
           }
       }

actifs

Styles CSS et fichiers JavaScript à inclure.

Type : Objet

Clés d'objet prises en charge :

  • css (array) - Fichiers CSS à inclure. Les fichiers doivent être situés dans le répertoire assets/css.
  • js (array) - Fichiers JavaScript à inclure. Les fichiers doivent être situés dans le répertoire assets/js.

Exemple :

"assets": {
           "css": ["widget.css"],
           "js": ["class.widget.js"]
       }

author

Auteur du module. L'auteur sera affiché dans la section Administration.

Type : Chaîne

Exemple:

"author": "John Smith"

configuration

Valeurs par défaut pour les options du module. L'objet peut contenir des clés personnalisées. Si spécifiées, ces valeurs seront écrites dans la base de données lors de l’inscription du module. Les nouvelles variables ajoutées ultérieurement seront écrites lors du premier appel. Ensuite, les valeurs des variables ne peuvent être modifiées que directement dans la base de données.

Type : Objet

Exemple :

"config": {
           "username": "Administrateur",
           "password": "",
           "auth_url": "https://exemple.com/auth"
       }

description

Descriptif des modules.

Type : Chaîne

Exemple:

"description": "Ceci est un widget horloge."

widget

Configuration des widgets. Utilisé si type est défini sur widget.

Type : Objet

Clés d'objet prises en charge :

  • name (string) - utilisé dans la liste des widgets et comme en-tête par défaut. S'il est vide, le paramètre "name" du module sera utilisé.

  • template_support (booléen) - détermine si le widget doit être disponible dans les modèles de tableaux de bord. Valeurs prises en charge : true, false (par défaut).

  • ** size** (objet) - dimensions du widget par défaut. Clés prises en charge :

    • width (entier) - largeur du widget par défaut.
      • height* (entier) - hauteur du widget par défaut.
  • form_class (string) - classe avec formulaire de champs de widget. Doit être situé dans le répertoire includes. Si la classe est WidgetForm.php, ce qui est attendu par défaut, ce paramètre peut être omis. Si vous utilisez un nom différent, spécifiez-le ici.

  • js_class (string) - nom d'une classe JavaScript pour le mode d'affichage des widgets afin d'étendre la classe CWidget par défaut. La classe sera chargée avec le tableau de bord. Le fichier source de la classe doit se trouver dans le répertoire assets/js. Voir aussi : assets.

  • use_time_selector (booléen) - détermine si le widget nécessite un sélecteur d'heure du tableau de bord. Valeurs prises en charge : true, false (par défaut).

  • refresh_rate (entier) - taux de rafraîchissement du widget en secondes (par défaut : 60).

Exemple:

"widget": {
           "name": "",
           "template_support": true,
           "size": {
               "width": 12,
               "height": 5
           },
           "form_class": "WidgetForm",
           "js_class": "CWidget",
           "use_time_selector": false,
           "refresh_rate": 60
       }

URL

Un lien vers la description du module.

Type : Chaîne

Exemple:

"url": "http://exemple.com"