mirror of
https://github.com/cytopia/devilbox.git
synced 2025-01-12 07:52:45 +00:00
176 lines
3.8 KiB
PHP
176 lines
3.8 KiB
PHP
<?php
|
|
namespace devilbox;
|
|
|
|
/**
|
|
* @requires devilbox::Logger
|
|
*/
|
|
class Helper
|
|
{
|
|
|
|
/*********************************************************************************
|
|
*
|
|
* Statics
|
|
*
|
|
*********************************************************************************/
|
|
|
|
/**
|
|
* Environmental variables from PHP docker
|
|
* @var array
|
|
*/
|
|
private static $_env = null;
|
|
|
|
|
|
/**
|
|
* Hostname to IP addresses
|
|
* @var array
|
|
*/
|
|
private static $_ip_address = null;
|
|
|
|
|
|
/**
|
|
* Class instance
|
|
* @var object
|
|
*/
|
|
private static $_instance = null;
|
|
|
|
|
|
/**
|
|
* Generic singleton instance getter.
|
|
* Make sure to overwrite this in your class
|
|
* for a more complex initialization.
|
|
*
|
|
* @param string $hostname Hostname
|
|
* @param array $data Additional data (if required)
|
|
* @return object|null
|
|
*/
|
|
public static function getInstance()
|
|
{
|
|
if (self::$_instance === null) {
|
|
self::$_instance = new self();
|
|
}
|
|
return self::$_instance;
|
|
}
|
|
|
|
|
|
|
|
/*********************************************************************************
|
|
*
|
|
* Private constructor for singleton
|
|
*
|
|
*********************************************************************************/
|
|
|
|
/**
|
|
* DO NOT CALL ME!
|
|
* Use singleton getInstance() instead.
|
|
*/
|
|
private function __construct()
|
|
{
|
|
}
|
|
|
|
|
|
|
|
/*********************************************************************************
|
|
*
|
|
* Public Helper Functions
|
|
*
|
|
*********************************************************************************/
|
|
|
|
/**
|
|
* Get Docker environment variables from docker-compose.yml
|
|
* Only values from php docker can be retrieved here, so make
|
|
* sure they are passed to it.
|
|
*
|
|
* Values are cached in static context.
|
|
*
|
|
* @param string $variable Variable name
|
|
* @return string Variable value
|
|
*/
|
|
public function getEnv($variable)
|
|
{
|
|
if (self::$_env === null) {
|
|
|
|
$output = array();
|
|
|
|
// Translate PHP Docker environmental variables to $ENV
|
|
exec('env', $output);
|
|
|
|
foreach ($output as $var) {
|
|
$tmp = explode('=', $var);
|
|
self::$_env[$tmp[0]] = $tmp[1];
|
|
}
|
|
|
|
}
|
|
if (!isset(self::$_env[$variable])) {
|
|
loadClass('Logger')->error('Environment variable not found: \''.$variable.'\'');
|
|
return null;
|
|
}
|
|
return self::$_env[$variable];
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
* Retrieve the IP address of the container.
|
|
*
|
|
* @return string|boolean IP address or false
|
|
*/
|
|
public function getIpAddress($hostname)
|
|
{
|
|
// Request was already done before and is cached
|
|
if (isset(self::$_ip_address[$hostname])) {
|
|
return self::$_ip_address[$hostname];
|
|
}
|
|
|
|
// New request, generic check
|
|
// Note the traiing dot to prevent recursive lookups
|
|
$ip = $this->exec('ping -c 1 '.$hostname.'. 2>/dev/null | grep -Eo \'[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+\' | head -1');
|
|
//$ip = gethostbyname($hostname.'');
|
|
|
|
if (filter_var($ip, FILTER_VALIDATE_IP) === false) {
|
|
//loadClass('Logger')->error('Retrieving the IP address of host \''.$hostname.'\' failed: '.$ip);
|
|
self::$_ip_address[$hostname] = false;
|
|
} else {
|
|
self::$_ip_address[$hostname] = $ip;
|
|
}
|
|
|
|
return self::$_ip_address[$hostname];
|
|
}
|
|
|
|
|
|
/**
|
|
* Shorter version to regex select a string.
|
|
*
|
|
* @param string $regex Regex
|
|
* @param string $string String to look in to
|
|
* @return bool|string Returns false on error otherwise the string
|
|
*/
|
|
public function egrep($regex, $string)
|
|
{
|
|
$match = array();
|
|
$error = preg_match($regex, $string, $match);
|
|
|
|
if ($error === false) {
|
|
loadClass('Logger')->error('Error matching regex: \''.$regex. '\' in string: \''.$string.'\'');
|
|
return false;
|
|
}
|
|
|
|
return isset($match[0]) ? $match[0] : false;
|
|
}
|
|
|
|
|
|
/**
|
|
* Executes shell commands on the PHP-FPM Host
|
|
*
|
|
* @param string $cmd Command
|
|
* @param integer $exit_code Reference to exit code
|
|
* @return string
|
|
*/
|
|
public function exec($cmd, &$exit_code = -1)
|
|
{
|
|
$output = array();
|
|
|
|
exec($cmd, $output, $exit_code);
|
|
return implode ("\n", $output);
|
|
}
|
|
}
|