mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	git-svn-id: http://www.observium.org/svn/observer/trunk@3240 61d68cd4-352d-0410-923a-c4978735b2b8
		
			
				
	
	
		
			147 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			147 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
		
			Executable File
		
	
	
	
	
| <?php
 | |
| 
 | |
| // RPM
 | |
| if (!empty($agent_data['rpm']))
 | |
| {
 | |
|   echo("\nRPM 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']]['text'] = $pkg_db['manager'] ."-".$pkg_db['name']."-".$pkg_db['arch']."-".$pkg_db['version']."-".$pkg_db['build'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['manager'] = $pkg_db['manager'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['name']    = $pkg_db['name'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['arch']    = $pkg_db['arch'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['version'] = $pkg_db['version'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['build']   = $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];
 | |
|   }
 | |
| }
 | |
| 
 | |
| // DPKG
 | |
| if (!empty($agent_data['dpkg']))
 | |
| {
 | |
|   echo("\nDEB Packages: ");
 | |
|   // Build array of existing packages
 | |
|   $manager = "deb";
 | |
| 
 | |
|   $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']]['text'] = $pkg_db['manager'] ."-".$pkg_db['name']."-".$pkg_db['arch']."-".$pkg_db['version']."-".$pkg_db['build'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['manager'] = $pkg_db['manager'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['name']    = $pkg_db['name'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['arch']    = $pkg_db['arch'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['version'] = $pkg_db['version'];
 | |
|     $pkgs_db_id[$pkg_db['pkg_id']]['build']   = $pkg_db['build'];
 | |
|   }
 | |
| 
 | |
|   foreach (explode("\n", $agent_data['dpkg']) as $package)
 | |
|   {
 | |
|     list($name, $version, $arch, $size) = explode(" ", $package);
 | |
|     $build = "";
 | |
|     $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 * 1024;
 | |
|     $pkgs[$manager][$name][$arch][$version][$build]['status']  = '1';
 | |
|     $text = $manager."-".$name."-".$arch."-".$version."-".$build;
 | |
|     $pkgs_id[] = $pkgs[$manager][$name][$arch][$version][$build];
 | |
|   }
 | |
| }
 | |
| 
 | |
| // This is run for all "packages" and is common to RPM/DEB/etc
 | |
| 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');
 | |
|       if ($build != "") { $dbuild = '-' . $build; } else { $dbuild = ''; }
 | |
|       echo("+".$name."-".$version.$dbuild."-".$arch);
 | |
|       log_event('Package installed: '.$name.' ('.$arch.') version '.$version.$dbuild, $device, 'package');
 | |
|     } 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));
 | |
|       if ($pkg_c['build'] != "") { $pkg_c_dbuild = '-'.$pkg_c['build']; } else { $pkg_c_dbuild = ''; }
 | |
|       echo("U(".$pkg_c['name']."-".$pkg_c['version'].$pkg_c_dbuild."|".$name."-".$version.$dbuild.")");
 | |
|       $pkg_update = array('version' => $version, 'build' => $build, 'status' => '1', 'size' => $size);
 | |
|       dbUpdate($pkg_update, 'packages', '`pkg_id` = ?', array($pkg_c['pkg_id']));
 | |
|       log_event('Package updated: '.$name.' ('.$arch.') from '.$pkg_c['version'].$pkg_c_dbuild .' to '.$version.$dbuild, $device, 'package');
 | |
|       unset($pkgs_db_id[$pkg_c['pkg_id']]);
 | |
|     }
 | |
|   }
 | |
|   unset($pkg_update);
 | |
| }
 | |
| 
 | |
| // Packages
 | |
| foreach ($pkgs_db_id as $id => $pkg)
 | |
| {
 | |
|   dbDelete('packages', "`pkg_id` =  ?", array($id));
 | |
|   echo("-".$pkg['text']);
 | |
|   log_event('Package removed: '.$pkg['name'].' '.$pkg['arch'].' '.$pkg['version']. ($pkg['build'] != '' ? "-".$pkg['build'] : ''), $device, 'package');
 | |
| }
 | |
| 
 | |
| echo "\n";
 | |
| 
 | |
| unset($pkg);
 | |
| unset($pkgs_db_id);
 | |
| unset($pkg_c);
 | |
| unset($pkgs);
 | |
| unset($pkgs_db);
 | |
| unset($pkgs_db_db);
 | |
| 
 | |
| ?>
 |