Gracefully deny users or groups with too long DNs
Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
This commit is contained in:
parent
f469b3e958
commit
03ae7b654f
3 changed files with 16 additions and 1 deletions
|
@ -678,6 +678,9 @@ class Access extends LDAPUtility implements IUserTools {
|
|||
*/
|
||||
public function cacheUserDisplayName($ocName, $displayName, $displayName2 = '') {
|
||||
$user = $this->userManager->get($ocName);
|
||||
if($user === null) {
|
||||
return;
|
||||
}
|
||||
$displayName = $user->composeAndStoreDisplayName($displayName, $displayName2);
|
||||
$cacheKeyTrunk = 'getDisplayName';
|
||||
$this->connection->writeToCache($cacheKeyTrunk.$ocName, $displayName);
|
||||
|
|
|
@ -209,6 +209,17 @@ abstract class AbstractMapping {
|
|||
* @return bool
|
||||
*/
|
||||
public function map($fdn, $name, $uuid) {
|
||||
if(mb_strlen($fdn) > 255) {
|
||||
\OC::$server->getLogger()->error(
|
||||
'Cannot map, because the DN exceeds 255 characters: {dn}',
|
||||
[
|
||||
'app' => 'user_ldap',
|
||||
'dn' => $fdn,
|
||||
]
|
||||
);
|
||||
return false;
|
||||
}
|
||||
|
||||
$row = array(
|
||||
'ldap_dn' => $fdn,
|
||||
'owncloud_name' => $name,
|
||||
|
|
|
@ -106,7 +106,8 @@ abstract class AbstractMappingTest extends \Test\TestCase {
|
|||
list($mapper, $data) = $this->initTest();
|
||||
|
||||
// test that mapping will not happen when it shall not
|
||||
$paramKeys = array('', 'dn', 'name', 'uuid');
|
||||
$tooLongDN = 'uid=joann,ou=Secret Small Specialized Department,ou=Some Tremendously Important Department,ou=Another Very Important Department,ou=Pretty Meaningful Derpartment,ou=Quite Broad And General Department,ou=The Topmost Department,dc=hugelysuccessfulcompany,dc=com';
|
||||
$paramKeys = array('', 'dn', 'name', 'uuid', $tooLongDN);
|
||||
foreach($paramKeys as $key) {
|
||||
$failEntry = $data[0];
|
||||
if(!empty($key)) {
|
||||
|
|
Loading…
Reference in a new issue