package fi.otavanopisto.muikku.dao.security;
import javax.persistence.EntityManager;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;
import fi.otavanopisto.muikku.model.security.UserGroupRolePermission_;
import fi.otavanopisto.muikku.dao.CoreDAO;
import fi.otavanopisto.muikku.model.security.Permission;
import fi.otavanopisto.muikku.model.security.UserGroupRolePermission;
import fi.otavanopisto.muikku.model.users.RoleEntity;
import fi.otavanopisto.muikku.model.users.UserGroupEntity;
public class UserGroupRolePermissionDAO extends CoreDAO<UserGroupRolePermission> {
private static final long serialVersionUID = 1034213846498141630L;
public UserGroupRolePermission create(UserGroupEntity userGroup, RoleEntity role, Permission permission) {
UserGroupRolePermission curpermission = new UserGroupRolePermission();
curpermission.setUserGroup(userGroup);
curpermission.setRole(role);
curpermission.setPermission(permission);
getEntityManager().persist(curpermission);
return curpermission;
}
// TODO: Not a DAO method
public boolean hasPermissionAccess(UserGroupEntity userGroup, RoleEntity role, Permission permission) {
return findByRoleAndPermission(userGroup, role, permission) != null;
}
public UserGroupRolePermission findByRoleAndPermission(UserGroupEntity userGroup, RoleEntity role, Permission permission) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<UserGroupRolePermission> criteria = criteriaBuilder.createQuery(UserGroupRolePermission.class);
Root<UserGroupRolePermission> root = criteria.from(UserGroupRolePermission.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(UserGroupRolePermission_.userGroup), userGroup),
criteriaBuilder.equal(root.get(UserGroupRolePermission_.role), role),
criteriaBuilder.equal(root.get(UserGroupRolePermission_.permission), permission)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
@Override
public void delete(UserGroupRolePermission userGroupRolePermission) {
super.delete(userGroupRolePermission);
}
}