From 0e3d9e4f2613bc5b188804ac35eea872b8be35d7 Mon Sep 17 00:00:00 2001 From: Klaus Leithoff Date: Wed, 16 Dec 2009 14:14:49 +0000 Subject: [PATCH] check for systemusers as well and deny creation, when such a user already exists --- admin/inc/class.boaccounts.inc.php | 28 +++++++++++++++++++--------- 1 file changed, 19 insertions(+), 9 deletions(-) diff --git a/admin/inc/class.boaccounts.inc.php b/admin/inc/class.boaccounts.inc.php index 8e948c4e4e..afa58ae75b 100755 --- a/admin/inc/class.boaccounts.inc.php +++ b/admin/inc/class.boaccounts.inc.php @@ -352,20 +352,30 @@ $error[$totalerrors] = lang('The groups must include the primary group'); $totalerrors++; } - + // if accounts stored in ldap, there is a chance that users are systemusers as well. + // check if an account already exists there, and if it does deny creation (increase the totalerrors counter + // and the message thereof + if($GLOBALS['egw_info']['server']['account_repository'] == 'ldap') + { + if (posix_getpwnam($_userData['account_lid'])) + { + $error[$totalerrors] = lang('There already is a system-user with this name. User\'s should not have the same name as a systemuser'); + $totalerrors++; + } + } if($_userData['old_loginid'] != $_userData['account_lid']) { - if($GLOBALS['egw']->accounts->exists($_userData['account_lid'])) + if($GLOBALS['egw']->accounts->exists($_userData['account_lid'])) { - if($GLOBALS['egw']->accounts->exists($_userData['account_lid']) && $GLOBALS['egw']->accounts->get_type($_userData['account_lid'])=='g') - { + if($GLOBALS['egw']->accounts->exists($_userData['account_lid']) && $GLOBALS['egw']->accounts->get_type($_userData['account_lid'])=='g') + { $error[$totalerrors] = lang('There already is a group with this name. Userid\'s can not have the same name as a groupid'); - } - else - { + } + else + { $error[$totalerrors] = lang('That loginid has already been taken'); - } - $totalerrors++; + } + $totalerrors++; } }