org.sonar.plugins.ldap.LdapUserMapping Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of sonar-ldap-plugin Show documentation
Show all versions of sonar-ldap-plugin Show documentation
Delegates authentication to LDAP.
The newest version!
/*
* Sonar LDAP Plugin
* Copyright (C) 2009 SonarSource
* [email protected]
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
*/
package org.sonar.plugins.ldap;
import com.google.common.base.Objects;
import org.apache.commons.lang.StringUtils;
import org.slf4j.LoggerFactory;
import org.sonar.api.config.Settings;
/**
* @author Evgeny Mandrikov
*/
public class LdapUserMapping {
private static final String DEFAULT_OBJECT_CLASS = "inetOrgPerson";
private static final String DEFAULT_LOGIN_ATTRIBUTE = "uid";
private static final String DEFAULT_NAME_ATTRIBUTE = "cn";
private static final String DEFAULT_EMAIL_ATTRIBUTE = "mail";
private static final String DEFAULT_REQUEST = "(&(objectClass=inetOrgPerson)(uid={login}))";
private final String baseDn;
private final String request;
private final String realNameAttribute;
private final String emailAttribute;
/**
* Constructs mapping from Sonar settings.
*/
public LdapUserMapping(Settings settings, String settingsPrefix) {
String usersBaseDn = settings.getString(settingsPrefix + ".user.baseDn");
if (usersBaseDn == null) {
String realm = settings.getString(settingsPrefix + ".realm");
if (realm != null) {
usersBaseDn = LdapAutodiscovery.getDnsDomainDn(realm);
}
}
String objectClass = settings.getString(settingsPrefix + ".user.objectClass");
String loginAttribute = settings.getString(settingsPrefix + ".user.loginAttribute");
this.baseDn = usersBaseDn;
this.realNameAttribute = StringUtils.defaultString(settings.getString(settingsPrefix + ".user.realNameAttribute"), DEFAULT_NAME_ATTRIBUTE);
this.emailAttribute = StringUtils.defaultString(settings.getString(settingsPrefix + ".user.emailAttribute"), DEFAULT_EMAIL_ATTRIBUTE);
String req;
if (StringUtils.isNotBlank(objectClass) || StringUtils.isNotBlank(loginAttribute)) {
objectClass = StringUtils.defaultString(objectClass, DEFAULT_OBJECT_CLASS);
loginAttribute = StringUtils.defaultString(loginAttribute, DEFAULT_LOGIN_ATTRIBUTE);
req = "(&(objectClass=" + objectClass + ")(" + loginAttribute + "={login}))";
// For backward compatibility with plugin versions lower than 1.2
LoggerFactory.getLogger(LdapGroupMapping.class)
.warn("Properties '" + settingsPrefix + ".user.objectClass' and '" + settingsPrefix + ".user.loginAttribute' are deprecated" +
" and should be replaced by single property '" + settingsPrefix + ".user.request' with value: " + req);
} else {
req = StringUtils.defaultString(settings.getString(settingsPrefix + ".user.request"), DEFAULT_REQUEST);
}
req = StringUtils.replace(req, "{login}", "{0}");
this.request = req;
}
/**
* Search for this mapping.
*/
public LdapSearch createSearch(LdapContextFactory contextFactory, String username) {
return new LdapSearch(contextFactory)
.setBaseDn(getBaseDn())
.setRequest(getRequest())
.setParameters(username);
}
/**
* Base DN. For example "ou=users,o=mycompany" or "cn=users" (Active Directory Server).
*/
public String getBaseDn() {
return baseDn;
}
/**
* Request. For example:
*
* (&(objectClass=inetOrgPerson)(uid={0}))
* (&(objectClass=user)(sAMAccountName={0}))
*
*/
public String getRequest() {
return request;
}
/**
* Real Name Attribute. For example "cn".
*/
public String getRealNameAttribute() {
return realNameAttribute;
}
/**
* EMail Attribute. For example "mail".
*/
public String getEmailAttribute() {
return emailAttribute;
}
@Override
public String toString() {
return Objects.toStringHelper(this)
.add("baseDn", getBaseDn())
.add("request", getRequest())
.add("realNameAttribute", getRealNameAttribute())
.add("emailAttribute", getEmailAttribute())
.toString();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy