All Downloads are FREE. Search and download functionalities are using the official Maven repository.

fi.foyt.fni.persistence.dao.materials.UserMaterialRoleDAO Maven / Gradle / Ivy

There is a newer version: 3.3.13
Show newest version
package fi.foyt.fni.persistence.dao.materials;

import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Root;

import fi.foyt.fni.persistence.dao.GenericDAO;
import fi.foyt.fni.persistence.model.materials.Material;
import fi.foyt.fni.persistence.model.materials.MaterialRole;
import fi.foyt.fni.persistence.model.materials.UserMaterialRole;
import fi.foyt.fni.persistence.model.materials.UserMaterialRole_;
import fi.foyt.fni.persistence.model.users.User;

public class UserMaterialRoleDAO extends GenericDAO {

	private static final long serialVersionUID = 1L;

	public UserMaterialRole create(Material material, User user, MaterialRole role) {
    EntityManager entityManager = getEntityManager();

    UserMaterialRole userMaterialRole = new UserMaterialRole();
    userMaterialRole.setMaterial(material);
    userMaterialRole.setUser(user);
    userMaterialRole.setRole(role);

    entityManager.persist(userMaterialRole);

    return userMaterialRole;
  }

	public UserMaterialRole findByMaterialAndUser(Material material, User user) {
		EntityManager entityManager = getEntityManager();

    CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
    CriteriaQuery criteria = criteriaBuilder.createQuery(UserMaterialRole.class);
    Root root = criteria.from(UserMaterialRole.class);
    criteria.select(root);
    criteria.where(
        criteriaBuilder.and(
          criteriaBuilder.equal(root.get(UserMaterialRole_.material), material),
          criteriaBuilder.equal(root.get(UserMaterialRole_.user), user)
        )
    );
    
    return getSingleResult(entityManager.createQuery(criteria));
  }

	public List listByMaterial(Material material) {
		EntityManager entityManager = getEntityManager();

    CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
    CriteriaQuery criteria = criteriaBuilder.createQuery(UserMaterialRole.class);
    Root root = criteria.from(UserMaterialRole.class);
    criteria.select(root);
    criteria.where(
      criteriaBuilder.equal(root.get(UserMaterialRole_.material), material)
    );
    
    return entityManager.createQuery(criteria).getResultList();
  }

	public List listByMaterialAndRole(Material material, MaterialRole role) {
		EntityManager entityManager = getEntityManager();

    CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
    CriteriaQuery criteria = criteriaBuilder.createQuery(UserMaterialRole.class);
    Root root = criteria.from(UserMaterialRole.class);
    criteria.select(root);
    criteria.where(
        criteriaBuilder.and(
          criteriaBuilder.equal(root.get(UserMaterialRole_.material), material),
          criteriaBuilder.equal(root.get(UserMaterialRole_.role), role)
        )
    );
    
    return entityManager.createQuery(criteria).getResultList();
  }

	public UserMaterialRole updateRole(UserMaterialRole userMaterialRole, MaterialRole role) {
		userMaterialRole.setRole(role);
    getEntityManager().persist(userMaterialRole);
    return userMaterialRole;
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy