UCS 4.4 Rest API gives an error creating group "Default"

claiming a user or group with that name exists, which is not the case
(probably because other LDAP objects with cn=Default exist)
we work around that by creating it as DefaultX and rename it in LDAP to Default for now
This commit is contained in:
Ralf Becker 2019-10-18 16:23:35 +02:00
parent 414b169791
commit 5a9bc1a98a

View File

@ -106,8 +106,28 @@ class Univention extends Ldap
// create new groups incl. Samba objectclass and SID // create new groups incl. Samba objectclass and SID
elseif($data['account_type'] === 'g' && (empty($data['account_id']) || elseif($data['account_type'] === 'g' && (empty($data['account_id']) ||
$data['account_id'] >= Ads::MIN_ACCOUNT_ID && !$this->id2name($data['account_id']))) $data['account_id'] >= Ads::MIN_ACCOUNT_ID && !$this->id2name($data['account_id'])))
{
// UCS 4.4 Rest API gives an error creating group "Default" claiming a user or group with that name exists
if ($data['account_lid'] === 'Default')
{
// we work around that by creating the group as DefaultX and then rename it to Default in ldap
$data['account_lid'] = 'DefaultX';
if (($data['account_dn'] = $udm->createGroup($data)) &&
ldap_rename($this->ds, $data['account_dn'], 'cn=Default',
substr($data['account_dn'], 12), true)) // strlen("cn=DefaultX,")==12
{
$data['account_dn'] = str_replace('=DefaultX,', '=Default,', $data['account_dn']);
$data['account_lid'] = 'Default';
}
else
{
throw new Exception("Creating Group DefaultX and renaming to Default failed!");
}
}
else
{ {
$data['account_dn'] = $udm->createGroup($data); $data['account_dn'] = $udm->createGroup($data);
}
$data['account_id'] = $this->name2id($data['account_lid'], 'account_lid', 'g'); $data['account_id'] = $this->name2id($data['account_lid'], 'account_lid', 'g');
} }
// account_lid and password changes need to go through UDM too // account_lid and password changes need to go through UDM too
@ -139,7 +159,7 @@ class Univention extends Ldap
*/ */
function name2id($_name,$which='account_lid',$account_type=null) function name2id($_name,$which='account_lid',$account_type=null)
{ {
if ((!$id = parent::name2id($_name, $which, $account_type))) if ((!$id = parent::name2id($_name, $which, $account_type)) && $account_type !== 'g')
{ {
$user_dn = $this->user_context; $user_dn = $this->user_context;
$this->user_context = preg_replace('/(cn|uid)=([^,]+),/i', '', $this->user_context); $this->user_context = preg_replace('/(cn|uid)=([^,]+),/i', '', $this->user_context);