io.quarkus.elytron.security.ldap.LdapRecorder Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of quarkus-elytron-security-ldap Show documentation
Show all versions of quarkus-elytron-security-ldap Show documentation
Secure your applications with username/password via LDAP
package io.quarkus.elytron.security.ldap;
import java.util.ArrayList;
import java.util.List;
import javax.naming.NamingException;
import javax.naming.directory.DirContext;
import org.wildfly.common.function.ExceptionSupplier;
import org.wildfly.security.auth.realm.ldap.AttributeMapping;
import org.wildfly.security.auth.realm.ldap.DirContextFactory;
import org.wildfly.security.auth.realm.ldap.LdapSecurityRealmBuilder;
import org.wildfly.security.auth.server.SecurityRealm;
import io.quarkus.elytron.security.ldap.config.AttributeMappingConfig;
import io.quarkus.elytron.security.ldap.config.DirContextConfig;
import io.quarkus.elytron.security.ldap.config.IdentityMappingConfig;
import io.quarkus.elytron.security.ldap.config.LdapSecurityRealmRuntimeConfig;
import io.quarkus.runtime.RuntimeValue;
import io.quarkus.runtime.annotations.Recorder;
@Recorder
public class LdapRecorder {
/**
* Create a runtime value for a {@linkplain LdapSecurityRealm}
*
* @param runtimeConfig the realm config
* @return runtime value wrapper for the SecurityRealm
*/
public RuntimeValue createRealm(LdapSecurityRealmRuntimeConfig runtimeConfig) {
LdapSecurityRealmBuilder.IdentityMappingBuilder identityMappingBuilder = LdapSecurityRealmBuilder.builder()
.setDirContextSupplier(createDirContextSupplier(runtimeConfig.dirContext))
.identityMapping();
if (runtimeConfig.identityMapping.searchRecursive) {
identityMappingBuilder.searchRecursive();
}
LdapSecurityRealmBuilder ldapSecurityRealmBuilder = identityMappingBuilder
.map(createAttributeMappings(runtimeConfig.identityMapping))
.setRdnIdentifier(runtimeConfig.identityMapping.rdnIdentifier)
.setSearchDn(runtimeConfig.identityMapping.searchBaseDn)
.build();
if (runtimeConfig.directVerification) {
ldapSecurityRealmBuilder.addDirectEvidenceVerification(false);
}
return new RuntimeValue<>(ldapSecurityRealmBuilder.build());
}
private ExceptionSupplier createDirContextSupplier(DirContextConfig dirContext) {
DirContextFactory dirContextFactory = new QuarkusDirContextFactory(
dirContext.url,
dirContext.principal.orElse(null),
dirContext.password.orElse(null));
return () -> dirContextFactory.obtainDirContext(dirContext.referralMode);
}
private AttributeMapping[] createAttributeMappings(IdentityMappingConfig identityMappingConfig) {
List attributeMappings = new ArrayList<>();
for (AttributeMappingConfig attributeMappingConfig : identityMappingConfig.attributeMappings.values()) {
attributeMappings.add(AttributeMapping.fromFilter(attributeMappingConfig.filter)
.from(attributeMappingConfig.from)
.to(attributeMappingConfig.to)
.searchDn(attributeMappingConfig.filterBaseDn)
.build());
}
AttributeMapping[] attributeMappingsArray = new AttributeMapping[attributeMappings.size()];
return attributeMappings.toArray(attributeMappingsArray);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy