/**
* Licensed to the Austrian Association for Software Tool Integration (AASTI)
* under one or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information regarding copyright
* ownership. The AASTI licenses this file to you 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.openengsb.connector.userprojects.ldap.internal;
import java.util.List;
import org.openengsb.connector.userprojects.ldap.internal.ldap.DefaultModelManager;
import org.openengsb.connector.userprojects.ldap.internal.ldap.ModelManager;
import org.openengsb.core.services.SecurityContext;
import org.openengsb.domain.userprojects.UserProjectsDomainEvents;
import org.openengsb.domain.userprojects.event.UpdateAssignmentEvent;
import org.openengsb.domain.userprojects.event.UpdateProjectsEvent;
import org.openengsb.domain.userprojects.event.UpdateRolesEvent;
import org.openengsb.domain.userprojects.event.UpdateUserEvent;
import org.openengsb.domain.userprojects.model.Assignment;
import org.openengsb.domain.userprojects.model.Project;
import org.openengsb.domain.userprojects.model.Role;
import org.openengsb.domain.userprojects.model.User;
import org.openengsb.infrastructure.ldap.LdapDao;
public final class DefaultSynchronizationService implements SynchronizationService {
private ModelManager modelManager;
private UserProjectsDomainEvents events;
public void setUserProjectsDomainEvents(UserProjectsDomainEvents domainEvents) {
events = domainEvents;
}
@Override
public void syncFromLdapServerToOpenEngSB(LdapDao ldapDao) {
modelManager = new DefaultModelManager(ldapDao);
SecurityContext.executeWithSystemPermissions(new Runnable() {
@Override
public void run() {
syncUsers();
syncProjects();
syncRoles();
syncAssignments();
}
});
}
private void syncUsers() {
List<User> userList = modelManager.findUsers();
UpdateUserEvent event = new UpdateUserEvent();
event.setNewUpdatedUsers(userList);
events.raiseEvent(event);
}
private void syncProjects() {
List<Project> projectList = modelManager.findProjects();
UpdateProjectsEvent event = new UpdateProjectsEvent();
event.setUpdatedProjects(projectList);
events.raiseEvent(event);
}
private void syncRoles() {
List<Role> roleList = modelManager.findRoles();
UpdateRolesEvent event = new UpdateRolesEvent();
event.setUpdatedRoles(roleList);
events.raiseEvent(event);
}
private void syncAssignments() {
List<Assignment> assignmentList = modelManager.findAssignments();
UpdateAssignmentEvent event = new UpdateAssignmentEvent();
event.setUpdatedAssignments(assignmentList);
events.raiseEvent(event);
}
}