%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/infra/fusioninventory/inc/
Upload File :
Create Path :
Current File : //home/infra/fusioninventory/inc/networkinventory.class.php

<?php

/**
 * FusionInventory
 *
 * Copyright (C) 2010-2023 by the FusionInventory Development Team.
 *
 * http://www.fusioninventory.org/
 * https://github.com/fusioninventory/fusioninventory-for-glpi
 * http://forge.fusioninventory.org/
 *
 * ------------------------------------------------------------------------
 *
 * LICENSE
 *
 * This file is part of FusionInventory project.
 *
 * FusionInventory is free software: you can redistribute it and/or modify
 * it under the terms of the GNU Affero General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * FusionInventory is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
 * GNU Affero General Public License for more details.
 *
 * You should have received a copy of the GNU Affero General Public License
 * along with FusionInventory. If not, see <http://www.gnu.org/licenses/>.
 *
 * ------------------------------------------------------------------------
 *
 * This file is used to manage network inventory task jobs.
 *
 * ------------------------------------------------------------------------
 *
 * @package   FusionInventory
 * @author    David Durieux
 * @copyright Copyright (c) 2010-2023 FusionInventory team
 * @license   AGPL License 3.0 or (at your option) any later version
 *            http://www.gnu.org/licenses/agpl-3.0-standalone.html
 * @link      http://www.fusioninventory.org/
 * @link      https://github.com/fusioninventory/fusioninventory-for-glpi
 *
 */

if (!defined('GLPI_ROOT')) {
   die("Sorry. You can't access this file directly");
}

/**
 * Manage network inventory task jobs.
 */
class PluginFusioninventoryNetworkinventory extends PluginFusioninventoryCommunication {


   /**
    * Get all devices and put in taskjobstate each task for each device for
    * each agent
    *
    * @global object $DB
    * @param integer $taskjobs_id
    * @return string
    */
   function prepareRun($taskjobs_id) {
      global $DB;

      $pfTask = new PluginFusioninventoryTask();
      $pfTaskjob = new PluginFusioninventoryTaskjob();
      $pfTaskjoblog = new PluginFusioninventoryTaskjoblog();
      $pfTaskjobstate = new PluginFusioninventoryTaskjobstate();
      $pfIPRange = new PluginFusioninventoryIPRange();
      $pfAgent = new PluginFusioninventoryAgent();
      $a_specificity = [];
      $a_specificity['DEVICE'] = [];

      $uniqid = uniqid();

      $pfTaskjob->getFromDB($taskjobs_id);
      $pfTask->getFromDB($pfTaskjob->fields['plugin_fusioninventory_tasks_id']);

      $NetworkEquipment = new NetworkEquipment();
      $NetworkPort = new NetworkPort();

      /*
       * * Different possibilities  :
       * IP RANGE
       * NetworkEquipment
       * Printer
       *
       * We will count total number of devices to query
       */
      // get all snmpauth
      $a_snmpauth = getAllDataFromTable("glpi_plugin_fusioninventory_configsecurities");

      // get items_id by type
      $a_iprange = [];
      $a_NetworkEquipment = [];
      $a_Printer = [];
      $communication = $pfTask->fields['communication'];
      $a_definition = importArrayFromDB($pfTaskjob->fields['definition']);
      foreach ($a_definition as $datas) {
         $itemtype = key($datas);
         $items_id = current($datas);

         switch ($itemtype) {

            case 'PluginFusioninventoryIPRange':
               $a_iprange[] = $items_id;
               break;

            case 'NetworkEquipment':
               $query = "SELECT `glpi_networkequipments`.`id` AS `gID`,
                         `glpi_ipaddresses`.`name` AS `gnifaddr`,
                         `plugin_fusioninventory_configsecurities_id`,
                  FROM `glpi_networkequipments`
                  LEFT JOIN `glpi_plugin_fusioninventory_networkequipments`
                       ON `networkequipments_id`=`glpi_networkequipments`.`id`
                  LEFT JOIN `glpi_networkports`
                       ON `glpi_networkports`.`items_id`=`glpi_networkequipments`.`id`
                          AND `glpi_networkports`.`itemtype`='NetworkEquipment'
                  LEFT JOIN `glpi_networknames`
                       ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                          AND `glpi_networknames`.`itemtype`='NetworkPort'
                  LEFT JOIN `glpi_ipaddresses`
                       ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                          AND `glpi_ipaddresses`.`itemtype`='NetworkName'
                  WHERE `glpi_networkequipments`.`is_deleted`='0'
                       AND `plugin_fusioninventory_configsecurities_id`!='0'
                       AND `glpi_networkequipments`.`id` = '".$items_id."'
                       AND `glpi_ipaddresses`.`name`!=''
                  LIMIT 1";
               $result=$DB->query($query);
               while ($data=$DB->fetchArray($result)) {
                  if (isset($a_snmpauth[$data['plugin_fusioninventory_configsecurities_id']])) {
                     $input = [];
                     $input['TYPE'] = 'NETWORKING';
                     $input['ID'] = $data['gID'];
                     $input['IP'] = $data['gnifaddr'];
                     $input['AUTHSNMP_ID'] = $data['plugin_fusioninventory_configsecurities_id'];
                     $a_specificity['DEVICE']['NetworkEquipment'.$data['gID']] = $input;
                     $a_NetworkEquipment[] = $items_id;
                  }
               }
               break;

            case 'Printer':
               $query = "SELECT `glpi_printers`.`id` AS `gID`,
                         `glpi_ipaddresses`.`name` AS `gnifaddr`,
                         `plugin_fusioninventory_configsecurities_id`,
                  FROM `glpi_printers`
                  LEFT JOIN `glpi_plugin_fusioninventory_printers`
                          ON `printers_id`=`glpi_printers`.`id`
                  LEFT JOIN `glpi_networkports`
                       ON `glpi_networkports`.`items_id`=`glpi_printers`.`id`
                          AND `glpi_networkports`.`itemtype`='Printer'
                  LEFT JOIN `glpi_networknames`
                       ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                          AND `glpi_networknames`.`itemtype`='NetworkPort'
                  LEFT JOIN `glpi_ipaddresses`
                       ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                          AND `glpi_ipaddresses`.`itemtype`='NetworkName'
                  WHERE `glpi_printers`.`is_deleted`=0
                        AND `plugin_fusioninventory_configsecurities_id`!='0'
                        AND `glpi_printers`.`id` = '".$items_id."'
                        AND `glpi_ipaddresses`.`name`!=''
                  LIMIT 1";
               $result=$DB->query($query);
               while ($data=$DB->fetchArray($result)) {
                  if (isset($a_snmpauth[$data['plugin_fusioninventory_configsecurities_id']])) {
                     $input = [];
                     $input['TYPE'] = 'PRINTER';
                     $input['ID'] = $data['gID'];
                     $input['IP'] = $data['gnifaddr'];
                     $input['AUTHSNMP_ID'] = $data['plugin_fusioninventory_configsecurities_id'];
                     $a_specificity['DEVICE']['Printer'.$data['gID']] = $input;
                     $a_Printer[] = $items_id;
                  }
               }
               break;

         }
      }

      // Get all devices on each iprange
      foreach ($a_iprange as $items_id) {
         $pfIPRange->getFromDB($items_id);
         // Search NetworkEquipment
         $query = "SELECT `glpi_networkequipments`.`id` AS `gID`,
                            `glpi_ipaddresses`.`name` AS `gnifaddr`,
                            `plugin_fusioninventory_configsecurities_id`,
                     FROM `glpi_networkequipments`
                     LEFT JOIN `glpi_plugin_fusioninventory_networkequipments`
                          ON `networkequipments_id`=`glpi_networkequipments`.`id`
                     LEFT JOIN `glpi_networkports`
                          ON `glpi_networkports`.`items_id`=`glpi_networkequipments`.`id`
                             AND `glpi_networkports`.`itemtype`='NetworkEquipment'
                     LEFT JOIN `glpi_networknames`
                          ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                             AND `glpi_networknames`.`itemtype`='NetworkPort'
                     LEFT JOIN `glpi_ipaddresses`
                          ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                             AND `glpi_ipaddresses`.`itemtype`='NetworkName'
                     WHERE `glpi_networkequipments`.`is_deleted`='0'
                          AND `plugin_fusioninventory_configsecurities_id`!='0'";
         if ($pfIPRange->fields['entities_id'] != '-1') {
            $entities = "(".$this->fields['entities_id'];
            foreach (getAncestorsOf("glpi_entities", $pfIPRange->fields['entities_id']) as $parent) {
               $entities .= ",$parent";
            }
            $entities .= ")";
            $query .= " AND `glpi_networkequipments`.`entities_id` IN ".
                        $entities." ";
         }
         $query .= " AND inet_aton(`glpi_ipaddresses`.`name`)
                         BETWEEN inet_aton('".$pfIPRange->fields['ip_start']."')
                         AND inet_aton('".$pfIPRange->fields['ip_end']."') ";
         $query .= " GROUP BY `glpi_networkequipments`.`id`";
         $result=$DB->query($query);
         while ($data=$DB->fetchArray($result)) {
            if (isset($a_snmpauth[$data['plugin_fusioninventory_configsecurities_id']])) {
               $input = [];
               $input['TYPE'] = 'NETWORKING';
               $input['ID'] = $data['gID'];
               $input['IP'] = $data['gnifaddr'];
               $input['AUTHSNMP_ID'] = $data['plugin_fusioninventory_configsecurities_id'];
               $a_specificity['DEVICE']['NetworkEquipment'.$data['gID']] = $input;
               $a_NetworkEquipment[] = $data['gID'];
            }
         }
         // Search Printer
         $query = "SELECT `glpi_printers`.`id` AS `gID`,
                         `glpi_ipaddresses`.`name` AS `gnifaddr`,
                         `plugin_fusioninventory_configsecurities_id`,
                  FROM `glpi_printers`
                  LEFT JOIN `glpi_plugin_fusioninventory_printers`
                          ON `printers_id`=`glpi_printers`.`id`
                  LEFT JOIN `glpi_networkports`
                       ON `glpi_networkports`.`items_id`=`glpi_printers`.`id`
                          AND `glpi_networkports`.`itemtype`='Printer'
                  LEFT JOIN `glpi_networknames`
                       ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                          AND `glpi_networknames`.`itemtype`='NetworkPort'
                  LEFT JOIN `glpi_ipaddresses`
                       ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                          AND `glpi_ipaddresses`.`itemtype`='NetworkName'
                  WHERE `glpi_printers`.`is_deleted`=0
                        AND `plugin_fusioninventory_configsecurities_id`!='0'";
         if ($pfIPRange->fields['entities_id'] != '-1') {
            $entities = "(".$this->fields['entities_id'];
            foreach (getAncestorsOf("glpi_entities", $pfIPRange->fields['entities_id']) as $parent) {
               $entities .= ",$parent";
            }
            $entities .= ")";
            $query .= "AND `glpi_printers`.`entities_id` IN ".$entities." ";
         }
         $query .= " AND inet_aton(`glpi_ipaddresses`.`name`)
                      BETWEEN inet_aton('".$pfIPRange->fields['ip_start']."')
                      AND inet_aton('".$pfIPRange->fields['ip_end']."') ";
         $query .= " GROUP BY `glpi_printers`.`id`";
         $result=$DB->query($query);
         while ($data=$DB->fetchArray($result)) {
            if (isset($a_snmpauth[$data['plugin_fusioninventory_configsecurities_id']])) {
               $input = [];
               $input['TYPE'] = 'PRINTER';
               $input['ID'] = $data['gID'];
               $input['IP'] = $data['gnifaddr'];
               $input['AUTHSNMP_ID'] = $data['plugin_fusioninventory_configsecurities_id'];
               $a_specificity['DEVICE']['Printer'.$data['gID']] = $input;
               $a_Printer[] = $data['gID'];
            }
         }
      }
      $count_device = count($a_NetworkEquipment) + count($a_Printer);

      $a_actions = importArrayFromDB($pfTaskjob->fields['action']);

      // *** For dynamic agent same subnet, it's an another management ***
      if (strstr($pfTaskjob->fields['action'], '".2"')) {
         $a_subnet = [];
         $a_agentList = [];
         $a_devicesubnet = [];
         foreach ($a_NetworkEquipment as $items_id) {
            $NetworkEquipment->getFromDB($items_id);
            $a_ip = explode(".", $NetworkEquipment->fields['ip']);
            $ip_subnet = $a_ip[0].".".$a_ip[1].".".$a_ip[2].".";
            if (!isset($a_subnet[$ip_subnet])) {
               $a_subnet[$ip_subnet] = 0;
            }
            $a_subnet[$ip_subnet]++;
            $a_devicesubnet[$ip_subnet]['NetworkEquipment'][$items_id] = 1;
         }
         foreach ($a_Printer as $items_id) {
            $a_ports = $NetworkPort->find(
                  ['itemtype' => 'Printer',
                   'items_id' => $items_id,
                   ['ip']     => ['!=', '127.0.0.1']]);
            foreach ($a_ports as $a_port) {
               $a_ip = explode(".", $a_port['ip']);
               $ip_subnet = $a_ip[0].".".$a_ip[1].".".$a_ip[2].".";
               if (!isset($a_subnet[$ip_subnet])) {
                  $a_subnet[$ip_subnet] = 0;
               }
               $a_subnet[$ip_subnet]++;
               $a_devicesubnet[$ip_subnet]['Printer'][$items_id] = 1;
            }
         }
         $a_agentsubnet = [];
         foreach ($a_subnet as $subnet=>$num) {
            $a_agentList = $this->getAgentsSubnet($num, $communication, $subnet);
            if (!isset($a_agentList)) {
               $a_agentsubnet[$subnet] = '';
            } else {
               $a_agentsubnet[$subnet] = $a_agentList;
            }
         }
         $a_input = [];
         $a_input['plugin_fusioninventory_taskjobs_id'] = $taskjobs_id;
         $a_input['state'] = 1;
         $a_input['plugin_fusioninventory_agents_id'] = 0;
         $a_input['itemtype'] = '';
         $a_input['items_id'] = 0;
         $a_input['uniqid'] = $uniqid;
         $a_input['execution_id'] = $task->fields['execution_id'];

         $taskvalid = 0;
         foreach ($a_agentsubnet as $subnet=>$a_agentList) {
            if (!isset($a_agentList)
                    OR (isset($a_agentList)
                       && is_array($a_agentList)
                       && count($a_agentList) == '0')
                    OR (isset($a_agentList)
                       && !is_array($a_agentList)
                       && $a_agentList == '')) {

               // No agent available for this subnet
               for ($i=0; $i < 2; $i++) {
                  $itemtype = 'Printer';
                  if ($i == '0') {
                     $itemtype = 'NetworkEquipment';
                  }
                  if (isset($a_devicesubnet[$subnet][$itemtype])) {
                     foreach ($a_devicesubnet[$subnet][$itemtype] as $items_id=>$num) {
                        $a_input['itemtype'] = $itemtype;
                        $a_input['items_id'] = $items_id;
                        $a_input['specificity'] = exportArrayToDB(
                                          $a_specificity['DEVICE'][$itemtype.$items_id]);
                        $Taskjobstates_id = $pfTaskjobstate->add($a_input);
                           //Add log of taskjob
                           $a_input['plugin_fusioninventory_taskjobstates_id'] = $Taskjobstates_id;
                           $a_input['state'] = 7;
                           $a_input['date'] = date("Y-m-d H:i:s");
                           $pfTaskjoblog->add($a_input);
                        $pfTaskjobstate->changeStatusFinish($Taskjobstates_id,
                                                            0,
                                                            '',
                                                            1,
                                                            "Unable to find agent to inventory ".
                                                               "this ".$itemtype);
                        $a_input['state'] = 1;
                     }
                  }
               }
            } else {
               // add taskjobstate
               $count_device_subnet = 0;
               if (isset($a_devicesubnet[$subnet]['NetworkEquipment'])) {
                  $count_device_subnet += count($a_devicesubnet[$subnet]['NetworkEquipment']);
               }
               if (isset($a_devicesubnet[$subnet]['Printer'])) {
                  $count_device_subnet += count($a_devicesubnet[$subnet]['Printer']);
               }
               $nb_devicebyagent = ceil($count_device_subnet / count($a_agentList));
               $nbagent = 0;
               $agent_id = array_pop($a_agentList);
               $a_input['state'] = 0;

               for ($i=0; $i < 2; $i++) {
                  $itemtype = 'Printer';
                  if ($i == '0') {
                     $itemtype = 'NetworkEquipment';
                  }
                  if (isset($a_devicesubnet[$subnet][$itemtype])) {
                     foreach ($a_devicesubnet[$subnet][$itemtype] as $items_id=>$num) {
                        $a_input['itemtype'] = $itemtype;
                        $a_input['items_id'] = $items_id;
                        $a_input['specificity'] = exportArrayToDB(
                                       $a_specificity['DEVICE'][$itemtype.$items_id]);
                        if ($nbagent == $nb_devicebyagent) {
                           $agent_id = array_pop($a_agentList);
                           $nbagent = 0;
                        }
                        $a_input['plugin_fusioninventory_agents_id'] = $agent_id;
                        $nbagent++;
                        $taskvalid++;
                        $Taskjobstates_id = $pfTaskjobstate->add($a_input);
                        //Add log of taskjob
                           $a_input['plugin_fusioninventory_taskjobstates_id'] = $Taskjobstates_id;
                           $a_input['state'] = 7;
                           $a_input['date'] = date("Y-m-d H:i:s");
                           $pfTaskjoblog->add($a_input);
                           unset($a_input['state']);
                           $a_input['plugin_fusioninventory_agents_id'] = 0;
                           $a_input['state'] = 0;
                        if ($communication == "push") {
                           $_SESSION['glpi_plugin_fusioninventory']['agents'][$agent_id] = 1;
                        }
                     }
                  }
               }
            }
         }
         if ($taskvalid == "0") {
            $pfTaskjob->reinitializeTaskjobs($pfTaskjob->fields['plugin_fusioninventory_tasks_id']);
         }
      } else {
         $a_agentList = [];
         // *** Only agents not dynamic ***
         if ((!strstr($pfTaskjob->fields['action'], '".1"'))
               AND (!strstr($pfTaskjob->fields['action'], '".2"'))) {

            $agent_require_model = 0;
            foreach ($a_actions as $a_action) {
               if ((!in_array('.1', $a_action))
                  AND (!in_array('.2', $a_action))) {

                  $agent_id = current($a_action);
                  if ($pfAgent->getFromDB($agent_id)) {
                     $agent_version = $pfAgent->getAgentVersion($agent_id);
                     if (strnatcmp($agent_version, '2.3.4') < 0) {
                        $agent_require_model = 1;
                     }
                     if ($communication == 'pull') {
                        $a_agentList[] = $agent_id;
                     } else {
                        if ($pfTaskjob->isAgentAlive('1', $agent_id)) {
                           $a_agentList[] = $agent_id;
                        }
                     }
                  }
               }
            }
         } else if (strstr($pfTaskjob->fields['action'], '".1"')) {
            /*
             * Case : dynamic agent
             */
            $a_agentList = $this->getAgentsSubnet($count_device, $communication);
         }
         /*
          * Manage agents
          */
         if (count($a_agentList) == 0) {
            $a_input = [];
            $a_input['plugin_fusioninventory_taskjobs_id'] = $taskjobs_id;
            $a_input['state'] = 1;
            $a_input['plugin_fusioninventory_agents_id'] = 0;
            $a_input['itemtype'] = '';
            $a_input['items_id'] = 0;
            $a_input['uniqid'] = $uniqid;
            $a_input['execution_id'] = $task->fields['execution_id'];

            $Taskjobstates_id = $pfTaskjobstate->add($a_input);
               //Add log of taskjob
               $a_input['plugin_fusioninventory_taskjobstates_id'] = $Taskjobstates_id;
               $a_input['state'] = 7;
               $a_input['date'] = date("Y-m-d H:i:s");
               $pfTaskjoblog->add($a_input);
            $pfTaskjobstate->changeStatusFinish($Taskjobstates_id,
                                                0,
                                                '',
                                                1,
                                                "Unable to find agent to run this job");
            $input_taskjob = [];
            $input_taskjob['id'] = $pfTaskjob->fields['id'];
            //$input_taskjob['status'] = 0;
            $pfTaskjob->update($input_taskjob);
         } else if ($count_device == 0) {
            $a_input = [];
            $a_input['plugin_fusioninventory_taskjobs_id'] = $taskjobs_id;
            $a_input['state'] = 1;
            $a_input['plugin_fusioninventory_agents_id'] = 0;
            $a_input['itemtype'] = '';
            $a_input['items_id'] = 0;
            $a_input['uniqid'] = $uniqid;
            $Taskjobstates_id = $pfTaskjobstate->add($a_input);
               //Add log of taskjob
               $a_input['plugin_fusioninventory_taskjobstates_id'] = $Taskjobstates_id;
               $a_input['state'] = 7;
               $a_input['date'] = date("Y-m-d H:i:s");
               $pfTaskjoblog->add($a_input);
            $pfTaskjobstate->changeStatusFinish($Taskjobstates_id,
                                                0,
                                                '',
                                                0,
                                                "No suitable devices to inventory");
            $input_taskjob = [];
            $input_taskjob['id'] = $pfTaskjob->fields['id'];
            //$input_taskjob['status'] = 1;
            $pfTaskjob->update($input_taskjob);
         } else {
            foreach ($a_agentList as $agent_id) {
               //Add jobstate and put status (waiting on server = 0)
               $a_input = [];
               $a_input['plugin_fusioninventory_taskjobs_id'] = $taskjobs_id;
               $a_input['state'] = 0;
               $a_input['plugin_fusioninventory_agents_id'] = $agent_id;
               $a_input['uniqid'] = $uniqid;
               $a_input['execution_id'] = $task->fields['execution_id'];
               $alternate = 0;
               for ($d=0; $d < ceil($count_device / count($a_agentList)); $d++) {
                  if ((count($a_NetworkEquipment) + count($a_Printer)) > 0) {
                     $getdevice = "NetworkEquipment";
                     if ($alternate == "1") {
                        $getdevice = "Printer";
                        $alternate = 0;
                     } else {
                        $getdevice = "NetworkEquipment";
                        $alternate++;
                     }
                     if (count($a_NetworkEquipment) == '0') {
                        $getdevice = "Printer";
                     } else if (count($a_Printer) == '0') {
                        $getdevice = "NetworkEquipment";
                     }
                     $a_input['itemtype'] = $getdevice;

                     switch ($getdevice) {

                        case 'NetworkEquipment':
                           $a_input['items_id'] = array_pop($a_NetworkEquipment);
                              $a_input['specificity'] = exportArrayToDB(
                                    $a_specificity['DEVICE']['NetworkEquipment'.$a_input['items_id']]);
                           break;

                        case 'Printer':
                           $a_input['items_id'] = array_pop($a_Printer);
                              $a_input['specificity'] = exportArrayToDB(
                                    $a_specificity['DEVICE']['Printer'.$a_input['items_id']]);
                           break;

                     }
                     $Taskjobstates_id = $pfTaskjobstate->add($a_input);
                     //Add log of taskjob
                        $a_input['plugin_fusioninventory_taskjobstates_id'] = $Taskjobstates_id;
                        $a_input['state'] = 7;
                        $a_input['date'] = date("Y-m-d H:i:s");
                        $pfTaskjoblog->add($a_input);
                        unset($a_input['state']);
                     if ($communication == "push") {
                        $_SESSION['glpi_plugin_fusioninventory']['agents'][$agent_id] = 1;
                     }
                  }
               }
            }
            $input_taskjob = [];
            $input_taskjob['id'] = $pfTaskjob->fields['id'];
            $input_taskjob['status'] = 1;
            $pfTaskjob->update($input_taskjob);
         }
      }
      return $uniqid;
   }


   /**
    * When agent contact server, this function send datas to agent
    *
    * @param object $jobstate PluginFusioninventoryTaskjobstate instance
    * @return SimpleXMLElement
    */
   function run($jobstate) {

      $pfAgent = new PluginFusioninventoryAgent();
      $pfTaskjobstate = new PluginFusioninventoryTaskjobstate();
      $pfTaskjoblog = new PluginFusioninventoryTaskjoblog();
      $pfConfigSecurity = new PluginFusioninventoryConfigSecurity();
      $pfToolbox = new PluginFusioninventoryToolbox();
      $pfConfig = new PluginFusioninventoryConfig();

      $current = $jobstate;
      $pfAgent->getFromDB($current->fields['plugin_fusioninventory_agents_id']);

      $ip = current(PluginFusioninventoryToolbox::getIPforDevice(
              $jobstate->fields['itemtype'],
              $jobstate->fields['items_id']));

      if ($ip == '') {
         $pfTaskjobstate->changeStatusFinish($jobstate->fields['id'],
            $jobstate->fields['items_id'],
            $jobstate->fields['itemtype'],
            1,
            "Device have no ip");
      } else {
         $sxml_option = $this->message->addChild('OPTION');
         $sxml_option->addChild('NAME', 'SNMPQUERY');
         $sxml_param = $sxml_option->addChild('PARAM');
         // Use general config when threads number is set to 0 on the agent
         if ($pfAgent->fields["threads_networkinventory"] == 0) {
            $sxml_param->addAttribute('THREADS_QUERY',
               $pfConfig->getValue('threads_networkinventory'));
         } else {
            $sxml_param->addAttribute('THREADS_QUERY',
               $pfAgent->fields["threads_networkinventory"]);
         }
         // Use general config when timeout is set to 0 on the agent
         if ($pfAgent->fields["timeout_networkinventory"] == 0) {
            $sxml_param->addAttribute('TIMEOUT',
               $pfConfig->getValue('timeout_networkinventory'));
         } else {
            $sxml_param->addAttribute('TIMEOUT',
               $pfAgent->fields["timeout_networkinventory"]);
         }
         $sxml_param->addAttribute('PID', $current->fields['id']);

         $changestate = 0;
         $taskjobstatedatas = $jobstate->fields;
         $sxml_device = $sxml_option->addChild('DEVICE');

         $a_extended = ['plugin_fusioninventory_configsecurities_id' => 0];
         if ($jobstate->fields['itemtype'] == 'Printer') {
            $sxml_device->addAttribute('TYPE', 'PRINTER');
            $pfPrinter = new PluginFusioninventoryPrinter();
            $a_extended = current($pfPrinter->find(['printers_id' => $jobstate->fields['items_id']], [], 1));
         } else if ($jobstate->fields['itemtype'] == 'NetworkEquipment') {
            $sxml_device->addAttribute('TYPE', 'NETWORKING');
            $pfNetworkEquipment = new PluginFusioninventoryNetworkEquipment();
            $a_extended = current($pfNetworkEquipment->find(['networkequipments_id' => $jobstate->fields['items_id']], [], 1));
         }
         $sxml_device->addAttribute('ID', $jobstate->fields['items_id']);

         $sxml_device->addAttribute('IP', $ip);
         $sxml_device->addAttribute('AUTHSNMP_ID', $a_extended['plugin_fusioninventory_configsecurities_id']);

         if ($changestate == '0') {
            $pfTaskjobstate->changeStatus($taskjobstatedatas['id'], 1);
            $pfTaskjoblog->addTaskjoblog($taskjobstatedatas['id'],
               '0',
               'PluginFusioninventoryAgent',
               '1',
               $pfAgent->fields["threads_networkinventory"].' threads '.
               $pfAgent->fields["timeout_networkinventory"].' timeout'
            );
            $changestate = $pfTaskjobstate->fields['id'];
         } else {
            $pfTaskjobstate->changeStatusFinish($taskjobstatedatas['id'],
               $taskjobstatedatas['items_id'],
               $taskjobstatedatas['itemtype'],
               0,
               "Merged with ".$changestate);
         }
         $snmpauthlist=$pfConfigSecurity->find();
         if (count($snmpauthlist)) {
            foreach ($snmpauthlist as $snmpauth) {
               $pfToolbox->addAuth($sxml_option, $snmpauth['id']);
            }
         }
      }
      return $this->message;
   }


   /**
    * Get agents by the subnet given
    *
    * @global object $DB
    * @param integer $nb_computers
    * @param string $communication
    * @param string $subnet
    * @param string $ipstart
    * @param string $ipend
    * @return array
    */
   function getAgentsSubnet($nb_computers, $communication, $subnet = '', $ipstart = '', $ipend = '') {
      global $DB;

      $pfTaskjob = new PluginFusioninventoryTaskjob();
      $pfAgentmodule = new PluginFusioninventoryAgentmodule();

      // Number of computers min by agent
      $nb_computerByAgentMin = 20;
      $nb_agentsMax = ceil($nb_computers / $nb_computerByAgentMin);

      $a_agentList = [];

      if ($subnet != '') {
         $subnet = " AND `glpi_ipaddresses`.`name` LIKE '".$subnet."%' ";
      } else if ($ipstart != '' AND $ipend != '') {
         $subnet = " AND ( INET_ATON(`glpi_ipaddresses`.`name`) > INET_ATON('".$ipstart."')
            AND  INET_ATON(`glpi_ipaddresses`.`name`) < INET_ATON('".$ipend."') ) ";
      }
      $a_agents = $pfAgentmodule->getAgentsCanDo('NETWORKINVENTORY');
      $a_agentsid = [];
      foreach ($a_agents as $a_agent) {
         $a_agentsid[] = $a_agent['id'];
      }
      if (count($a_agentsid) == '0') {
         return $a_agentList;
      }

      $where = " AND `glpi_plugin_fusioninventory_agents`.`ID` IN (";
      $where .= implode(', ', $a_agentsid);
      $where .= ")
         AND `glpi_ipaddresses`.`name` != '127.0.0.1' ";

      $query = "SELECT `glpi_plugin_fusioninventory_agents`.`id` as `a_id`,
         `glpi_ipaddresses`.`name` as ip, token
         FROM `glpi_plugin_fusioninventory_agents`
         LEFT JOIN `glpi_networkports`
            ON `glpi_networkports`.`items_id` = `glpi_plugin_fusioninventory_agents`.`computers_id`
         LEFT JOIN `glpi_networknames`
              ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                 AND `glpi_networknames`.`itemtype`='NetworkPort'
         LEFT JOIN `glpi_ipaddresses`
              ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                 AND `glpi_ipaddresses`.`itemtype`='NetworkName'
         LEFT JOIN `glpi_computers`
            ON `glpi_computers`.`id` = `glpi_plugin_fusioninventory_agents`.`computers_id`
         WHERE `glpi_networkports`.`itemtype`='Computer'
            ".$subnet."
            ".$where." ";
      Toolbox::logInFile('NET', $query);
      $result = $DB->query($query);
      if ($result) {
         while ($data=$DB->fetchArray($result)) {
            if ($communication == 'push') {
               if ($pfTaskjob->isAgentAlive("1", $data['a_id'])) {
                  if (!in_array($a_agentList, $data['a_id'])) {
                     $a_agentList[] = $data['a_id'];
                     if (count($a_agentList) >= $nb_agentsMax) {
                        return $a_agentList;
                     }
                  }
               }
            } else if ($communication == 'pull') {
               if (!in_array($data['a_id'], $a_agentList)) {
                  $a_agentList[] = $data['a_id'];
                  if (count($a_agentList) > $nb_agentsMax) {
                     return $a_agentList;
                  }
               }
            }
         }
      }
      return $a_agentList;
   }


   /**
    * Get the devices have an IP in the IP range
    *
    * @global object $DB
    * @param integer $ipranges_id
    * @return array
    */
   function getDevicesOfIPRange($ipranges_id) {
      global $DB;

      $devicesList = [];
      $pfIPRange = new PluginFusioninventoryIPRange();

      // get all snmpauth
      $a_snmpauth = getAllDataFromTable("glpi_plugin_fusioninventory_configsecurities");

      $pfIPRange->getFromDB($ipranges_id);
      // Search NetworkEquipment
      $query = "SELECT `glpi_networkequipments`.`id` AS `gID`,
                       `glpi_networkequipments`.`name` AS `gNAME`,
                       `glpi_ipaddresses`.`name` AS `gnifaddr`,
                       `plugin_fusioninventory_configsecurities_id`
                  FROM `glpi_networkequipments`
                  LEFT JOIN `glpi_plugin_fusioninventory_networkequipments`
                       ON `networkequipments_id`=`glpi_networkequipments`.`id`
                  LEFT JOIN `glpi_networkports`
                       ON `glpi_networkports`.`items_id`=`glpi_networkequipments`.`id`
                          AND `glpi_networkports`.`itemtype`='NetworkEquipment'
                  LEFT JOIN `glpi_networknames`
                       ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                          AND `glpi_networknames`.`itemtype`='NetworkPort'
                  LEFT JOIN `glpi_ipaddresses`
                       ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                          AND `glpi_ipaddresses`.`itemtype`='NetworkName'
                  WHERE `glpi_networkequipments`.`is_deleted`='0'
                       AND `plugin_fusioninventory_configsecurities_id`!='0'";
      if ($pfIPRange->fields['entities_id'] != '-1') {
         $entities = "(".$pfIPRange->fields['entities_id'];
         foreach (getAncestorsOf("glpi_entities", $pfIPRange->fields['entities_id']) as $parent) {
            $entities .= ",$parent";
         }
         $entities .= ")";
         $query .= " AND `glpi_networkequipments`.`entities_id` IN ".
                     $entities." ";
      }
      $query .= " AND inet_aton(`glpi_ipaddresses`.`name`)
                      BETWEEN inet_aton('".$pfIPRange->fields['ip_start']."')
                      AND inet_aton('".$pfIPRange->fields['ip_end']."') ";
      $query .= " GROUP BY `glpi_networkequipments`.`id`";
      $result=$DB->query($query);
      while ($data=$DB->fetchArray($result)) {
         if (isset($a_snmpauth[$data['plugin_fusioninventory_configsecurities_id']])) {
            $devicesList[] = [
               'NetworkEquipment' => $data['gID']
            ];
         }
      }
      // Search Printer
      $query = "SELECT `glpi_printers`.`id` AS `gID`,
                      `glpi_printers`.`name` AS `gNAME`,
                      `glpi_ipaddresses`.`name` AS `gnifaddr`,
                      `plugin_fusioninventory_configsecurities_id`
               FROM `glpi_printers`
               LEFT JOIN `glpi_plugin_fusioninventory_printers`
                       ON `printers_id`=`glpi_printers`.`id`
               LEFT JOIN `glpi_networkports`
                    ON `glpi_networkports`.`items_id`=`glpi_printers`.`id`
                       AND `glpi_networkports`.`itemtype`='Printer'
               LEFT JOIN `glpi_networknames`
                    ON `glpi_networknames`.`items_id`=`glpi_networkports`.`id`
                       AND `glpi_networknames`.`itemtype`='NetworkPort'
               LEFT JOIN `glpi_ipaddresses`
                    ON `glpi_ipaddresses`.`items_id`=`glpi_networknames`.`id`
                       AND `glpi_ipaddresses`.`itemtype`='NetworkName'
               WHERE `glpi_printers`.`is_deleted`=0
                     AND `plugin_fusioninventory_configsecurities_id`!='0'";
      if ($pfIPRange->fields['entities_id'] != '-1') {
         $entities = "(".$pfIPRange->fields['entities_id'];
         foreach (getAncestorsOf("glpi_entities", $pfIPRange->fields['entities_id']) as $parent) {
            $entities .= ",$parent";
         }
         $entities .= ")";
         $query .= "AND `glpi_printers`.`entities_id` IN ".$entities." ";
      }
      $query .= " AND inet_aton(`glpi_ipaddresses`.`name`)
                   BETWEEN inet_aton('".$pfIPRange->fields['ip_start']."')
                   AND inet_aton('".$pfIPRange->fields['ip_end']."') ";
      $query .= " GROUP BY `glpi_printers`.`id`";
      $result=$DB->query($query);
      while ($data=$DB->fetchArray($result)) {
         if (isset($a_snmpauth[$data['plugin_fusioninventory_configsecurities_id']])) {
            $devicesList[] = [
               'Printer' => $data['gID']
            ];
         }
      }
      return $devicesList;
   }
}

Zerion Mini Shell 1.0