manifest.json

Jebkuram modulim ir nepieciešams fails manifest.json. Failam jāatrodas moduļa galvenajā direktorijā (piemēram, zabbix/ui/modules/module_name/manifest.json).

Kā minimālā prasība manifest.json jānorāda šādi lauki:

{
    "manifest_version": 2.0,
    "id": "my_ip_address",
    "name": "My IP Address",
    "namespace": "MyIPAddress",
    "version": "1.0"
}

manifest.json atbalstītie parametri (nospiediet uz parametra nosaukuma, lai skatītu detalizētu aprakstu):

Parameter Description Required
manifest_version Moduļa manifesta versija. Yes
id Unikāls moduļa ID.
name Moduļa nosaukums, kas tiks parādīts sadaļā Administration.
namespace PHP nosaukumtelpa moduļa klasēm.
version Moduļa versija.
type Moduļa tips. Logrīkam jābūt iestatītam uz widget Yes for widgets, otherwise no
widget Logrīka konfigurācija. Tiek izmantota tikai logrīkiem.
actions Darbības, ko reģistrēt ar moduli.
assets Iekļaujamie CSS stili un JavaScript faili. No
author Moduļa autors.
config Noklusējuma vērtības pielāgotām moduļa opcijām.
description Moduļa apraksts.
url Saite uz moduļa aprakstu.

manifest_version

Moduļa manifesta versija. Pašlaik atbalstītā versija ir 2.0.

Tips: Double

Piemērs:

"manifest_version": 2.0

id

Moduļa ID. Tam jābūt unikālam. Lai izvairītos no nosaukumu konfliktiem nākotnē, moduļiem ieteicams izmantot prefiksu (autora vai uzņēmuma nosaukumu, vai jebkuru citu). Piemēram, ja modulis ir piemērs mācību stundām un moduļa nosaukums ir "My module", tad ID būs "example_my_module".

Type: String

Example:

"id": "example_my_module"

nosaukums

Moduļa nosaukums, kas tiks parādīts sadaļā Administrēšana.

Type: String

Example:

"name": "My module"

nosaukumtelpa

PHP nosaukumtelpa moduļa klasēm.

Tips: String

Piemērs:

"namespace": "ClockWidget"

versija

Moduļa versija. Versija tiks parādīta sadaļā Administrēšana.

Tips: String

Piemērs:

"version": "1.0"

type

Moduļa tips. Nepieciešams logrīkiem, un tam jābūt vienādam ar "widget".

Tips: String

Noklusējums: "module"

Piemērs:

"type": "widget"

darbības

Darbības, kas jāreģistrē modulī. Katrai darbībai ir obligāti jādefinē class objekta atslēga, pārējās darbību atslēgas ir neobligātas.

Tips: Object

Atbalstītās objekta atslēgas, ja type ir module:

  • write.your.action.name (object) - darbības nosaukums; tas jāraksta ar mazajiem burtiem [a-z], atdalot vārdus ar punktiem. Atbalsta šādas atslēgas:
    • class (string; required) - darbības klases nosaukums.
    • layout (string) - darbības izkārtojums. Atbalstītās vērtības: layout.json, layout.htmlpage (noklusējums), null.
    • view (string) - darbības skats.

Piemērs:

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

Atbalstītās objekta atslēgas, ja type ir widget:

  • widget.{id}.view (object) - faila un klases nosaukums logrīka skatam. Aizstājiet {id} ar logrīka id vērtību (piemēram, widget.example_clock.view). Atbalsta šādas atslēgas:
    • class (string; required) - darbības klases nosaukums logrīka skata režīmam, lai paplašinātu noklusēto CControllerDashboardWidgetView klasi. Klases pirmkoda failam jāatrodas direktorijā actions.
    • view (string) - logrīka skats. Tam jāatrodas direktorijā views. Ja skata fails ir widget.view.php, kas pēc noklusējuma tiek sagaidīts, šo parametru var izlaist. Ja tiek izmantots cits nosaukums, norādiet to šeit.
  • widget.{id}.edit (object) - faila nosaukums logrīka konfigurācijas skatam. Aizstājiet {id} ar logrīka id vērtību (piemēram, widget.example_clock.edit). Atbalsta šādas atslēgas:
    • class (string; required) - darbības klases nosaukums logrīka konfigurācijas skata režīmam. Klases pirmkoda failam jāatrodas direktorijā actions.
    • view (string) - logrīka konfigurācijas skats. Tam jāatrodas direktorijā views. Ja skata fails ir widget.edit.php, kas pēc noklusējuma tiek sagaidīts, šo parametru var izlaist. Ja tiek izmantots cits nosaukums, norādiet to šeit.

Piemērs:

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

assets

Iekļaujamie CSS stili un JavaScript faili.

Tips: Object

Atbalstītās objekta atslēgas:

  • css (array) - Iekļaujamie CSS faili. Failiem jāatrodas mapē assets/css.
  • js (array) - Iekļaujamie JavaScript faili. Failiem jāatrodas mapē assets/js.

Piemērs:

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

autors

Moduļa autors. Autors tiks parādīts sadaļā Administrēšana.

Type: String

Piemērs:

"author": "John Smith"

config

Noklusējuma vērtības moduļa opcijām. Objekts var saturēt jebkādas pielāgotas atslēgas. Ja norādīts, šīs vērtības moduļa reģistrācijas laikā tiks ierakstītas datubāzē. Jaunas mainīgās vērtības, kas pievienotas vēlāk, tiks ierakstītas pirmajā izsaukuma reizē. Pēc tam mainīgo vērtības var mainīt tikai tieši datubāzē.

Type: Object

Piemērs:

"config": {
    "username": "Admin",
    "password": "",
    "auth_url": "https://example.com/auth"
}

apraksts

Moduļa apraksts.

Type: String

Piemērs:

"description": "This is a clock widget."

logrīks

Logrīka konfigurācija. Tiek izmantota, ja type ir iestatīts uz widget.

Tips: Object

Atbalstītās objekta atslēgas:

  • name (string) - tiek izmantots logrīku sarakstā un kā noklusējuma galvene. Ja tukšs, tiks izmantots moduļa parametrs "name".

  • size (object) - noklusējuma logrīka izmēri. Atbalsta atslēgas:

    • width (integer) - noklusējuma logrīka platums.
    • height (integer) - noklusējuma logrīka augstums.
  • form_class (string) - klase ar logrīka lauku formu. Tai jāatrodas includes direktorijā. Ja klase ir WidgetForm.php, kas pēc noklusējuma tiek sagaidīta, šo parametru var izlaist. Ja tiek izmantots cits nosaukums, norādiet to šeit.

  • js_class (string) - JavaScript klases nosaukums logrīka skata režīmam, lai paplašinātu noklusējuma CWidget klasi. Klase tiks ielādēta kopā ar paneli. Klases avota failam jāatrodas assets/js direktorijā. Skatiet arī: assets.

  • use_time_selector (boolean) - nosaka, vai logrīkam ir nepieciešams paneļa laika atlasītājs. Atbalstītās vērtības: true, false (noklusējums).

  • refresh_rate (integer) - logrīka atsvaidzināšanas intervāls sekundēs (noklusējums: 60).

Piemērs:

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

url

Saite uz moduļa aprakstu. Logrīkiem šī saite tiks atvērta, noklikšķinot uz palīdzības ikonas logā Pievienot logrīku vai Rediģēt logrīku. Ja url nav norādīts, noklikšķinot uz palīdzības ikonas, tiks atvērta vispārīgā lapa Paneļa logrīki.

Tips: String

Piemērs:

"url": "http://example.com"