/*
* JBoss, Home of Professional Open Source
*
* Copyright 2013 Red Hat, Inc. and/or its affiliates.
*
* 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.picketlink.test.idm.testers;
import org.picketlink.idm.config.IdentityConfigurationBuilder;
import org.picketlink.idm.internal.DefaultPartitionManager;
import org.picketlink.idm.jpa.model.sample.simple.AccountTypeEntity;
import org.picketlink.idm.jpa.model.sample.simple.GroupTypeEntity;
import org.picketlink.idm.jpa.model.sample.simple.IdentityTypeEntity;
import org.picketlink.idm.jpa.model.sample.simple.PartitionTypeEntity;
import org.picketlink.idm.jpa.model.sample.simple.PasswordCredentialTypeEntity;
import org.picketlink.idm.jpa.model.sample.simple.RelationshipTypeEntity;
import org.picketlink.idm.jpa.model.sample.simple.RoleTypeEntity;
import org.picketlink.idm.model.basic.Agent;
import org.picketlink.idm.model.basic.Realm;
import org.picketlink.idm.model.basic.User;
import org.picketlink.test.idm.basic.AttributeReferenceTypeEntity;
import org.picketlink.test.idm.relationship.RelationshipIdentityTypeReferenceEntity;
import org.picketlink.test.idm.util.JPAContextInitializer;
import org.picketlink.test.idm.util.LDAPEmbeddedServer;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import static org.picketlink.common.constants.LDAPConstants.CN;
import static org.picketlink.common.constants.LDAPConstants.CREATE_TIMESTAMP;
import static org.picketlink.common.constants.LDAPConstants.EMAIL;
import static org.picketlink.common.constants.LDAPConstants.SN;
import static org.picketlink.common.constants.LDAPConstants.UID;
import static org.picketlink.test.idm.util.PersistenceUtil.createEntityManagerFactory;
/**
* @author pedroigor
*/
public class MultipleIdentityConfigurationTester implements IdentityConfigurationTester {
private final LDAPEmbeddedServer embeddedServer = new LDAPEmbeddedServer();
private EntityManagerFactory emf;
private EntityManager entityManager;
public static final String LDAP_CONFIGURATION_NAME = "LDAPMultipleIdentityConfigurationTester";
public static final String JPA_CONFIGURATION_NAME = "JPAMultipleIdentityConfigurationTester";
@Override
public DefaultPartitionManager getPartitionManager() {
IdentityConfigurationBuilder builder = new IdentityConfigurationBuilder();
builder
.named(JPA_CONFIGURATION_NAME)
.stores()
.jpa()
.mappedEntity(
AttributeReferenceTypeEntity.class,
RelationshipTypeEntity.class,
RelationshipIdentityTypeReferenceEntity.class,
RoleTypeEntity.class,
GroupTypeEntity.class,
PartitionTypeEntity.class,
IdentityTypeEntity.class,
AccountTypeEntity.class,
PasswordCredentialTypeEntity.class
)
.addContextInitializer(new JPAContextInitializer(null) {
@Override
public EntityManager getEntityManager() {
return entityManager;
}
})
.supportAllFeatures()
.named(LDAP_CONFIGURATION_NAME)
.stores()
.ldap()
.baseDN(embeddedServer.getBaseDn())
.bindDN(embeddedServer.getBindDn())
.bindCredential(embeddedServer.getBindCredential())
.url(embeddedServer.getConnectionUrl())
.supportType(Agent.class, User.class)
.supportCredentials(true)
.mapping(Agent.class)
.baseDN(embeddedServer.getAgentDnSuffix())
.objectClasses("inetOrgPerson", "organizationalPerson")
.attribute("loginName", UID, true)
.readOnlyAttribute("createdDate", CREATE_TIMESTAMP)
.mapping(User.class)
.baseDN(embeddedServer.getUserDnSuffix())
.objectClasses("inetOrgPerson", "organizationalPerson")
.attribute("loginName", UID, true)
.attribute("firstName", CN)
.attribute("lastName", SN)
.attribute("email", EMAIL)
.readOnlyAttribute("createdDate", CREATE_TIMESTAMP);
DefaultPartitionManager partitionManager = new DefaultPartitionManager(builder.buildAll());
if (partitionManager.getPartition(Realm.class, Realm.DEFAULT_REALM) == null) {
partitionManager.add(new Realm(Realm.DEFAULT_REALM));
}
return partitionManager;
}
@Override
public void beforeTest() {
try {
this.embeddedServer.setup();
this.embeddedServer.importLDIF("ldap/users.ldif");
} catch (Exception e) {
throw new RuntimeException("Error starting Embedded LDAP server.", e);
}
this.emf = createEntityManagerFactory("ldap-usergroup-jpa-role-tests-pu");
this.entityManager = emf.createEntityManager();
this.entityManager.getTransaction().begin();
}
@Override
public void afterTest() {
try {
this.embeddedServer.tearDown();
} catch (Exception e) {
throw new RuntimeException("Error starting Embedded LDAP server.", e);
}
this.entityManager.getTransaction().commit();
this.entityManager.close();
this.emf.close();
}
public EntityManager getEntityManager() {
return entityManager;
}
}