mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-25 17:34:03 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			436 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			436 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
 | |
| 
 | |
| namespace Icinga\Application;
 | |
| 
 | |
| /**
 | |
|  * Platform tests for icingaweb
 | |
|  */
 | |
| class Platform
 | |
| {
 | |
|     /**
 | |
|      * Domain name
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected static $domain;
 | |
| 
 | |
|     /**
 | |
|      * Host name
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected static $hostname;
 | |
| 
 | |
|     /**
 | |
|      * Fully qualified domain name
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected static $fqdn;
 | |
| 
 | |
|     /**
 | |
|      * Return the operating system's name
 | |
|      *
 | |
|      * @return  string
 | |
|      */
 | |
|     public static function getOperatingSystemName()
 | |
|     {
 | |
|         return php_uname('s');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test of windows
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public static function isWindows()
 | |
|     {
 | |
|         return strtoupper(substr(self::getOperatingSystemName(), 0, 3)) === 'WIN';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test of linux
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public static function isLinux()
 | |
|     {
 | |
|         return strtoupper(substr(self::getOperatingSystemName(), 0, 5)) === 'LINUX';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the Linux distribution's name
 | |
|      * or 'linux' if the name could not be found out
 | |
|      * or false if the OS isn't Linux or an error occurred
 | |
|      *
 | |
|      * @param int $reliable
 | |
|      *      3: Only parse /etc/os-release (or /usr/lib/os-release).
 | |
|      *          For the paranoid ones.
 | |
|      *      2: If that (3) doesn't help, check /etc/*-release, too.
 | |
|      *          If something is unclear, return 'linux'.
 | |
|      *      1: Almost equal to mode 2. The possible return values also include:
 | |
|      *          'redhat' -- unclear whether RHEL/Fedora/...
 | |
|      *          'suse' -- unclear whether SLES/openSUSE/...
 | |
|      *      0: If even that (1) doesn't help, check /proc/version, too.
 | |
|      *          This may not work (as expected) on LXC containers!
 | |
|      *          (No reliability at all!)
 | |
|      *
 | |
|      * @return string|bool
 | |
|      */
 | |
|     public static function getLinuxDistro($reliable = 2)
 | |
|     {
 | |
|         if (! self::isLinux()) {
 | |
|             return false;
 | |
|         }
 | |
| 
 | |
|         foreach (array('/etc/os-release', '/usr/lib/os-release') as $osReleaseFile) {
 | |
|             if (false === ($osRelease = @file(
 | |
|                 $osReleaseFile,
 | |
|                 FILE_IGNORE_NEW_LINES | FILE_SKIP_EMPTY_LINES
 | |
|             ))) {
 | |
|                 continue;
 | |
|             }
 | |
| 
 | |
|             foreach ($osRelease as $osInfo) {
 | |
|                 if (false === ($res = @preg_match('/(?<!.)[ \t]*#/ms', $osInfo))) {
 | |
|                     return false;
 | |
|                 }
 | |
|                 if ($res === 1) {
 | |
|                     continue;
 | |
|                 }
 | |
| 
 | |
|                 $matches = array();
 | |
|                 if (false === ($res = @preg_match(
 | |
|                     '/(?<!.)[ \t]*ID[ \t]*=[ \t]*(\'|"|)(.*?)(?:\1)[ \t]*(?!.)/msi',
 | |
|                     $osInfo,
 | |
|                     $matches
 | |
|                 ))) {
 | |
|                     return false;
 | |
|                 }
 | |
|                 if (! ($res === 0 || $matches[2] === '' || $matches[2] === 'linux')) {
 | |
|                     return $matches[2];
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if ($reliable > 2) {
 | |
|             return 'linux';
 | |
|         }
 | |
| 
 | |
|         foreach (array(
 | |
|             'fedora' => '/etc/fedora-release',
 | |
|             'centos' => '/etc/centos-release'
 | |
|         ) as $distro => $releaseFile) {
 | |
|             if (! (false === (
 | |
|                 $release = @file_get_contents($releaseFile)
 | |
|             ) || false === strpos(strtolower($release), $distro))) {
 | |
|                 return $distro;
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if (false !== ($release = @file_get_contents('/etc/redhat-release'))) {
 | |
|             $release = strtolower($release);
 | |
|             if (false !== strpos($release, 'red hat enterprise linux')) {
 | |
|                 return 'rhel';
 | |
|             }
 | |
|             foreach (array('fedora', 'centos') as $distro) {
 | |
|                 if (false !== strpos($release, $distro)) {
 | |
|                     return $distro;
 | |
|                 }
 | |
|             }
 | |
|             return $reliable < 2 ? 'redhat' : 'linux';
 | |
|         }
 | |
| 
 | |
|         if (false !== ($release = @file_get_contents('/etc/SuSE-release'))) {
 | |
|             $release = strtolower($release);
 | |
|             foreach (array(
 | |
|                 'opensuse'  => 'opensuse',
 | |
|                 'sles'      => 'suse linux enterprise server',
 | |
|                 'sled'      => 'suse linux enterprise desktop'
 | |
|             ) as $distro => $name) {
 | |
|                 if (false !== strpos($release, $name)) {
 | |
|                     return $distro;
 | |
|                 }
 | |
|             }
 | |
|             return $reliable < 2 ? 'suse' : 'linux';
 | |
|         }
 | |
| 
 | |
|         if ($reliable < 1) {
 | |
|             if (false === ($procVersion = @file_get_contents('/proc/version'))) {
 | |
|                 return false;
 | |
|             }
 | |
|             $procVersion = strtolower($procVersion);
 | |
|             foreach (array(
 | |
|                 'redhat'    => 'red hat',
 | |
|                 'suse'      => 'suse linux',
 | |
|                 'ubuntu'    => 'ubuntu',
 | |
|                 'debian'    => 'debian'
 | |
|             ) as $distro => $name) {
 | |
|                 if (false !== strpos($procVersion, $name)) {
 | |
|                     return $distro;
 | |
|                 }
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return 'linux';
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test of CLI environment
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public static function isCli()
 | |
|     {
 | |
|         if (PHP_SAPI == 'cli') {
 | |
|             return true;
 | |
|         } elseif ((PHP_SAPI == 'cgi' || PHP_SAPI == 'cgi-fcgi')
 | |
|             && empty($_SERVER['SERVER_NAME'])) {
 | |
|             return true;
 | |
|         }
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the hostname
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public static function getHostname()
 | |
|     {
 | |
|         if (self::$hostname === null) {
 | |
|             self::discoverHostname();
 | |
|         }
 | |
|         return self::$hostname;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the domain name
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public static function getDomain()
 | |
|     {
 | |
|         if (self::$domain === null) {
 | |
|             self::discoverHostname();
 | |
|         }
 | |
|         return self::$domain;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the fully qualified domain name
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public static function getFqdn()
 | |
|     {
 | |
|         if (self::$fqdn === null) {
 | |
|             self::discoverHostname();
 | |
|         }
 | |
|         return self::$fqdn;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Initialize domain and host strings
 | |
|      */
 | |
|     protected static function discoverHostname()
 | |
|     {
 | |
|         self::$hostname = gethostname();
 | |
|         self::$fqdn = gethostbyaddr(gethostbyname(self::$hostname));
 | |
| 
 | |
|         if (substr(self::$fqdn, 0, strlen(self::$hostname)) === self::$hostname) {
 | |
|             self::$domain = substr(self::$fqdn, strlen(self::$hostname) + 1);
 | |
|         } else {
 | |
|             $parts = preg_split('~\.~', self::$hostname, 2);
 | |
|             self::$domain = array_shift($parts);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the version of PHP
 | |
|      *
 | |
|      * @return  string
 | |
|      */
 | |
|     public static function getPhpVersion()
 | |
|     {
 | |
|         return phpversion();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the username PHP is running as
 | |
|      *
 | |
|      * @return  string
 | |
|      */
 | |
|     public static function getPhpUser()
 | |
|     {
 | |
|         if (static::isWindows()) {
 | |
|             return get_current_user(); // http://php.net/manual/en/function.get-current-user.php#75059
 | |
|         }
 | |
| 
 | |
|         if (function_exists('posix_geteuid')) {
 | |
|             $userInfo = posix_getpwuid(posix_geteuid());
 | |
|             return $userInfo['name'];
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Test for php extension
 | |
|      *
 | |
|      * @param   string  $extensionName  E.g. mysql, ldap
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function extensionLoaded($extensionName)
 | |
|     {
 | |
|         return extension_loaded($extensionName);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the value for the given PHP configuration option
 | |
|      *
 | |
|      * @param   string  $option     The option name for which to return the value
 | |
|      *
 | |
|      * @return  string|false
 | |
|      */
 | |
|     public static function getPhpConfig($option)
 | |
|     {
 | |
|         return ini_get($option);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether the given class exists
 | |
|      *
 | |
|      * @param   string  $name   The name of the class to check
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function classExists($name)
 | |
|     {
 | |
|         if (@class_exists($name)) {
 | |
|             return true;
 | |
|         }
 | |
| 
 | |
|         if (strpos($name, '_') !== false) {
 | |
|             // Assume it's a Zend-Framework class
 | |
|             return (@include str_replace('_', '/', $name) . '.php') !== false;
 | |
|         }
 | |
| 
 | |
|         return false;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a LDAP server
 | |
|      *
 | |
|      * Checks whether the ldap extension is loaded
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasLdapSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('ldap');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to any of the supported database servers
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public static function hasDatabaseSupport()
 | |
|     {
 | |
|         return static::hasMssqlSupport() || static::hasMysqlSupport() || static::hasOciSupport()
 | |
|             || static::hasOracleSupport() || static::hasPostgresqlSupport();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a MSSQL database
 | |
|      *
 | |
|      * Checks whether the mssql/dblib pdo or sqlsrv extension has
 | |
|      * been loaded and Zend framework adapter for MSSQL is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasMssqlSupport()
 | |
|     {
 | |
|         if ((static::extensionLoaded('mssql') || static::extensionLoaded('pdo_dblib'))
 | |
|             && static::classExists('Zend_Db_Adapter_Pdo_Mssql')
 | |
|         ) {
 | |
|             return true;
 | |
|         }
 | |
| 
 | |
|         return static::extensionLoaded('sqlsrv') && static::classExists('Zend_Db_Adapter_Sqlsrv');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a MySQL database
 | |
|      *
 | |
|      * Checks whether the mysql pdo extension has been loaded and the Zend framework adapter for MySQL is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasMysqlSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('pdo_mysql') && static::classExists('Zend_Db_Adapter_Pdo_Mysql');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a IBM DB2 database
 | |
|      *
 | |
|      * Checks whether the ibm pdo extension has been loaded and the Zend framework adapter for IBM is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasIbmSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('pdo_ibm') && static::classExists('Zend_Db_Adapter_Pdo_Ibm');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a Oracle database using OCI8
 | |
|      *
 | |
|      * Checks whether the OCI8 extension has been loaded and the Zend framework adapter for Oracle is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasOciSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('oci8') && static::classExists('Zend_Db_Adapter_Oracle');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a Oracle database using PDO_OCI
 | |
|      *
 | |
|      * Checks whether the OCI PDO extension has been loaded and the Zend framework adapter for Oci is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasOracleSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('pdo_oci') && static::classExists('Zend_Db_Adapter_Pdo_Mysql');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a PostgreSQL database
 | |
|      *
 | |
|      * Checks whether the pgsql pdo extension has been loaded and the Zend framework adapter for PostgreSQL is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasPostgresqlSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('pdo_pgsql') && static::classExists('Zend_Db_Adapter_Pdo_Pgsql');
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return whether it's possible to connect to a SQLite database
 | |
|      *
 | |
|      * Checks whether the sqlite pdo extension has been loaded and the Zend framework adapter for SQLite is available
 | |
|      *
 | |
|      * @return  bool
 | |
|      */
 | |
|     public static function hasSqliteSupport()
 | |
|     {
 | |
|         return static::extensionLoaded('pdo_sqlite') && static::classExists('Zend_Db_Adapter_Pdo_Sqlite');
 | |
|     }
 | |
| }
 |