mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-13 09:28:29 +01:00
- fixed not working accounts::cache_invalidate(): cache is now in regular egw_cache on session level
- calling static methods static: accounts::cache_invalidate() or egw::invalidate_session_cache() - fixed wrong number of deleted items in setup_cmd_ldap sub-comand=delete_ldap - only use create, if we have an ldap_admin_pw set - call an add_account hook for each created account, if specified (not by default)
This commit is contained in:
parent
3c58ef8473
commit
d6822d9564
@ -832,10 +832,11 @@ class accounts
|
|||||||
{
|
{
|
||||||
//echo "<p>accounts::cache_invalidate($account_id)</p>\n";
|
//echo "<p>accounts::cache_invalidate($account_id)</p>\n";
|
||||||
if (self::$cache) self::$cache = array();
|
if (self::$cache) self::$cache = array();
|
||||||
|
egw_cache::unsetSession('accounts_cache','phpgwapi');
|
||||||
|
|
||||||
if (method_exists($GLOBALS['egw'],'invalidate_session_cache')) // egw object in setup is limited
|
if (method_exists($GLOBALS['egw'],'invalidate_session_cache')) // egw object in setup is limited
|
||||||
{
|
{
|
||||||
$GLOBALS['egw']->invalidate_session_cache(); // invalidates whole egw-enviroment if stored in the session
|
egw::invalidate_session_cache(); // invalidates whole egw-enviroment if stored in the session
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1003,7 +1003,7 @@ class setup
|
|||||||
}
|
}
|
||||||
$this->accounts = new accounts($config);
|
$this->accounts = new accounts($config);
|
||||||
if (!isset($GLOBALS['egw']->accounts)) $GLOBALS['egw']->accounts = $this->accounts;
|
if (!isset($GLOBALS['egw']->accounts)) $GLOBALS['egw']->accounts = $this->accounts;
|
||||||
$this->accounts->cache_invalidate(); // the cache is shared for all instances of the class
|
accounts::cache_invalidate(); // the cache is shared for all instances of the class
|
||||||
|
|
||||||
if($this->accounts->backend instanceof accounts_ldap && !$this->accounts->backend->ds)
|
if($this->accounts->backend instanceof accounts_ldap && !$this->accounts->backend->ds)
|
||||||
{
|
{
|
||||||
|
@ -168,7 +168,7 @@ abstract class setup_cmd extends admin_cmd
|
|||||||
if (!is_null(self::$egw_accounts_backup))
|
if (!is_null(self::$egw_accounts_backup))
|
||||||
{
|
{
|
||||||
$GLOBALS['egw']->accounts = self::$egw_accounts_backup;
|
$GLOBALS['egw']->accounts = self::$egw_accounts_backup;
|
||||||
$GLOBALS['egw']->accounts->cache_invalidate();
|
accounts::cache_invalidate();
|
||||||
unset(self::$egw_accounts_backup);
|
unset(self::$egw_accounts_backup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -42,6 +42,7 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
* @param string $ldap_search_filter=null search-filter for accounts, default "(uid=%user)"
|
* @param string $ldap_search_filter=null search-filter for accounts, default "(uid=%user)"
|
||||||
* @param string $ldap_group_context=null ou for groups, default "ou=groups,$base"
|
* @param string $ldap_group_context=null ou for groups, default "ou=groups,$base"
|
||||||
* @param string $sub_command='create_ldap' 'create_ldap', 'test_ldap', 'test_ldap_root'
|
* @param string $sub_command='create_ldap' 'create_ldap', 'test_ldap', 'test_ldap_root'
|
||||||
|
* @param string $ldap_encryption_type='des'
|
||||||
*/
|
*/
|
||||||
function __construct($domain,$ldap_host=null,$ldap_suffix=null,$ldap_admin=null,$ldap_admin_pw=null,
|
function __construct($domain,$ldap_host=null,$ldap_suffix=null,$ldap_admin=null,$ldap_admin_pw=null,
|
||||||
$ldap_base=null,$ldap_root_dn=null,$ldap_root_pw=null,$ldap_context=null,$ldap_search_filter=null,
|
$ldap_base=null,$ldap_root_dn=null,$ldap_root_pw=null,$ldap_context=null,$ldap_search_filter=null,
|
||||||
@ -125,7 +126,7 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
{
|
{
|
||||||
$msg = array();
|
$msg = array();
|
||||||
// if migrating to ldap, check ldap and create context if not yet exiting
|
// if migrating to ldap, check ldap and create context if not yet exiting
|
||||||
if ($to_ldap)
|
if ($to_ldap && !empty($this->ldap_admin_pw))
|
||||||
{
|
{
|
||||||
$msg[] = $this->create();
|
$msg[] = $this->create();
|
||||||
}
|
}
|
||||||
@ -169,14 +170,7 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ($account['account_pwd'][0] != '{') // plain has to be explicitly specified for sql, in ldap it's the default
|
$account['account_passwd'] = self::hash_ldap2sql($account['account_pwd']);
|
||||||
{
|
|
||||||
$account['account_passwd'] = '{PLAIN}'.$account['account_pwd'];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$account['account_passwd'] = $account['account_pwd'];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
unset($account['person_id']);
|
unset($account['person_id']);
|
||||||
|
|
||||||
@ -189,6 +183,29 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
$accounts_obj->set_memberships($account['memberships'],$account_id);
|
$accounts_obj->set_memberships($account['memberships'],$account_id);
|
||||||
$msg[] = lang('%1 created in %2.',$what,$target);
|
$msg[] = lang('%1 created in %2.',$what,$target);
|
||||||
$accounts_created++;
|
$accounts_created++;
|
||||||
|
|
||||||
|
// should we run any or some addAccount hooks
|
||||||
|
if ($this->add_account_hook)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
$account['location'] = 'addAccount';
|
||||||
|
// running all addAccount hooks (currently NOT working, as not all work in setup)
|
||||||
|
if ($this->add_account_hook === true)
|
||||||
|
{
|
||||||
|
$GLOBALS['egw']->hooks->process($account,array(),true);
|
||||||
|
}
|
||||||
|
elseif(is_callable($this->add_account_hook))
|
||||||
|
{
|
||||||
|
call_user_func($this->add_account_hook,$account);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
catch(Exception $e)
|
||||||
|
{
|
||||||
|
$msg[] = $e->getMessage();
|
||||||
|
$errors++;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -207,9 +224,11 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
$msg[] = lang('%1 already exists in %2.',$what,$target);
|
$msg[] = lang('%1 already exists in %2.',$what,$target);
|
||||||
|
$errors++;
|
||||||
|
|
||||||
if ($accounts_obj->id2name($account_id) != $account['account_lid'])
|
if ($accounts_obj->id2name($account_id) != $account['account_lid'])
|
||||||
{
|
{
|
||||||
|
$msg[] = lang("==> different group '%1' under that gidNumber %2, NOT setting memberships!",$account['account_lid'],$account_id);
|
||||||
++$errors;
|
++$errors;
|
||||||
continue; // different group under that gidnumber!
|
continue; // different group under that gidnumber!
|
||||||
}
|
}
|
||||||
@ -218,6 +237,8 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
$accounts_obj->set_members($account['members'],$account_id);
|
$accounts_obj->set_members($account['members'],$account_id);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
$this->restore_db();
|
||||||
|
|
||||||
return lang('%1 users and %2 groups created, %3 errors',$accounts_created,$groups_created,$errors).
|
return lang('%1 users and %2 groups created, %3 errors',$accounts_created,$groups_created,$errors).
|
||||||
($errors || $this->verbose ? "\n- ".implode("\n- ",$msg) : '');
|
($errors || $this->verbose ? "\n- ".implode("\n- ",$msg) : '');
|
||||||
}
|
}
|
||||||
@ -253,6 +274,21 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
return $hash;
|
return $hash;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert LDAP hash to SQL hash
|
||||||
|
*
|
||||||
|
* @param string $hash
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function hash_ldap2sql($hash)
|
||||||
|
{
|
||||||
|
if ($hash[0] != '{') // plain has to be explicitly specified for sql, in ldap it's the default
|
||||||
|
{
|
||||||
|
$hash = '{PLAIN}'.$hash;
|
||||||
|
}
|
||||||
|
return $hash;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Read all accounts from sql or ldap
|
* Read all accounts from sql or ldap
|
||||||
*
|
*
|
||||||
@ -284,6 +320,8 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
$account['memberships'] = $accounts_obj->memberships($account_id,true);
|
$account['memberships'] = $accounts_obj->memberships($account_id,true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
accounts::cache_invalidate();
|
||||||
|
|
||||||
return $accounts;
|
return $accounts;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -446,16 +484,17 @@ class setup_cmd_ldap extends setup_cmd
|
|||||||
{
|
{
|
||||||
throw new egw_exception(lang('Error listing "dn=%1"!',$dn));
|
throw new egw_exception(lang('Error listing "dn=%1"!',$dn));
|
||||||
}
|
}
|
||||||
|
$deleted = 0;
|
||||||
foreach($entries as $n => $entry)
|
foreach($entries as $n => $entry)
|
||||||
{
|
{
|
||||||
if ($n === 'count') continue;
|
if ($n === 'count') continue;
|
||||||
$this->rdelete($entry['dn']);
|
$deleted += $this->rdelete($entry['dn']);
|
||||||
}
|
}
|
||||||
if (!ldap_delete($this->test_ldap->ds,$dn))
|
if (!ldap_delete($this->test_ldap->ds,$dn))
|
||||||
{
|
{
|
||||||
throw new egw_exception(lang('Error deleting "dn=%1"!',$dn));
|
throw new egw_exception(lang('Error deleting "dn=%1"!',$dn));
|
||||||
}
|
}
|
||||||
return 1 + $entries['count'];
|
return ++$deleted;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user