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 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('mysql') && 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('pgsql') && static::classExists('Zend_Db_Adapter_Pdo_Pgsql'); } }