/** * Copyright (C) 2011 JTalks.org Team * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ package org.jtalks.jcommune.model.dao.hibernate; import org.apache.commons.lang.StringUtils; import org.apache.commons.lang.Validate; import org.hibernate.Query; import org.hibernate.SessionFactory; import org.jtalks.common.model.dao.hibernate.GenericDao; import org.jtalks.common.model.entity.Group; import org.jtalks.common.model.entity.User; import org.jtalks.jcommune.model.dao.GroupDao; import org.jtalks.jcommune.model.dao.utils.SqlLikeEscaper; import org.jtalks.jcommune.model.dto.GroupAdministrationDto; import org.jtalks.jcommune.model.dto.PageRequest; import org.jtalks.jcommune.model.dto.UserDto; import ru.javatalks.utils.general.Assert; import java.util.List; /** * Hibernate implementation of {@link GroupDao} * * @author Vitaliy Kravchenko * @author Pavel Vervenko * @author Leonid Kazancev */ public class GroupHibernateDao extends GenericDao<Group> implements GroupDao { private static final String FIND_GROUP_BY_NAME = "findGroupByName", FIND_ALL_GROUPS = "findAllGroups"; private static final String FIND_EXACTLY_BY_NAME = "findGroupExactlyByName"; /** * @param sessionFactory The SessionFactory. */ public GroupHibernateDao(SessionFactory sessionFactory) { super(sessionFactory, Group.class); } /** * {@inheritDoc} */ @Override @SuppressWarnings("unchecked") public List<Group> getAll() { return session().getNamedQuery("findAllGroups").list(); } /** * {@inheritDoc} */ @SuppressWarnings("unchecked") @Override public List<Group> getMatchedByName(String name) { Validate.notNull(name, "User Group name can't be null"); if (StringUtils.isBlank(name)) { return this.getAll(); } Query query = session().getNamedQuery("findGroupByName"); query.setString("name", SqlLikeEscaper.escapeControlCharacters(name)); return query.list(); } /** * {@inheritDoc} */ @Override public Group getGroupByName(String name) { Validate.notNull(name, "User Group name can't be null"); Query query = session().getNamedQuery("findGroupExactlyByName"); // we should use lower case to search ignoring case query.setString("name", name); return (Group) query.uniqueResult(); } /** * {@inheritDoc} */ @Override public void delete(Group group) { session().update(group); group.getUsers().clear(); saveOrUpdate(group); super.delete(group); } /** * {@inheritDoc} */ @Override public List<Group> getGroupsOfUser(User user) { Assert.throwIfNull(user, "user"); Query query = session().getNamedQuery("findGroupsOfUser"); query.setParameter(0, "%" + user + "%"); return query.list(); } /** * {@inheritDoc} */ @Override public List<Group> getGroupsByIds(List<Long> ids) { return (List<Group>)session().getNamedQuery("getGroupsByIds") .setParameterList("ids", ids).list(); } /** * {@inheritDoc} */ @SuppressWarnings("unchecked") @Override public List<Group> getByNameContains(String name) { Validate.notNull(name, "User Group name can't be null"); if (org.apache.commons.lang3.StringUtils.isBlank(name)) { return this.getAll(); } Query query = session().getNamedQuery(FIND_GROUP_BY_NAME); query.setString("name", SqlLikeEscaper.escapeControlCharacters(name)); return query.list(); } /** * {@inheritDoc} */ @Override public List<Group> getByName(String name) { Validate.notNull(name, "User Group name can't be null"); Query query = session().getNamedQuery(FIND_EXACTLY_BY_NAME); // we should use lower case to search ignoring case query.setString("name", name); return query.list(); } /** * {@inheritDoc} */ @SuppressWarnings("unchecked") @Override public List<GroupAdministrationDto> getGroupNamesWithCountOfUsers() { return (List<GroupAdministrationDto>) session().getNamedQuery("selectGroupsWithUserCount").list(); } @Override public List<UserDto> getGroupUsersPage(long id, PageRequest pageRequest) { Query query = session().getNamedQuery("getUserDTOListFromGroupById"); query.setParameter("id", id); query.setFirstResult(pageRequest.getOffset()).setMaxResults(pageRequest.getPageSize()); return query.list(); } @Override public int getGroupUserCount(long id) { Query query = session().getNamedQuery("getCountUsersInGroup"); query.setParameter("id", id); Number count = (Number) query.uniqueResult(); return count.intValue(); } }