package fi.otavanopisto.muikku.dao.plugins;
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.otavanopisto.muikku.model.plugins.PluginUserSetting_;
import fi.otavanopisto.muikku.dao.CoreDAO;
import fi.otavanopisto.muikku.model.plugins.PluginUserSetting;
import fi.otavanopisto.muikku.model.plugins.PluginUserSettingKey;
import fi.otavanopisto.muikku.model.users.UserEntity;
public class PluginUserSettingDAO extends CoreDAO<PluginUserSetting> {
private static final long serialVersionUID = 7948864110260023579L;
public PluginUserSetting create(PluginUserSettingKey key, UserEntity user, String value) {
PluginUserSetting pluginUserSetting = new PluginUserSetting();
pluginUserSetting.setKey(key);
pluginUserSetting.setUser(user);
pluginUserSetting.setValue(value);
getEntityManager().persist(pluginUserSetting);
return pluginUserSetting;
}
public PluginUserSetting findByKeyAndUser(PluginUserSettingKey key, UserEntity user) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<PluginUserSetting> criteria = criteriaBuilder.createQuery(PluginUserSetting.class);
Root<PluginUserSetting> root = criteria.from(PluginUserSetting.class);
criteria.select(root);
criteria.where(
criteriaBuilder.and(
criteriaBuilder.equal(root.get(PluginUserSetting_.key), key),
criteriaBuilder.equal(root.get(PluginUserSetting_.user), user)
)
);
return getSingleResult(entityManager.createQuery(criteria));
}
public List<UserEntity> listUsersByKey(PluginUserSettingKey key) {
EntityManager entityManager = getEntityManager();
CriteriaBuilder criteriaBuilder = entityManager.getCriteriaBuilder();
CriteriaQuery<UserEntity> criteria = criteriaBuilder.createQuery(UserEntity.class);
Root<PluginUserSetting> root = criteria.from(PluginUserSetting.class);
criteria.select(root.get(PluginUserSetting_.user));
criteria.where(
criteriaBuilder.equal(root.get(PluginUserSetting_.key), key)
);
return entityManager.createQuery(criteria).getResultList();
}
public PluginUserSetting updateValue(PluginUserSetting pluginUserSetting, String value) {
pluginUserSetting.setValue(value);
getEntityManager().persist(pluginUserSetting);
return pluginUserSetting;
}
}