diff --git a/config.php.default b/config.php.default index 5091819b1f..7a39c92037 100755 --- a/config.php.default +++ b/config.php.default @@ -33,6 +33,9 @@ $config['auth_mechanism'] = "mysql"; # default, other options: ldap, http-auth $config['nets'][] = "172.22.0.0/16"; $config['nets'][] = "192.168.0.0/24"; +### Use the new Unix Agent (ALPHA) +$config['poller_modules']['unix-agent'] = 0; + include("includes/static-config.php"); ?> diff --git a/html/pages/device.inc.php b/html/pages/device.inc.php index 84fde78e1a..fa810897c6 100644 --- a/html/pages/device.inc.php +++ b/html/pages/device.inc.php @@ -215,6 +215,15 @@ if (device_permitted($vars['device']) || $check_device == $vars['device']) '); } + if ($config['poller_modules']['unix-agent'] && @dbFetchCell("SELECT COUNT(*) FROM `packages` WHERE device_id = '".$device['device_id']."'") > '0') + { + echo('
  • + + Packages + +
  • '); + } + if ($config['enable_inventory'] && @dbFetchCell("SELECT * FROM `entPhysical` WHERE device_id = '".$device['device_id']."'") > '0') { echo('
  • diff --git a/html/pages/device/packages.inc.php b/html/pages/device/packages.inc.php new file mode 100644 index 0000000000..cf22a35136 --- /dev/null +++ b/html/pages/device/packages.inc.php @@ -0,0 +1,27 @@ +'); + +$i=0; +foreach (dbFetchRows("SELECT * FROM `packages` WHERE `device_id` = ? ORDER BY `name`", array($device['device_id'])) as $entry) +{ + if (!is_integer($i/2)) { $row_colour = $list_colour_a; } else { $row_colour = $list_colour_b; } + echo(""); + echo(''.$entry['name'].''); + + echo("".$entry['version']."-".$entry['build'].""); + + echo("".$entry['arch'].""); + echo("".$entry['manager'].""); + echo("".format_si($entry['size']).""); + + + echo(""); + + $i++; + +} + +echo(""); + +?> diff --git a/html/pages/packages.inc.php b/html/pages/packages.inc.php new file mode 100644 index 0000000000..173c7af58b --- /dev/null +++ b/html/pages/packages.inc.php @@ -0,0 +1,63 @@ + $value) +{ + if ($value != "") + { + switch ($var) + { + case 'name': + $where .= " AND `$var` LIKE ?"; + $param[] = "%".$value."%"; + break; + } + } +} + +echo(''); + +$i=0; +foreach (dbFetchRows("SELECT * FROM `packages` WHERE 1 $where GROUP BY `name`", $param) as $entry) +{ + if (!is_integer($i/2)) { $row_colour = $list_colour_a; } else { $row_colour = $list_colour_b; } + echo(""); + echo(''); + + echo(""); + + $i++; + +} + +echo("
    '.$entry['name'].'"); + foreach (dbFetchRows("SELECT * FROM `packages` WHERE `name` = ? ORDER BY version, build", array($entry['name'])) as $entry_v) + { + $entry['blah'][$entry_v['version']][$entry_v['build']][$entry_v['device_id']] = 1; + } + + foreach ($entry['blah'] as $version => $bleu) + { + + $content = '
    '; + + foreach ($bleu as $build => $bloo) + { + $content .= '
    '.$version.'-'.$build.''; + foreach ($bloo as $device_id => $no) + { + $this_device = device_by_id_cache($device_id); + $content .= ''.$this_device['hostname'].' '; + + } + $content .= "
    "; + } + $content .= "
    "; + + echo("".overlib_link("", $version, $content, NULL).""); + } + + echo("
    "); + + echo("
    "); + +?> diff --git a/includes/defaults.inc.php b/includes/defaults.inc.php index 0338448c05..f1e56c5518 100644 --- a/includes/defaults.inc.php +++ b/includes/defaults.inc.php @@ -388,6 +388,7 @@ $config['poller_modules']['cisco-ace-loadbalancer'] = 1; $config['poller_modules']['cisco-ace-serverfarms'] = 1; $config['poller_modules']['netscaler-vsvr'] = 1; $config['poller_modules']['entity-physical'] = 1; +$config['poller_modules']['unix-agent'] = 0; ## List of discovery modules. Need to be in this array to be ## considered for execution. diff --git a/includes/polling/unix-agent.inc.php b/includes/polling/unix-agent.inc.php new file mode 100755 index 0000000000..35950c9bac --- /dev/null +++ b/includes/polling/unix-agent.inc.php @@ -0,0 +1,120 @@ +>>", $section); + $agent_data[$section] = trim($data); + } + + if(!empty($agent_data['rpm'])) + { + echo("RPM Packages "); + ## Build array of existing packages + $manager = "rpm"; + + $pkgs_db_db = dbFetchRows("SELECT * FROM `packages` WHERE `device_id` = ?", array($device['device_id'])); + foreach ($pkgs_db_db as $pkg_db) + { + $pkgs_db[$pkg_db['manager']][$pkg_db['name']][$pkg_db['arch']][$pkg_db['version']][$pkg_db['build']]['id'] = $pkg_db['pkg_id']; + $pkgs_db[$pkg_db['manager']][$pkg_db['name']][$pkg_db['arch']][$pkg_db['version']][$pkg_db['build']]['status'] = $pkg_db['status']; + $pkgs_db[$pkg_db['manager']][$pkg_db['name']][$pkg_db['arch']][$pkg_db['version']][$pkg_db['build']]['size'] = $pkg_db['size']; + $pkgs_db_id[$pkg_db['pkg_id']] = $pkg_db['manager'] ."-".$pkg_db['name']."-".$pkg_db['arch']."-".$pkg_db['version']."-".$pkg_db['build']; + } + + foreach(explode("\n", $agent_data['rpm']) as $package) + { + list($name, $version, $build, $arch, $size) = explode(" ", $package); + $pkgs[$manager][$name][$arch][$version][$build]['manager'] = $manager; + $pkgs[$manager][$name][$arch][$version][$build]['name'] = $name; + $pkgs[$manager][$name][$arch][$version][$build]['arch'] = $arch; + $pkgs[$manager][$name][$arch][$version][$build]['version'] = $version; + $pkgs[$manager][$name][$arch][$version][$build]['build'] = $build; + $pkgs[$manager][$name][$arch][$version][$build]['size'] = $size; + $pkgs[$manager][$name][$arch][$version][$build]['status'] = '1'; + $text = $manager."-".$name."-".$arch."-".$version."-".$build; + $pkgs_id[] = $pkgs[$manager][$name][$arch][$version][$build]; + } + + foreach($pkgs_id as $pkg) { + $name = $pkg['name']; + $version = $pkg['version']; + $build = $pkg['build']; + $arch = $pkg['arch']; + $size = $pkg['size']; + + #echo(str_pad($name, 20)." ".str_pad($version, 10)." ".str_pad($build, 10)." ".$arch."\n"); + #echo($name." "); + + if(is_array($pkgs_db[$pkg['manager']][$pkg['name']][$pkg['arch']][$pkg['version']][$pkg['build']])) + { + ### FIXME - packages_history table + $id = $pkgs_db[$pkg['manager']][$pkg['name']][$pkg['arch']][$pkg['version']][$pkg['build']]['id']; + if($pkgs_db[$pkg['manager']][$pkg['name']][$pkg['arch']][$pkg['version']][$pkg['build']]['status'] != '1') + { + $pkg_update['status'] = '1'; + } + if($pkgs_db[$pkg['manager']][$pkg['name']][$pkg['arch']][$pkg['version']][$pkg['build']]['size'] != $size) + { + $pkg_update['size'] = $size; + } + if(!empty($pkg_update)) + { + dbUpdate($pkg_update, 'packages', '`pkg_id` = ?', array($id)); + echo("u"); + } else { + echo("."); + } + unset($pkgs_db_id[$id]); + } else { + if(count($pkgs[$manager][$name][$arch], 1) > "10" || count($pkgs_db[$manager][$name][$arch], 1) == '0') { + dbInsert(array('device_id' => $device['device_id'], 'name' => $name, 'manager' => $manager, + 'status' => 1, 'version' => $version, 'build' => $build, 'arch' => $arch, 'size' => $size), 'packages'); + echo("+".$name."-".$version."-".$build."-".$arch); + } elseif(count($pkgs_db[$manager][$name][$arch], 1)) { + $pkg_c = dbFetchRow("SELECT * FROM `packages` WHERE `device_id` = ? AND `manager` = ? AND `name` = ? and `arch` = ? ORDER BY version DESC, build DESC", + array($device['device_id'], $manager, $name, $arch)); + echo("U(".$pkg_c['name']."-".$pkg_c['version']."-".$pkg_c['build']."|".$name."-".$version."-".$build.")"); + $pkg_update = array('version' => $version, 'build' => $build, 'status' => '1', 'size' => $size); + dbUpdate($pkg_update, 'packages', '`pkg_id` = ?', array($pkg_c['pkg_id'])); + unset($pkgs_db_id[$pkg_c['pkg_id']]); + } + } + unset($pkg_update); + } + } + + foreach($pkgs_db_id as $id => $text) + { + dbDelete('packages', "`pkg_id` = ?", array($id)); + echo("-".$text); + } + +} + +echo("\n"); + +} + +?>