X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/1b4ed69f41955d27794718cd74b3f56fba9be63f..refs/pull/5676/head:/app/Access/LdapService.php diff --git a/app/Access/LdapService.php b/app/Access/LdapService.php index 7c8d8b18f..0f456efc2 100644 --- a/app/Access/LdapService.php +++ b/app/Access/LdapService.php @@ -71,6 +71,26 @@ class LdapService return $users[0]; } + /** + * Build the user display name from the (potentially multiple) attributes defined by the configuration. + */ + protected function getUserDisplayName(array $userDetails, array $displayNameAttrs, string $defaultValue): string + { + $displayNameParts = []; + foreach ($displayNameAttrs as $dnAttr) { + $dnComponent = $this->getUserResponseProperty($userDetails, $dnAttr, null); + if ($dnComponent) { + $displayNameParts[] = $dnComponent; + } + } + + if (empty($displayNameParts)) { + return $defaultValue; + } + + return implode(' ', $displayNameParts); + } + /** * Get the details of a user from LDAP using the given username. * User found via configurable user filter. @@ -81,21 +101,25 @@ class LdapService { $idAttr = $this->config['id_attribute']; $emailAttr = $this->config['email_attribute']; - $displayNameAttr = $this->config['display_name_attribute']; + $displayNameAttrs = explode('|', $this->config['display_name_attribute']); $thumbnailAttr = $this->config['thumbnail_attribute']; $user = $this->getUserWithAttributes($userName, array_filter([ - 'cn', 'dn', $idAttr, $emailAttr, $displayNameAttr, $thumbnailAttr, + 'cn', 'dn', $idAttr, $emailAttr, ...$displayNameAttrs, $thumbnailAttr, ])); if (is_null($user)) { return null; } - $userCn = $this->getUserResponseProperty($user, 'cn', null); + $nameDefault = $this->getUserResponseProperty($user, 'cn', null); + if (is_null($nameDefault)) { + $nameDefault = ldap_explode_dn($user['dn'], 1)[0] ?? $user['dn']; + } + $formatted = [ 'uid' => $this->getUserResponseProperty($user, $idAttr, $user['dn']), - 'name' => $this->getUserResponseProperty($user, $displayNameAttr, $userCn), + 'name' => $this->getUserDisplayName($user, $displayNameAttrs, $nameDefault), 'dn' => $user['dn'], 'email' => $this->getUserResponseProperty($user, $emailAttr, null), 'avatar' => $thumbnailAttr ? $this->getUserResponseProperty($user, $thumbnailAttr, null) : null, @@ -334,7 +358,7 @@ class LdapService ]); } - return $allGroups; + return $formattedGroups; } protected function extractGroupNamesFromLdapGroupDns(array $groupDNs): array