* Univention/Admin: renaming of accounts or groups works now (failed with removed old account)

This commit is contained in:
Ralf Becker 2015-08-06 12:11:24 +00:00
parent e109d06e0d
commit 63587d767f

View File

@ -15,8 +15,12 @@
* Univention LDAP Backend for accounts * Univention LDAP Backend for accounts
* *
* This backend is mostly identical to LDAP backend and need to be configured in the same way. * This backend is mostly identical to LDAP backend and need to be configured in the same way.
*
* Only difference is that new users get created via univention-directory-manager CLI program, * Only difference is that new users get created via univention-directory-manager CLI program,
* to generate necesary Kerberos stuff. * to generate necesary Kerberos stuff.
*
* Existing users and groups need to be renamed via same CLI, as removing and
* adding entry under new dn via LDAP fails (Type or value exists).
*/ */
class accounts_univention extends accounts_ldap class accounts_univention extends accounts_ldap
{ {
@ -43,55 +47,85 @@ class accounts_univention extends accounts_ldap
*/ */
function save(&$data) function save(&$data)
{ {
if (!$data['account_id'] && $data['account_type'] !== 'g' && self::available()) if (self::available())
{ {
$config = $this->frontend->config && $this->frontend->config['ldap_context'] ? $config = $this->frontend->config && $this->frontend->config['ldap_context'] ?
$this->frontend->config : $GLOBALS['egw_info']['server']; $this->frontend->config : $GLOBALS['egw_info']['server'];
$params = array(
'users/user','create', if (!$data['account_id'] && $data['account_type'] !== 'g')
'--binddn', $config['ldap_root_dn'],
'--bindpwd', 5=>$config['ldap_root_pw'],
'--position', $config['ldap_context'],
'--set', 'username='.$data['account_lid'],
'--set', 'firstname='.$data['account_firstname'],
'--set', 'lastname='.$data['account_lastname'],
);
if ($data['account_email'])
{ {
$params[] = '--set'; $params[] = 'mailPrimaryAddress='.$data['account_email']; $params = array(
} 'users/user','create',
if (!empty($data['account_passwd'])) '--binddn', $config['ldap_root_dn'],
{ '--bindpwd', 5=>$config['ldap_root_pw'],
$params[] = '--set'; $params[] = 'password='.$data['account_passwd']; '--position', $config['ldap_context'],
// we need to set mailHomeServer, so mailbox gets created for Dovecot '--set', 'username='.$data['account_lid'],
// get_default() does not work for Adminstrator, try acc_id=1 instead '--set', 'firstname='.$data['account_firstname'],
// if everything fails try hostname ... '--set', 'lastname='.$data['account_lastname'],
try { );
if (!($account = emailadmin_account::get_default(false, false, false))) if ($data['account_email'])
{ {
$account = emailadmin_account::read(1); $params[] = '--set'; $params[] = 'mailPrimaryAddress='.$data['account_email'];
}
if (!empty($data['account_passwd']))
{
$params[] = '--set'; $params[] = 'password='.$data['account_passwd'];
// we need to set mailHomeServer, so mailbox gets created for Dovecot
// get_default() does not work for Adminstrator, try acc_id=1 instead
// if everything fails try hostname ...
try {
if (!($account = emailadmin_account::get_default(false, false, false)))
{
$account = emailadmin_account::read(1);
}
$hostname = $account->acc_imap_host;
} }
$hostname = $account->acc_imap_host; catch(Exception $e) {
unset($e);
}
if (empty($hostname)) $hostname = trim(system('hostname -f'));
$params[] = '--set'; $params[] = 'mailHomeServer='.$hostname;
} }
catch(Exception $e) {
unset($e);
}
if (empty($hostname)) $hostname = trim(system('hostname -f'));
$params[] = '--set'; $params[] = 'mailHomeServer='.$hostname;
}
$cmd = self::DIRECTORY_MANAGER_BIN.' '.implode(' ', array_map('escapeshellarg', $params));
$output_arr = $ret = $matches = null;
exec($cmd, $output_arr, $ret);
$output = implode("\n", $output_arr);
if ($ret || !preg_match('/^Object created: (uid=.*)$/mui', $output, $matches))
{
$params[5] = '********'; // mask out password!
$cmd = self::DIRECTORY_MANAGER_BIN.' '.implode(' ', array_map('escapeshellarg', $params)); $cmd = self::DIRECTORY_MANAGER_BIN.' '.implode(' ', array_map('escapeshellarg', $params));
throw new egw_exception_wrong_userinput($cmd."\nreturned\n".$output); $output_arr = $ret = $matches = null;
exec($cmd, $output_arr, $ret);
$output = implode("\n", $output_arr);
if ($ret || !preg_match('/^Object created: (uid=.*)$/mui', $output, $matches))
{
$params[5] = '********'; // mask out password!
$cmd = self::DIRECTORY_MANAGER_BIN.' '.implode(' ', array_map('escapeshellarg', $params));
throw new egw_exception_wrong_userinput($cmd."\nreturned\n".$output);
}
$data['account_dn'] = $matches[1];
$data['account_id'] = $this->name2id($data['account_lid'], 'account_lid', 'u');
}
elseif($data['account_id'] && ($data['old_loginid'] || ($data['old_loginid'] = $this->id2name($data['account_id']))) &&
$data['account_lid'] != $data['old_loginid'] &&
($data['account_dn'] = $this->id2name($data['account_id'], 'account_dn')))
{
$params = array(
$data['account_type'] !== 'g' ? 'users/user' : 'groups/group', 'modify',
'--binddn', $config['ldap_root_dn'],
'--bindpwd', 5=>$config['ldap_root_pw'],
'--dn', $data['account_dn'],
'--set', ($data['account_type'] !== 'g' ? 'username' : 'name').'='.$data['account_lid'],
);
$cmd = self::DIRECTORY_MANAGER_BIN.' '.implode(' ', array_map('escapeshellarg', $params));
$output_arr = $ret = $matches = null;
exec($cmd, $output_arr, $ret);
$output = implode("\n", $output_arr);
if ($ret || !preg_match('/^Object modified: ((uid|cn)=.*)$/mui', $output, $matches))
{
$params[5] = '********'; // mask out password!
$cmd = self::DIRECTORY_MANAGER_BIN.' '.implode(' ', array_map('escapeshellarg', $params));
throw new egw_exception_wrong_userinput($cmd."\nreturned\n".$output);
}
$data['account_dn'] = $data['account_type'] !== 'g' ? $matches[1] :
// duno why but directory-manager returns old dn for groups ...
preg_replace('/^cn=[^,]+,/', 'cn='.$data['account_lid'].',', $data['account_dn']);
} }
$data['account_dn'] = $matches[1];
$data['account_id'] = $this->name2id($data['account_lid'], 'account_lid', 'u');
} }
//else error_log(__METHOD__."() ".self::DIRECTORY_MANAGER_BIN." is NOT available!");
return parent::save($data); return parent::save($data);
} }