mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-18 03:48:55 +01:00
fixed detection of running inside eGroupWare, as debian package sets up a header.inc.php without domains, also allow to access header with password direct specified and not as hash (secret)
This commit is contained in:
parent
ed4a2eabd0
commit
125c300182
@ -29,12 +29,21 @@ abstract class setup_cmd extends admin_cmd
|
|||||||
*/
|
*/
|
||||||
protected function _check_header_access()
|
protected function _check_header_access()
|
||||||
{
|
{
|
||||||
if ($this->header_secret != ($secret = $this->_calc_header_secret($GLOBALS['egw_info']['server']['header_admin_user'],
|
if (!$this->header_secret && $this->header_admin_user) // no secret specified but header_admin_user/password
|
||||||
$GLOBALS['egw_info']['server']['header_admin_password'])))
|
|
||||||
{
|
{
|
||||||
//echo "header_secret='$this->header_secret' != '$secret'=_calc_header_secret({$GLOBALS['egw_info']['server']['header_admin_user']},{$GLOBALS['egw_info']['server']['header_admin_password']})\n";
|
if (!$this->uid) $this->uid = true;
|
||||||
|
$this->set_header_secret($this->header_admin_user,$this->header_admin_password);
|
||||||
|
}
|
||||||
|
$secret = $this->_calc_header_secret($GLOBALS['egw_info']['server']['header_admin_user'],
|
||||||
|
$GLOBALS['egw_info']['server']['header_admin_password']);
|
||||||
|
if ($this->uid === true) unset($this->uid);
|
||||||
|
|
||||||
|
if ($this->header_secret != $secret)
|
||||||
|
{
|
||||||
|
//echo "_check_header_access: header_secret='$this->header_secret' != '$secret'=_calc_header_secret({$GLOBALS['egw_info']['server']['header_admin_user']},{$GLOBALS['egw_info']['server']['header_admin_password']})\n";
|
||||||
throw new Exception (lang('Wrong credentials to access the header.inc.php file!'),2);
|
throw new Exception (lang('Wrong credentials to access the header.inc.php file!'),2);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -109,7 +118,8 @@ abstract class setup_cmd extends admin_cmd
|
|||||||
self::$egw_setup = $GLOBALS['egw_setup'];
|
self::$egw_setup = $GLOBALS['egw_setup'];
|
||||||
self::$egw_setup->ConfigDomain = $domain;
|
self::$egw_setup->ConfigDomain = $domain;
|
||||||
|
|
||||||
if (isset($GLOBALS['egw_info']['server']['header_admin_user']) && !isset($GLOBALS['egw_domain']))
|
if (isset($GLOBALS['egw_info']['server']['header_admin_user']) && !isset($GLOBALS['egw_domain']) &&
|
||||||
|
is_object($GLOBALS['egw']) && $GLOBALS['egw'] instanceof egw)
|
||||||
{
|
{
|
||||||
// we run inside eGW, not setup --> read egw_domain array from the header via the showheader cmd
|
// we run inside eGW, not setup --> read egw_domain array from the header via the showheader cmd
|
||||||
$cmd = new setup_cmd_showheader(null); // null = only header, no db stuff, no hashes
|
$cmd = new setup_cmd_showheader(null); // null = only header, no db stuff, no hashes
|
||||||
@ -205,7 +215,7 @@ abstract class setup_cmd extends admin_cmd
|
|||||||
* @param boolean $verbose=false echo messages as they happen, instead returning them
|
* @param boolean $verbose=false echo messages as they happen, instead returning them
|
||||||
* @return array with translated messages
|
* @return array with translated messages
|
||||||
*/
|
*/
|
||||||
function check_installed($domain='',$stop=0,$verbose=false)
|
static function check_installed($domain='',$stop=0,$verbose=false)
|
||||||
{
|
{
|
||||||
self::_setup_enviroment($domain);
|
self::_setup_enviroment($domain);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user