org.connid.bundles.ad.authentication.ADAuthenticate Maven / Gradle / Ivy
The newest version!
/**
* Copyright (C) 2011 ConnId ([email protected])
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.connid.bundles.ad.authentication;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.connid.bundles.ad.ADConfiguration;
import org.connid.bundles.ad.ADConnection;
import org.connid.bundles.ldap.LdapConnection.AuthenticationResult;
import org.connid.bundles.ldap.LdapConnection.AuthenticationResultType;
import org.connid.bundles.ldap.commons.LdapConstants;
import org.connid.bundles.ldap.search.LdapSearches;
import org.identityconnectors.common.logging.Log;
import org.identityconnectors.common.security.GuardedString;
import org.identityconnectors.framework.common.exceptions.ConnectorSecurityException;
import org.identityconnectors.framework.common.exceptions.InvalidCredentialException;
import org.identityconnectors.framework.common.exceptions.PasswordExpiredException;
import org.identityconnectors.framework.common.objects.Attribute;
import org.identityconnectors.framework.common.objects.AttributeBuilder;
import org.identityconnectors.framework.common.objects.ConnectorObject;
import org.identityconnectors.framework.common.objects.ObjectClass;
import org.identityconnectors.framework.common.objects.OperationOptions;
import org.identityconnectors.framework.common.objects.Uid;
public class ADAuthenticate {
private static final Log LOG = Log.getLog(ADAuthenticate.class);
private final ADConnection conn;
private final ObjectClass oclass;
private final String username;
private final OperationOptions options;
public ADAuthenticate(
final ADConnection conn,
final ObjectClass oclass,
final String username,
final OperationOptions options) {
this.conn = conn;
this.oclass = oclass;
this.username = username;
this.options = options;
}
public Uid authenticate(GuardedString password) {
final ConnectorObject authnObject = getObjectToAuthenticate();
AuthenticationResult authnResult = null;
if (authnObject != null) {
final String entryDN = authnObject.getName().getNameValue();
authnResult = conn.authenticate(entryDN, password);
}
if (!isSuccess(authnResult)) {
throw new InvalidCredentialException(
conn.format("authenticationFailed", null, username));
}
try {
authnResult.propagate();
} catch (PasswordExpiredException e) {
e.initUid(authnObject.getUid());
throw e;
}
// AuthenticationResult did not throw an exception,
// so this authentication was successful.
return authnObject.getUid();
}
private static boolean isSuccess(final AuthenticationResult authResult) {
// PASSWORD_EXPIRED considered success: credentials were right.
final AuthenticationResultType type = authResult.getType();
return authResult != null
&& (type.equals(AuthenticationResultType.SUCCESS)
|| type.equals(AuthenticationResultType.PASSWORD_EXPIRED));
}
private ConnectorObject getObjectToAuthenticate() {
List userNameAttrs = getUserNameAttributes();
Map entryDN2Object = new HashMap();
for (String baseContext : ((ADConfiguration) conn.getConfiguration()).getUserBaseContexts()) {
for (String userNameAttr : userNameAttrs) {
Attribute attr = AttributeBuilder.build(userNameAttr, username);
for (ConnectorObject object : LdapSearches.findObjects(conn, oclass, baseContext, attr, "entryDN")) {
String entryDN = object.getAttributeByName("entryDN").getValue().get(0).toString();
entryDN2Object.put(entryDN, object);
}
// If we found more than one authentication candidates, no need to continue
if (entryDN2Object.size() > 1) {
throw new ConnectorSecurityException(conn.format(
"moreThanOneEntryMatched", null, username));
}
}
}
if (!entryDN2Object.isEmpty()) {
return entryDN2Object.values().iterator().next();
}
return null;
}
private List getUserNameAttributes() {
String[] result = LdapConstants.getLdapUidAttributes(options);
if (result != null && result.length > 0) {
return Arrays.asList(result);
}
return conn.getSchemaMapping().getUserNameLdapAttributes(oclass);
}
public Uid resolveUsername() {
ConnectorObject authnObject = getObjectToAuthenticate();
if (authnObject == null) {
throw new InvalidCredentialException(conn.format(
"cannotResolveUsername", null, username));
}
return authnObject.getUid();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy