Áú»¢¶Ä²©

This is the documentation page for an unsupported version of Áú»¢¶Ä²©.
Is this not what you were looking for? Switch to the current version or choose one from the drop-down menu.

6 Types de m¨¦dia

Aper?u

Les types de m¨¦dia sont ±ð³æ±è´Ç°ù³Ù¨¦²õ avec tous les objets et relations d'objet associ¨¦s.

Exportation

Pour exporter des types de m¨¦dias, proc¨¦der comme suit?:

  1. Aller dans : Alertes ¡ú Types de m¨¦dias
  2. Cocher les cases des types de m¨¦dias ¨¤ exporter
  3. Cliquer sur le bouton Exporter sous la liste

Selon le format s¨¦lectionn¨¦, les types de m¨¦dias sont ±ð³æ±è´Ç°ù³Ù¨¦²õ vers un fichier local avec un nom par d¨¦faut?:

  • zabbix_export_mediatypes.yaml - pour une exportation YAML (option d'exportation par d¨¦faut)
  • zabbix_export_mediatypes.xml - pour une exportation XML
  • zabbix_export_mediatypes.json - pour une exportation JSON

Importation

Pour importer des types de m¨¦dias, proc¨¦der comme suit :

  1. Aller dans : Alertes ¡ú Types de m¨¦dias
  2. Cliquer sur Importer sur la droite
  3. S¨¦lectionner le fichier ¨¤ importer
  4. Cocher les options requises dans les r¨¨gles d'importation
  5. Cliquer sur Importer

¸é¨¨²µ±ô±ð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.

Format d'exportation

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}

Balise d'¨¦l¨¦ment

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.
Notes de bas de page

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.