/* * Copyright 2012 PRODYNA AG * * Licensed under the Eclipse Public License (EPL), Version 1.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.opensource.org/licenses/eclipse-1.0.php or * http://www.nabucco.org/License.html * * 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.nabucco.framework.common.authorization.impl.service.resolve; import java.util.List; import org.nabucco.framework.base.facade.exception.persistence.PersistenceException; import org.nabucco.framework.base.facade.exception.service.ResolveException; import org.nabucco.framework.base.impl.service.maintain.NabuccoQuery; import org.nabucco.framework.common.authorization.facade.datatype.AuthorizationGroup; import org.nabucco.framework.common.authorization.facade.datatype.AuthorizationPermission; import org.nabucco.framework.common.authorization.facade.datatype.AuthorizationRole; import org.nabucco.framework.common.authorization.facade.datatype.AuthorizationUser; import org.nabucco.framework.common.authorization.facade.message.AuthorizationPermissionMsg; import org.nabucco.framework.common.authorization.facade.message.maintain.AuthorizationPermissionMaintainMsg; /** * ResolveAuthorizationPermissionServiceHandlerImpl * * @author Jens Wurm, PRODYNA AG */ public class ResolveAuthorizationPermissionServiceHandlerImpl extends ResolveAuthorizationPermissionServiceHandler { private static final long serialVersionUID = 1L; private AuthorizationPermissionMaintainMsg response; private AuthorizationPermission permission; @Override public AuthorizationPermissionMaintainMsg resolveAuthorizationPermission(AuthorizationPermissionMsg msg) throws ResolveException { this.permission = msg.getAuthorizationPermission(); this.response = new AuthorizationPermissionMaintainMsg(); try { this.resolve(); this.loadParentGroups(); this.loadParentUsers(); this.loadParentRoles(); } catch (PersistenceException e) { throw new ResolveException("Cannot resolve AuthorizationPermission with id " + this.permission.getId()); } this.response.setAuthorizationPermission(this.permission); return response; } /** * Resolve the permission. * * @throws PersistenceException * when the permission is not persistent */ private void resolve() throws PersistenceException { this.permission = super.getPersistenceManager().find(this.permission); } /** * Load all groups holding the permission. * * @throws PersistenceException * when the query execution fails */ private void loadParentGroups() throws ResolveException, PersistenceException { StringBuilder queryString = new StringBuilder(); queryString.append("select g from AuthorizationGroup g"); queryString.append(" inner join g.permissionListJPA gp"); queryString.append(" inner join gp.permission p"); queryString.append(" where (p.id = :permissionId)"); NabuccoQuery<AuthorizationGroup> query = super.getPersistenceManager().createQuery(queryString.toString()); query.setParameter("permissionId", this.permission.getId()); List<AuthorizationGroup> resultList = query.getResultList(); this.response.getAuthorizationGroupList().addAll(resultList); } /** * Load all users holding the permission. * * @throws PersistenceException * when the query execution fails */ private void loadParentUsers() throws ResolveException, PersistenceException { StringBuilder queryString = new StringBuilder(); queryString.append("select u from AuthorizationUser u"); queryString.append(" inner join u.permissionListJPA up"); queryString.append(" inner join up.permission p"); queryString.append(" where (p.id = :permissionId)"); NabuccoQuery<AuthorizationUser> query = super.getPersistenceManager().createQuery(queryString.toString()); query.setParameter("permissionId", this.permission.getId()); List<AuthorizationUser> resultList = query.getResultList(); this.response.getAuthorizationUserList().addAll(resultList); } /** * Load all roles holding the permission. * * @throws PersistenceException * when the query execution fails */ private void loadParentRoles() throws PersistenceException { StringBuilder queryString = new StringBuilder(); queryString.append("select r from AuthorizationRole r"); queryString.append(" inner join r.permissionListJPA rp"); queryString.append(" inner join rp.permission p"); queryString.append(" where (p.id = :permissionId)"); NabuccoQuery<AuthorizationRole> query = super.getPersistenceManager().createQuery(queryString.toString()); query.setParameter("permissionId", this.permission.getId()); List<AuthorizationRole> resultList = query.getResultList(); this.response.getAuthorizationRoleList().addAll(resultList); } }