Les types de m¨¦dia sont ±ð³æ±è´Ç°ù³Ù¨¦²õ avec tous les objets et relations d'objet associ¨¦s.
Pour exporter des types de m¨¦dias, proc¨¦der comme suit?:
Selon le format s¨¦lectionn¨¦, les types de m¨¦dias sont ±ð³æ±è´Ç°ù³Ù¨¦²õ vers un fichier local avec un nom par d¨¦faut?:
Pour importer des types de m¨¦dias, proc¨¦der comme suit :
¸é¨¨²µ±ô±ðs d'importation :
¸é¨¨²µ±ô±ð | Description |
---|---|
Mettre ¨¤ jour l'existant | Les ¨¦l¨¦ments existants seront mis ¨¤ jour avec les donn¨¦es extraites du fichier d'importation. Sinon, ils ne seront pas mis ¨¤ jour. |
Cr¨¦er un nouveau | L'importation ajoutera de nouveaux ¨¦l¨¦ments ¨¤ l'aide des donn¨¦es du fichier d'importation. Sinon, il ne les ajoutera pas. |
Un message de r¨¦ussite ou d'¨¦chec de l'importation sera affich¨¦ dans l'interface.
Exportation YAML :
zabbix_export:
version: '6.4'
media_types:
-
name: Pushover
type: WEBHOOK
parameters:
-name: endpoint
value: 'https://api.pushover.net/1/messages.json'
-name: eventid
value: '{EVENT.ID}'
-name: event_nseverity
value: '{EVENT.NSEVERITY}'
-name: event_source
value: '{EVENT.SOURCE}'
-name: event_value
value: '{EVENT.VALUE}'
-name: expire
value: '1200'
-name: message
value: '{ALERT.MESSAGE}'
-name: priority_average
value: '0'
-name: priority_default
value: '0'
-name: priority_disaster
value: '0'
-name: priority_high
value: '0'
-name: priority_information
value: '0'
-name: priority_not_classified
value: '0'
-name: priority_warning
value: '0'
-name: retry
value: '60'
-name: title
value: '{ALERT.SUBJECT}'
-name: token
value: '<PUSHOVER TOKEN HERE>'
-name: triggerid
value: '{TRIGGER.ID}'
-name: url
value: '{$ZABBIX.URL}'
-name: url_title
value: Áú»¢¶Ä²©
-name: user
value: '{ALERT.SENDTO}'
max_sessions: '0'
script: |
try {
var params = JSON.parse(value),
request = new HttpRequest(),
data,
response,
severities = [
{name: 'not_classified', color: '#97AAB3'},
{name: 'information', color: '#7499FF'},
{name: 'warning', color: '#FFC859'},
{name: 'average', color: '#FFA059'},
{name: 'high', color: '#E97659'},
{name: 'disaster', color: '#E45959'},
{name: 'resolved', color: '#009900'},
{name: 'default', color: '#000000'}
],
priority;
if (typeof params.HTTPProxy === 'string' && params.HTTPProxy.trim() !== '') {
request.setProxy(params.HTTPProxy);
}
if ([0, 1, 2, 3].indexOf(parseInt(params.event_source)) === -1) {
throw 'Incorrect "event_source" parameter given: "' + params.event_source + '".\nMust be 0-3.';
}
if (params.event_value !== '0' && params.event_value !== '1'
&& (params.event_source === '0' || params.event_source === '3')) {
throw 'Incorrect "event_value" parameter given: ' + params.event_value + '\nMust be 0 or 1.';
}
if ([0, 1, 2, 3, 4, 5].indexOf(parseInt(params.event_nseverity)) === -1) {
params.event_nseverity = '7';
}
if (params.event_value === '0') {
params.event_nseverity = '6';
}
priority = params['priority_' + severities[params.event_nseverity].name] || params.priority_default;
if (isNaN(priority) || priority < -2 || priority > 2) {
throw '"priority" should be -2..2';
}
if (params.event_source === '0' && isNaN(params.triggerid)) {
throw 'field "triggerid" is not a number';
}
if (isNaN(params.eventid)) {
throw 'field "eventid" is not a number';
}
if (typeof params.message !== 'string' || params.message.trim() === '') {
throw 'field "message" cannot be empty';
}
data = {
token: params.token,
user: params.user,
title: params.title,
message: params.message,
url: (params.event_source === '0')
? params.url + '/tr_events.php?triggerid=' + params.triggerid + '&eventid=' + params.eventid
: params.url,
url_title: params.url_title,
priority: priority
};
if (priority == 2) {
if (isNaN(params.retry) || params.retry < 30) {
throw 'field "retry" should be a number with value of at least 30 if "priority" is set to 2';
}
if (isNaN(params.expire) || params.expire > 10800) {
throw 'field "expire" should be a number with value of at most 10800 if "priority" is set to 2';
}
data.retry = params.retry;
data.expire = params.expire;
}
data = JSON.stringify(data);
Áú»¢¶Ä²©.log(4, '[ Pushover Webhook ] Sending request: ' + params.endpoint + '\n' + data);
request.addHeader('Content-Type: application/json');
response = request.post(params.endpoint, data);
Áú»¢¶Ä²©.log(4, '[ Pushover Webhook ] Received response with status code ' + request.getStatus() + '\n' + response);
if (response !== null) {
try {
response = JSON.parse(response);
}
catch (error) {
Áú»¢¶Ä²©.log(4, '[ Pushover Webhook ] Failed to parse response received from Pushover');
response = null;
}
}
if (request.getStatus() != 200 || response === null || typeof response !== 'object' || response.status !== 1) {
if (response !== null && typeof response === 'object' && typeof response.errors === 'object'
&& typeof response.errors[0] === 'string') {
throw response.errors[0];
}
else {
throw 'Unknown error. Check debug log for more information.';
}
}
return 'OK';
}
catch (error) {
Áú»¢¶Ä²©.log(4, '[ Pushover Webhook ] Pushover notification failed: ' + error);
throw 'Pushover notification failed: ' + error;
}
description: |
Please refer to setup guide here: https://git.zabbix.com/projects/ZBX/repos/zabbix/browse/templates/media/pushover
Set token parameter with to your Pushover application key.
When assigning Pushover media to the Áú»¢¶Ä²© user - add user key into send to field.
message_templates:
-
event_source: TRIGGERS
operation_mode: PROBLEM
subject: 'Problem: {EVENT.NAME}'
message: |
Problem started at {EVENT.TIME} on {EVENT.DATE}
Problem name: {EVENT.NAME}
Host: {HOST.NAME}
Severity: {EVENT.SEVERITY}
Operational data: {EVENT.OPDATA}
Original problem ID: {EVENT.ID}
{TRIGGER.URL}
-
event_source: TRIGGERS
operation_mode: RECOVERY
subject: 'Resolved in {EVENT.DURATION}: {EVENT.NAME}'
message: |
Problem has been resolved at {EVENT.RECOVERY.TIME} on {EVENT.RECOVERY.DATE}
Problem name: {EVENT.NAME}
Problem duration: {EVENT.DURATION}
Host: {HOST.NAME}
Severity: {EVENT.SEVERITY}
Original problem ID: {EVENT.ID}
{TRIGGER.URL}
-
event_source: TRIGGERS
operation_mode: UPDATE
subject: 'Updated problem in {EVENT.AGE}: {EVENT.NAME}'
message: |
{USER.FULLNAME} {EVENT.UPDATE.ACTION} problem at {EVENT.UPDATE.DATE} {EVENT.UPDATE.TIME}.
{EVENT.UPDATE.MESSAGE}
Current problem status is {EVENT.STATUS}, age is {EVENT.AGE}, acknowledged: {EVENT.ACK.STATUS}.
-
event_source: DISCOVERY
operation_mode: PROBLEM
subject: 'Discovery: {DISCOVERY.DEVICE.STATUS} {DISCOVERY.DEVICE.IPADDRESS}'
message: |
Discovery rule: {DISCOVERY.RULE.NAME}
Device IP: {DISCOVERY.DEVICE.IPADDRESS}
Device DNS: {DISCOVERY.DEVICE.DNS}
Device status: {DISCOVERY.DEVICE.STATUS}
Device uptime: {DISCOVERY.DEVICE.UPTIME}
Device service name: {DISCOVERY.SERVICE.NAME}
Device service port: {DISCOVERY.SERVICE.PORT}
Device service status: {DISCOVERY.SERVICE.STATUS}
Device service uptime: {DISCOVERY.SERVICE.UPTIME}
-
event_source: AUTOREGISTRATION
operation_mode: PROBLEM
subject: 'Autoregistration: {HOST.HOST}'
message: |
Host name: {HOST.HOST}
Host IP: {HOST.IP}
Agent port: {HOST.PORT}
Les valeurs des balises d'¨¦l¨¦ment sont expliqu¨¦es dans le tableau ci-dessous.
?±ô¨¦³¾±ð²Ô³Ù | Propri¨¦t¨¦ de l'¨¦l¨¦ment | Requis | Type | Intervalle1 | Description |
---|---|---|---|---|---|
media_types | - | ?±ô¨¦³¾±ð²Ô³Ù racine pour media_types. | |||
name | x | string |
Nom du type de m¨¦dia. | ||
type | x | string |
0 - EMAIL 1 - SMS 2 - SCRIPT 4 - WEBHOOK |
Transport utilis¨¦ par le type de m¨¦dia. | |
status | - | string |
0 - ENABLED (default) 1 - DISABLED |
Indique si le type de m¨¦dia est activ¨¦. | |
max_sessions | - | integer |
Valeurs possibles pour SMS : 1 - (par d¨¦faut) Valeurs possibles pour les autres types de m¨¦dia : 0-100, 0 - illimit¨¦ |
Le nombre maximum d'alertes pouvant ¨ºtre trait¨¦es en parall¨¨le. | |
attempts | - | integer |
1-10 (par d¨¦faut : 3) | Le nombre maximum de tentatives d'envoi d'une alerte. | |
attempt_interval | - | string |
0-60s (par d¨¦faut : 10s) | Intervalle entre chaque nouvelle tentative. Accepte les secondes et les unit¨¦s de temps avec suffixe. |
|
description | - | string |
Description du type de m¨¦dia. | ||
message_templates | - | ?±ô¨¦³¾±ð²Ô³Ù racine pour les mod¨¨les de message du type de m¨¦dia. | |||
event_source | x | string |
0 - TRIGGERS 1 - DISCOVERY 2 - AUTOREGISTRATION 3 - INTERNAL 4 - SERVICE |
Origine de l'¨¦v¨¦nement. | |
operation_mode | x | string |
0 - PROBLEM 1 - RECOVERY 2 - UPDATE |
Mode de fonctionnement. | |
subject | - | string |
Objet du message. | ||
message | - | string |
Corps du message. | ||
Utilis¨¦s uniquement par le type de m¨¦dia email. | |||||
smtp_server | x | string |
Serveur SMTP. | ||
smtp_port | - | integer |
Par d¨¦faut : 25 | Port du serveur SMTP auquel se connecter. | |
smtp_helo | x | string |
SMTP helo. | ||
smtp_email | x | string |
Adresse e-mail ¨¤ partir de laquelle les notifications seront envoy¨¦es. | ||
smtp_security | - | string |
0 - NONE (par d¨¦faut) 1 - STARTTLS 2 - SSL_OR_TLS |
Niveau de s¨¦curit¨¦ de la connexion SMTP ¨¤ utiliser. | |
smtp_verify_host | - | string |
0 - NO (par d¨¦faut) 1 - YES |
V¨¦rification SSL de l'h?te pour le SMTP. Facultatif si smtp_security est param¨¦trer ¨¤ STARTTLS ou SSL_OR_TLS. | |
smtp_verify_peer | - | string |
0 - NO (par d¨¦faut) 1 - YES |
V¨¦rification SSL des peers pour le SMTP. Facultatif si smtp_security est param¨¦trer ¨¤ STARTTLS ou SSL_OR_TLS. | |
smtp_authentication | - | string |
0 - NONE (par d¨¦faut) 1 - PASSWORD |
M¨¦thode d'authentification SMTP ¨¤ utiliser. | |
username | - | string |
Nom d'utilisateur. | ||
password | - | string |
Mot de passe d'authentification. | ||
content_type | - | string |
0 - TEXT 1 - HTML (par d¨¦faut) |
Format des messages. | |
Utilis¨¦ uniquement par le type de m¨¦dia SMS. | |||||
gsm_modem | x | string |
Nom de s¨¦rie du p¨¦riph¨¦rique du modem GSM. | ||
Utilis¨¦ uniquement par le type de m¨¦dia script. | |||||
script name | x | string |
Nom du script. | ||
parameters | - | ?±ô¨¦³¾±ð²Ô³Ù racine pour les param¨¨tres de script. | |||
Utilis¨¦s uniquement par le type de m¨¦dia Webhook. | |||||
script | x | string |
Script. | ||
timeout | - | string |
1-60s (par d¨¦faut : 30s) | Intervalle de d¨¦lai d'expiration de la requ¨ºte HTTP du script Javascript. | |
process_tags | - | string |
0 - NO (par d¨¦faut) 1 - YES |
Indique s'il faut traiter les balises renvoy¨¦es. | |
show_event_menu | - | string |
0 - NO (par d¨¦faut) 1 - YES |
Si {EVENT.TAGS.*} ont ¨¦t¨¦ correctement r¨¦solus dans les champs event_menu_url et event_menu_name, ce champ indique la pr¨¦sence d'une entr¨¦e dans le menu des ¨¦v¨¦nements. | |
event_menu_url | - | string |
URL de l'entr¨¦e du menu de l'¨¦v¨¦nement. Prend en charge la macro {EVENT.TAGS.*}. | ||
event_menu_name | - | string |
Nom de l'entr¨¦e du menu d'¨¦v¨¦nement. Prend en charge la macro {EVENT.TAGS.*}. | ||
parameters | - | ?±ô¨¦³¾±ð²Ô³Ù racine pour les param¨¨tres de type de m¨¦dia webhook. | |||
name | x | string |
Nom du param¨¨tre Webhook. | ||
value | - | string |
Valeur du param¨¨tre Webhook. |
1 Pour les valeurs de type cha?ne de caract¨¨res, seule la cha?ne sera export¨¦e (par exemple "EMAIL") sans la num¨¦rotation utilis¨¦e dans ce tableau. Les nombres pour les valeurs de plage (correspondant aux valeurs API) dans ce tableau sont utilis¨¦s uniquement pour l'ordre.