You are not logged in.

Announcement

 Téléchargez la dernière version stable de GLPI      -     Et vous, que pouvez vous faire pour le projet GLPI ? :  Contribuer
 Download last stable version of GLPI                      -     What can you do for GLPI ? :  Contribute

#1 2019-01-16 17:31:24

jeanbezbatti
Member
Registered: 2019-01-16
Posts: 2

Integração GLPI + Zabbix

Boa tarde, estou tentando fazer a integração para que assim que ser ativada uma trigger no zabbix, abrir um chamado no GLPI.

porém estou com alguns problemas, estou utilizando os scripts criados por Janssen Lima

ele utiliza a plug in webservice para essa integração estou esbarrando na seguinte situação:

Versoes:
Glpi 9.2.2
Webservices 1.8.0

Erro:
[root@zabbixserver ~]# php /etc/zabbix/scripts/tickets_zabbix_glpi.php eventhost="Impressora_152" event="DOWN" state="PROBLEM" hostproblemid=0 lasthostproblemid=0 servico="Toner yellow low on printer Impressora_152" triggerid="15152" eventzabbix="1418239"
+ Calling 'glpi.test' on 192.168.0.150/glpi_ho…/plugins/webservices/xmlrpc.php
+ Calling 'glpi.doLogin' on 192.168.0.150/glpi_ho…/plugins/webservices/xmlrpc.php

PHP Warning: file_get_contents(192.168.0.150/glpi_ho…/plugins/webservices/xmlrpc.php): failed to open stream: HTTP request failed! HTTP/1.0 500 Internal Server Error
in /etc/zabbix/scripts/tickets_zabbix_glpi.php on line 68
+ No response

Linha 68: $file = file_get_contents("http://$host/$url", false, $context);

O log do Webservice no GLPI:

ID    Data    Usuário    Campo    Atualizar
4507331    16-01-2019 13:20            Conexão (anonymous, 192.168.0.156, glpi.doLogin, xml-rpc)
4507330    16-01-2019 13:20            Conexão (anonymous, 192.168.0.156, glpi.test, xml-rpc)

192.168.0.150 = GLPI Server
Zabbix Server  = Zabbix Server

Script de inserção do Ticket:

<?php
// ----------------------------------------------------------------------------------------
// Autor: Janssen dos Reis Lima <janssenreislima@gmail.com>
// Script: tickets_zabbix_glpi.php
// Ultima Atualizacao: 18/02/2016
// -----------------------------------------------------------------------------------------
// Configuracoes:
// -----------------------------------------------------------------------------------------
$user =         "glpi";                       
$password =     "glpi";                       
$xmlhost =      "localhost";                   
$xmlurl =       "glpi/plugins/webservices/xmlrpc.php";   
$category =     "";                       
$watcher =     "2";                       
$watchergroup = "1";                       
$sqlhost =     "localhost";                   
$sqldb =     "glpi";                   
$sqluser =      "glpi";                                
$sqlpwd =       "glpi";                               
$path_zabbix =     "/usr/lib/zabbix/externalscripts";           
// ------------------------------------------------------------------------------------------------------------------------
$arg[] = "method=glpi.test";
$arg[] = "url=$xmlurl";
$arg[] = "host=$xmlhost";
$response = getxml($arg);
unset($arg);
$webservices_version = $response['webservices'];
$eventval=array();
if ($argv>1) {
    for ($i=1 ; $i<count($argv) ; $i++) {
        $it = explode("=",$argv[$i],2);
        $it[0] = preg_replace('/^--/','',$it[0]);
        $eventval[$it[0]] = (isset($it[1]) ? $it[1] : true);
    }
}
$eventhost=$eventval['eventhost'];
$event=$eventval['event'];
$state=$eventval['state'];
$hostproblemid=$eventval['hostproblemid'];
$lasthostproblemid=$eventval['lasthostproblemid'];
$servico=$eventval['servico'];
$eventzabbix=$eventval['eventzabbix'];
$triggerid=$eventval['triggerid'];
unset($eventval);
function getxml($arg) {
    $args=array();
    if ($arg>1) {
       for ($i=0 ; $i<count($arg) ; $i++) {
          $it = explode("=",$arg[$i],2);
          $it[0] = preg_replace('/^--/','',$it[0]);
          if (strpos($it[1],',') !== false) {
            $it[1] = explode(",", $it[1]);
          }
          $args[$it[0]] = (isset($it[1]) ? $it[1] : true);
       }
    }
    $method=$args['method'];
    $url=$args['url'];
    $host=$args['host'];
   
    if (isset($args['session'])) {
       $url.='?session='.$args['session'];
       unset($args['session']);
    }
    $header = "Content-Type: text/xml";
    echo "+ Calling '$method' on http://$host/$url\n";
   
    $request = xmlrpc_encode_request($method, $args);
    $context = stream_context_create(array('http' => array('method'  => "POST",
                                'header'  => $header,
                                'content' => $request)));
    $file = file_get_contents("http://$host/$url", false, $context);
    if (!$file) {
       die("+ No response\n");
    }
    if (in_array('Content-Encoding: deflate', $http_response_header)) {
       $lenc=strlen($file);
       echo "+ Compressed response : $lenc\n";
       $file = gzuncompress($file);
       $lend=strlen($file);
       echo "+ Uncompressed response : $lend (".round(100.0*$lenc/$lend)."%)\n";
    }
    $response = xmlrpc_decode($file);
    if (!is_array($response)) {
       echo $file;
       die ("+ Bad response\n");
    }
    if (xmlrpc_is_fault($response)) {
        echo("xmlrpc error(".$response['faultCode']."): ".$response['faultString']."\n");
    } else {
       return $response;
    }
}
if (!extension_loaded("xmlrpc")) {
   die("Extension xmlrpc not loaded\n");
}
switch ($event) {
    case "UP":
        if ($lasthostproblemid != 0) {
            $arg[] = "method=glpi.doLogin";
            $arg[] = "url=$xmlurl";
            $arg[] = "host=$xmlhost";
            $arg[] = "login_password=$password";
            $arg[] = "login_name=$user";
            $response = getxml($arg);
            $session = $response['session'];
           
            $mysql = mysql_connect($sqlhost, $sqluser, $sqlpwd) or die(mysql_error());
      mysql_select_db($sqldb) or die(mysql_error());
            $consulta_chamado = mysql_query("SELECT id FROM glpi_tickets WHERE status <> 5 AND content like '%$triggerid%'");
            $pega_id_ticket = mysql_fetch_array($consulta_chamado);
            $num_ticket = "{$pega_id_ticket['id']}";
            $content = "$state: $servico. Registro fechado automaticamente atraves do evento $eventzabbix.";
                       
            $arg[] = "method=glpi.addTicketFollowup";
            $arg[] = "url=$xmlurl";
            $arg[] = "host=$xmlhost";
            $arg[] = "session=$session";
            $arg[] = "ticket=$num_ticket";
            $arg[] = "content=$content";
            $resp = getxml($arg);
            unset($arg);
            unset($resp);
            mysql_query("UPDATE glpi_tickets SET status='5' WHERE id='$num_ticket'") or die(mysql_error());
            mysql_close($mysql);
            $arg[] = "method=glpi.doLogout";
            $arg[] = "url=$xmlurl";
            $arg[] = "host=$xmlhost";
            $arg[] = "session=$session";
            $response = getxml($arg);
            unset($arg);
            unset($response);
        }
    case "DOWN":
            switch ($state) {
                case "PROBLEM":
                    if ($lasthostproblemid != 1) {
                        $arg[] = "method=glpi.doLogin";
                        $arg[] = "url=$xmlurl";
                        $arg[] = "host=$xmlhost";
                        $arg[] = "login_password=$password";
                        $arg[] = "login_name=$user";
                        $response = getxml($arg);
                        $session = $response['session'];
                        unset($arg);
                        unset($response);
                        if (!empty($session)) {
                           
                            $title = "$state: $servico! - Evento $eventzabbix gerado automaticamente pelo Zabbix";
                            $content = "Nome do host: $eventhost. ID da trigger: $triggerid. Status da trigger: $state.";
                            if ($category != ''){
                                $arg[] = "method=glpi.listDropdownValues";
                                $arg[] = "url=$xmlurl";
                                $arg[] = "host=$xmlhost";
                                $arg[] = "session=$session";
                                $arg[] = "dropdown=itilcategories";
                                $arg[] = "name=$category";
                                $response = getxml($arg);
                                $categoryid = $response[0]['id'];
                                unset($arg);
                                $catarg = "category=$categoryid";
                            }
                            if (!empty($watcher)) {
                                $watcherarg = "observer=$watcher";
                            } elseif (!empty($watchergroup)) {
                                $arg[] = "method=glpi.listUsers";
                                $arg[] = "url=$xmlurl";
                                $arg[] = "host=$xmlhost";
                                $arg[] = "session=$session";
                                $arg[] = "group=$watchergroup";
                                $response = getxml($arg);
                                foreach($response as $user){
                                    $watcherids .= $user['id'].",";
                                }
                                $watcherids = rtrim($watcherids, ",");
                                $watcherarg = "observer=$watcherids";
                                unset($arg);
                            } else {
                                // uso futuro
                            }
                           
                           
                            $arg[] = "method=glpi.createTicket";
                            $arg[] = "url=$xmlurl";
                            $arg[] = "host=$xmlhost";
                            $arg[] = "session=$session";
                            $arg[] = "title=$title";
                            $arg[] = "content=$content";
                            $arg[] = "urgancy=5";
                            if (!empty($catarg)) $arg[] = $catarg;
                            if (!empty($watcherarg)) $arg[] = $watcherarg;
                                                        if (str_replace(".", "", $webservices_version) >= '120') {
                                                                $arg[] = "use_email_notification=1";
                                                        }
                            $response = getxml($arg);
                            unset($arg);
                            unset($response);
                                      $mysql = mysql_connect($sqlhost, $sqluser, $sqlpwd) or die(mysql_error());
                                      mysql_select_db($sqldb) or die(mysql_error());
                                      $consulta_evento = mysql_query("SELECT id FROM glpi_tickets WHERE name like '%$eventzabbix%'") or die(mysql_error());
                   
                                      $pega_id_ticket = mysql_fetch_array($consulta_evento);
                                      $num_ticket = "{$pega_id_ticket['id']}";
                                      sleep(10);
                                      $comando = "python $path_zabbix/ack_zabbix_glpi.py $eventzabbix $num_ticket";
                                      $output = shell_exec($comando);
                                      mysql_close($mysql);
                       
                            $arg[] = "method=glpi.doLogout";
                            $arg[] = "url=$xmlurl";
                            $arg[] = "host=$xmlhost";
                            $arg[] = "session=$session";
   
                            $response = getxml($arg);
                            unset($arg);
                            unset($response);
                        }
                    }
            }
}
?>

Offline

Board footer

Powered by FluxBB