diff options
author | Robert Speicher <robert@gitlab.com> | 2017-01-03 21:11:10 +0000 |
---|---|---|
committer | Robert Speicher <robert@gitlab.com> | 2017-01-03 21:11:10 +0000 |
commit | 115aac77f614a9130aa9bc6ff48aed47339aebfc (patch) | |
tree | 775412586cc3676662ef04f0760510422f8f44ef | |
parent | 8daff07ca70aeefb0fc11541b77298570de4f47e (diff) | |
parent | babb7d5260087abfe09d7c4d6994433def7d8b99 (diff) | |
download | gitlab-ce-include-uncovered-jasmine.tar.gz |
Merge branch 'ldap_person_attributes' into 'master'
include-uncovered-jasmine
Gitlab::LDAP::Person uses LDAP attributes configuration
Closes #26290
See merge request !8418
-rw-r--r-- | changelogs/unreleased/ldap_person_attributes.yml | 4 | ||||
-rw-r--r-- | lib/gitlab/ldap/person.rb | 19 | ||||
-rw-r--r-- | spec/lib/gitlab/ldap/person_spec.rb | 44 |
3 files changed, 65 insertions, 2 deletions
diff --git a/changelogs/unreleased/ldap_person_attributes.yml b/changelogs/unreleased/ldap_person_attributes.yml new file mode 100644 index 00000000000..d04b5dbe7e0 --- /dev/null +++ b/changelogs/unreleased/ldap_person_attributes.yml @@ -0,0 +1,4 @@ +--- +title: Gitlab::LDAP::Person uses LDAP attributes configuration +merge_request: 8418 +author: diff --git a/lib/gitlab/ldap/person.rb b/lib/gitlab/ldap/person.rb index b81f3e8e8f5..333f170a484 100644 --- a/lib/gitlab/ldap/person.rb +++ b/lib/gitlab/ldap/person.rb @@ -28,7 +28,7 @@ module Gitlab end def name - entry.cn.first + attribute_value(:name) end def uid @@ -40,7 +40,7 @@ module Gitlab end def email - entry.try(:mail) + attribute_value(:email) end def dn @@ -56,6 +56,21 @@ module Gitlab def config @config ||= Gitlab::LDAP::Config.new(provider) end + + # Using the LDAP attributes configuration, find and return the first + # attribute with a value. For example, by default, when given 'email', + # this method looks for 'mail', 'email' and 'userPrincipalName' and + # returns the first with a value. + def attribute_value(attribute) + attributes = Array(config.attributes[attribute.to_sym]) + selected_attr = attributes.find { |attr| entry.respond_to?(attr) } + + return nil unless selected_attr + + # Some LDAP attributes return an array, + # even if it is a single value (like 'cn') + Array(entry.public_send(selected_attr)).first + end end end end diff --git a/spec/lib/gitlab/ldap/person_spec.rb b/spec/lib/gitlab/ldap/person_spec.rb new file mode 100644 index 00000000000..60afe046788 --- /dev/null +++ b/spec/lib/gitlab/ldap/person_spec.rb @@ -0,0 +1,44 @@ +require 'spec_helper' + +describe Gitlab::LDAP::Person do + include LdapHelpers + + let(:entry) { ldap_user_entry('john.doe') } + + before do + stub_ldap_config( + attributes: { + name: 'cn', + email: %w(mail email userPrincipalName) + } + ) + end + + describe '#name' do + it 'uses the configured name attribute and handles values as an array' do + name = 'John Doe' + entry['cn'] = [name] + person = Gitlab::LDAP::Person.new(entry, 'ldapmain') + + expect(person.name).to eq(name) + end + end + + describe '#email' do + it 'returns the value of mail, if present' do + mail = 'john@example.com' + entry['mail'] = mail + person = Gitlab::LDAP::Person.new(entry, 'ldapmain') + + expect(person.email).to eq(mail) + end + + it 'returns the value of userPrincipalName, if mail and email are not present' do + user_principal_name = 'john.doe@example.com' + entry['userPrincipalName'] = user_principal_name + person = Gitlab::LDAP::Person.new(entry, 'ldapmain') + + expect(person.email).to eq(user_principal_name) + end + end +end |