/** * Copyright (c) 2000-present Liferay, Inc. All rights reserved. * * 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. */ package de.uhh.l2g.plugins.service.persistence; import com.liferay.portal.kernel.cache.CacheRegistryUtil; import com.liferay.portal.kernel.dao.orm.EntityCacheUtil; import com.liferay.portal.kernel.dao.orm.FinderCacheUtil; import com.liferay.portal.kernel.dao.orm.FinderPath; import com.liferay.portal.kernel.dao.orm.Query; import com.liferay.portal.kernel.dao.orm.QueryPos; import com.liferay.portal.kernel.dao.orm.QueryUtil; import com.liferay.portal.kernel.dao.orm.Session; import com.liferay.portal.kernel.exception.SystemException; import com.liferay.portal.kernel.log.Log; import com.liferay.portal.kernel.log.LogFactoryUtil; import com.liferay.portal.kernel.util.GetterUtil; import com.liferay.portal.kernel.util.InstanceFactory; import com.liferay.portal.kernel.util.OrderByComparator; import com.liferay.portal.kernel.util.PropsKeys; import com.liferay.portal.kernel.util.PropsUtil; import com.liferay.portal.kernel.util.StringBundler; import com.liferay.portal.kernel.util.StringPool; import com.liferay.portal.kernel.util.StringUtil; import com.liferay.portal.kernel.util.UnmodifiableList; import com.liferay.portal.model.CacheModel; import com.liferay.portal.model.ModelListener; import com.liferay.portal.service.persistence.impl.BasePersistenceImpl; import de.uhh.l2g.plugins.NoSuchHostException; import de.uhh.l2g.plugins.model.Host; import de.uhh.l2g.plugins.model.impl.HostImpl; import de.uhh.l2g.plugins.model.impl.HostModelImpl; import java.io.Serializable; import java.util.ArrayList; import java.util.Collections; import java.util.List; /** * The persistence implementation for the host service. * * <p> * Caching information and settings can be found in <code>portal.properties</code> * </p> * * @author Iavor Sturm * @see HostPersistence * @see HostUtil * @generated */ public class HostPersistenceImpl extends BasePersistenceImpl<Host> implements HostPersistence { /* * NOTE FOR DEVELOPERS: * * Never modify or reference this class directly. Always use {@link HostUtil} to access the host persistence. Modify <code>service.xml</code> and rerun ServiceBuilder to regenerate this class. */ public static final String FINDER_CLASS_NAME_ENTITY = HostImpl.class.getName(); public static final String FINDER_CLASS_NAME_LIST_WITH_PAGINATION = FINDER_CLASS_NAME_ENTITY + ".List1"; public static final String FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION = FINDER_CLASS_NAME_ENTITY + ".List2"; public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_ALL = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findAll", new String[0]); public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_ALL = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findAll", new String[0]); public static final FinderPath FINDER_PATH_COUNT_ALL = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, Long.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countAll", new String[0]); public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_BY_GROUPID = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByGroupId", new String[] { Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }); public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByGroupId", new String[] { Long.class.getName() }, HostModelImpl.GROUPID_COLUMN_BITMASK | HostModelImpl.SERVERROOT_COLUMN_BITMASK); public static final FinderPath FINDER_PATH_COUNT_BY_GROUPID = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, Long.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByGroupId", new String[] { Long.class.getName() }); /** * Returns all the hosts where groupId = ?. * * @param groupId the group ID * @return the matching hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findByGroupId(long groupId) throws SystemException { return findByGroupId(groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the hosts where groupId = ?. * * <p> * Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link de.uhh.l2g.plugins.model.impl.HostModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order. * </p> * * @param groupId the group ID * @param start the lower bound of the range of hosts * @param end the upper bound of the range of hosts (not inclusive) * @return the range of matching hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findByGroupId(long groupId, int start, int end) throws SystemException { return findByGroupId(groupId, start, end, null); } /** * Returns an ordered range of all the hosts where groupId = ?. * * <p> * Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link de.uhh.l2g.plugins.model.impl.HostModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order. * </p> * * @param groupId the group ID * @param start the lower bound of the range of hosts * @param end the upper bound of the range of hosts (not inclusive) * @param orderByComparator the comparator to order the results by (optionally <code>null</code>) * @return the ordered range of matching hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findByGroupId(long groupId, int start, int end, OrderByComparator orderByComparator) throws SystemException { boolean pagination = true; FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { pagination = false; finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID; finderArgs = new Object[] { groupId }; } else { finderPath = FINDER_PATH_WITH_PAGINATION_FIND_BY_GROUPID; finderArgs = new Object[] { groupId, start, end, orderByComparator }; } List<Host> list = (List<Host>)FinderCacheUtil.getResult(finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (Host host : list) { if ((groupId != host.getGroupId())) { list = null; break; } } } if (list == null) { StringBundler query = null; if (orderByComparator != null) { query = new StringBundler(3 + (orderByComparator.getOrderByFields().length * 3)); } else { query = new StringBundler(3); } query.append(_SQL_SELECT_HOST_WHERE); query.append(_FINDER_COLUMN_GROUPID_GROUPID_2); if (orderByComparator != null) { appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else if (pagination) { query.append(HostModelImpl.ORDER_BY_JPQL); } String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(groupId); if (!pagination) { list = (List<Host>)QueryUtil.list(q, getDialect(), start, end, false); Collections.sort(list); list = new UnmodifiableList<Host>(list); } else { list = (List<Host>)QueryUtil.list(q, getDialect(), start, end); } cacheResult(list); FinderCacheUtil.putResult(finderPath, finderArgs, list); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return list; } /** * Returns the first host in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the first matching host * @throws de.uhh.l2g.plugins.NoSuchHostException if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByGroupId_First(long groupId, OrderByComparator orderByComparator) throws NoSuchHostException, SystemException { Host host = fetchByGroupId_First(groupId, orderByComparator); if (host != null) { return host; } StringBundler msg = new StringBundler(4); msg.append(_NO_SUCH_ENTITY_WITH_KEY); msg.append("groupId="); msg.append(groupId); msg.append(StringPool.CLOSE_CURLY_BRACE); throw new NoSuchHostException(msg.toString()); } /** * Returns the first host in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the first matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByGroupId_First(long groupId, OrderByComparator orderByComparator) throws SystemException { List<Host> list = findByGroupId(groupId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last host in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the last matching host * @throws de.uhh.l2g.plugins.NoSuchHostException if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByGroupId_Last(long groupId, OrderByComparator orderByComparator) throws NoSuchHostException, SystemException { Host host = fetchByGroupId_Last(groupId, orderByComparator); if (host != null) { return host; } StringBundler msg = new StringBundler(4); msg.append(_NO_SUCH_ENTITY_WITH_KEY); msg.append("groupId="); msg.append(groupId); msg.append(StringPool.CLOSE_CURLY_BRACE); throw new NoSuchHostException(msg.toString()); } /** * Returns the last host in the ordered set where groupId = ?. * * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the last matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByGroupId_Last(long groupId, OrderByComparator orderByComparator) throws SystemException { int count = countByGroupId(groupId); if (count == 0) { return null; } List<Host> list = findByGroupId(groupId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the hosts before and after the current host in the ordered set where groupId = ?. * * @param hostId the primary key of the current host * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the previous, current, and next host * @throws de.uhh.l2g.plugins.NoSuchHostException if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host[] findByGroupId_PrevAndNext(long hostId, long groupId, OrderByComparator orderByComparator) throws NoSuchHostException, SystemException { Host host = findByPrimaryKey(hostId); Session session = null; try { session = openSession(); Host[] array = new HostImpl[3]; array[0] = getByGroupId_PrevAndNext(session, host, groupId, orderByComparator, true); array[1] = host; array[2] = getByGroupId_PrevAndNext(session, host, groupId, orderByComparator, false); return array; } catch (Exception e) { throw processException(e); } finally { closeSession(session); } } protected Host getByGroupId_PrevAndNext(Session session, Host host, long groupId, OrderByComparator orderByComparator, boolean previous) { StringBundler query = null; if (orderByComparator != null) { query = new StringBundler(6 + (orderByComparator.getOrderByFields().length * 6)); } else { query = new StringBundler(3); } query.append(_SQL_SELECT_HOST_WHERE); query.append(_FINDER_COLUMN_GROUPID_GROUPID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { query.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { query.append(_ORDER_BY_ENTITY_ALIAS); query.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { query.append(WHERE_GREATER_THAN_HAS_NEXT); } else { query.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { query.append(WHERE_GREATER_THAN); } else { query.append(WHERE_LESSER_THAN); } } } query.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { query.append(_ORDER_BY_ENTITY_ALIAS); query.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { query.append(ORDER_BY_ASC_HAS_NEXT); } else { query.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { query.append(ORDER_BY_ASC); } else { query.append(ORDER_BY_DESC); } } } } else { query.append(HostModelImpl.ORDER_BY_JPQL); } String sql = query.toString(); Query q = session.createQuery(sql); q.setFirstResult(0); q.setMaxResults(2); QueryPos qPos = QueryPos.getInstance(q); qPos.add(groupId); if (orderByComparator != null) { Object[] values = orderByComparator.getOrderByConditionValues(host); for (Object value : values) { qPos.add(value); } } List<Host> list = q.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the hosts where groupId = ? from the database. * * @param groupId the group ID * @throws SystemException if a system exception occurred */ @Override public void removeByGroupId(long groupId) throws SystemException { for (Host host : findByGroupId(groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(host); } } /** * Returns the number of hosts where groupId = ?. * * @param groupId the group ID * @return the number of matching hosts * @throws SystemException if a system exception occurred */ @Override public int countByGroupId(long groupId) throws SystemException { FinderPath finderPath = FINDER_PATH_COUNT_BY_GROUPID; Object[] finderArgs = new Object[] { groupId }; Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs, this); if (count == null) { StringBundler query = new StringBundler(2); query.append(_SQL_COUNT_HOST_WHERE); query.append(_FINDER_COLUMN_GROUPID_GROUPID_2); String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(groupId); count = (Long)q.uniqueResult(); FinderCacheUtil.putResult(finderPath, finderArgs, count); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return count.intValue(); } private static final String _FINDER_COLUMN_GROUPID_GROUPID_2 = "host.groupId = ?"; public static final FinderPath FINDER_PATH_WITH_PAGINATION_FIND_BY_COMPANYIDANDGROUPID = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_LIST_WITH_PAGINATION, "findByCompanyIdAndGroupId", new String[] { Long.class.getName(), Long.class.getName(), Integer.class.getName(), Integer.class.getName(), OrderByComparator.class.getName() }); public static final FinderPath FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYIDANDGROUPID = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "findByCompanyIdAndGroupId", new String[] { Long.class.getName(), Long.class.getName() }, HostModelImpl.COMPANYID_COLUMN_BITMASK | HostModelImpl.GROUPID_COLUMN_BITMASK | HostModelImpl.SERVERROOT_COLUMN_BITMASK); public static final FinderPath FINDER_PATH_COUNT_BY_COMPANYIDANDGROUPID = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, Long.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByCompanyIdAndGroupId", new String[] { Long.class.getName(), Long.class.getName() }); /** * Returns all the hosts where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @return the matching hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findByCompanyIdAndGroupId(long companyId, long groupId) throws SystemException { return findByCompanyIdAndGroupId(companyId, groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the hosts where companyId = ? and groupId = ?. * * <p> * Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link de.uhh.l2g.plugins.model.impl.HostModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order. * </p> * * @param companyId the company ID * @param groupId the group ID * @param start the lower bound of the range of hosts * @param end the upper bound of the range of hosts (not inclusive) * @return the range of matching hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findByCompanyIdAndGroupId(long companyId, long groupId, int start, int end) throws SystemException { return findByCompanyIdAndGroupId(companyId, groupId, start, end, null); } /** * Returns an ordered range of all the hosts where companyId = ? and groupId = ?. * * <p> * Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link de.uhh.l2g.plugins.model.impl.HostModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order. * </p> * * @param companyId the company ID * @param groupId the group ID * @param start the lower bound of the range of hosts * @param end the upper bound of the range of hosts (not inclusive) * @param orderByComparator the comparator to order the results by (optionally <code>null</code>) * @return the ordered range of matching hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findByCompanyIdAndGroupId(long companyId, long groupId, int start, int end, OrderByComparator orderByComparator) throws SystemException { boolean pagination = true; FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { pagination = false; finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYIDANDGROUPID; finderArgs = new Object[] { companyId, groupId }; } else { finderPath = FINDER_PATH_WITH_PAGINATION_FIND_BY_COMPANYIDANDGROUPID; finderArgs = new Object[] { companyId, groupId, start, end, orderByComparator }; } List<Host> list = (List<Host>)FinderCacheUtil.getResult(finderPath, finderArgs, this); if ((list != null) && !list.isEmpty()) { for (Host host : list) { if ((companyId != host.getCompanyId()) || (groupId != host.getGroupId())) { list = null; break; } } } if (list == null) { StringBundler query = null; if (orderByComparator != null) { query = new StringBundler(4 + (orderByComparator.getOrderByFields().length * 3)); } else { query = new StringBundler(4); } query.append(_SQL_SELECT_HOST_WHERE); query.append(_FINDER_COLUMN_COMPANYIDANDGROUPID_COMPANYID_2); query.append(_FINDER_COLUMN_COMPANYIDANDGROUPID_GROUPID_2); if (orderByComparator != null) { appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS, orderByComparator); } else if (pagination) { query.append(HostModelImpl.ORDER_BY_JPQL); } String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(companyId); qPos.add(groupId); if (!pagination) { list = (List<Host>)QueryUtil.list(q, getDialect(), start, end, false); Collections.sort(list); list = new UnmodifiableList<Host>(list); } else { list = (List<Host>)QueryUtil.list(q, getDialect(), start, end); } cacheResult(list); FinderCacheUtil.putResult(finderPath, finderArgs, list); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return list; } /** * Returns the first host in the ordered set where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the first matching host * @throws de.uhh.l2g.plugins.NoSuchHostException if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByCompanyIdAndGroupId_First(long companyId, long groupId, OrderByComparator orderByComparator) throws NoSuchHostException, SystemException { Host host = fetchByCompanyIdAndGroupId_First(companyId, groupId, orderByComparator); if (host != null) { return host; } StringBundler msg = new StringBundler(6); msg.append(_NO_SUCH_ENTITY_WITH_KEY); msg.append("companyId="); msg.append(companyId); msg.append(", groupId="); msg.append(groupId); msg.append(StringPool.CLOSE_CURLY_BRACE); throw new NoSuchHostException(msg.toString()); } /** * Returns the first host in the ordered set where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the first matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByCompanyIdAndGroupId_First(long companyId, long groupId, OrderByComparator orderByComparator) throws SystemException { List<Host> list = findByCompanyIdAndGroupId(companyId, groupId, 0, 1, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the last host in the ordered set where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the last matching host * @throws de.uhh.l2g.plugins.NoSuchHostException if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByCompanyIdAndGroupId_Last(long companyId, long groupId, OrderByComparator orderByComparator) throws NoSuchHostException, SystemException { Host host = fetchByCompanyIdAndGroupId_Last(companyId, groupId, orderByComparator); if (host != null) { return host; } StringBundler msg = new StringBundler(6); msg.append(_NO_SUCH_ENTITY_WITH_KEY); msg.append("companyId="); msg.append(companyId); msg.append(", groupId="); msg.append(groupId); msg.append(StringPool.CLOSE_CURLY_BRACE); throw new NoSuchHostException(msg.toString()); } /** * Returns the last host in the ordered set where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the last matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByCompanyIdAndGroupId_Last(long companyId, long groupId, OrderByComparator orderByComparator) throws SystemException { int count = countByCompanyIdAndGroupId(companyId, groupId); if (count == 0) { return null; } List<Host> list = findByCompanyIdAndGroupId(companyId, groupId, count - 1, count, orderByComparator); if (!list.isEmpty()) { return list.get(0); } return null; } /** * Returns the hosts before and after the current host in the ordered set where companyId = ? and groupId = ?. * * @param hostId the primary key of the current host * @param companyId the company ID * @param groupId the group ID * @param orderByComparator the comparator to order the set by (optionally <code>null</code>) * @return the previous, current, and next host * @throws de.uhh.l2g.plugins.NoSuchHostException if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host[] findByCompanyIdAndGroupId_PrevAndNext(long hostId, long companyId, long groupId, OrderByComparator orderByComparator) throws NoSuchHostException, SystemException { Host host = findByPrimaryKey(hostId); Session session = null; try { session = openSession(); Host[] array = new HostImpl[3]; array[0] = getByCompanyIdAndGroupId_PrevAndNext(session, host, companyId, groupId, orderByComparator, true); array[1] = host; array[2] = getByCompanyIdAndGroupId_PrevAndNext(session, host, companyId, groupId, orderByComparator, false); return array; } catch (Exception e) { throw processException(e); } finally { closeSession(session); } } protected Host getByCompanyIdAndGroupId_PrevAndNext(Session session, Host host, long companyId, long groupId, OrderByComparator orderByComparator, boolean previous) { StringBundler query = null; if (orderByComparator != null) { query = new StringBundler(6 + (orderByComparator.getOrderByFields().length * 6)); } else { query = new StringBundler(3); } query.append(_SQL_SELECT_HOST_WHERE); query.append(_FINDER_COLUMN_COMPANYIDANDGROUPID_COMPANYID_2); query.append(_FINDER_COLUMN_COMPANYIDANDGROUPID_GROUPID_2); if (orderByComparator != null) { String[] orderByConditionFields = orderByComparator.getOrderByConditionFields(); if (orderByConditionFields.length > 0) { query.append(WHERE_AND); } for (int i = 0; i < orderByConditionFields.length; i++) { query.append(_ORDER_BY_ENTITY_ALIAS); query.append(orderByConditionFields[i]); if ((i + 1) < orderByConditionFields.length) { if (orderByComparator.isAscending() ^ previous) { query.append(WHERE_GREATER_THAN_HAS_NEXT); } else { query.append(WHERE_LESSER_THAN_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { query.append(WHERE_GREATER_THAN); } else { query.append(WHERE_LESSER_THAN); } } } query.append(ORDER_BY_CLAUSE); String[] orderByFields = orderByComparator.getOrderByFields(); for (int i = 0; i < orderByFields.length; i++) { query.append(_ORDER_BY_ENTITY_ALIAS); query.append(orderByFields[i]); if ((i + 1) < orderByFields.length) { if (orderByComparator.isAscending() ^ previous) { query.append(ORDER_BY_ASC_HAS_NEXT); } else { query.append(ORDER_BY_DESC_HAS_NEXT); } } else { if (orderByComparator.isAscending() ^ previous) { query.append(ORDER_BY_ASC); } else { query.append(ORDER_BY_DESC); } } } } else { query.append(HostModelImpl.ORDER_BY_JPQL); } String sql = query.toString(); Query q = session.createQuery(sql); q.setFirstResult(0); q.setMaxResults(2); QueryPos qPos = QueryPos.getInstance(q); qPos.add(companyId); qPos.add(groupId); if (orderByComparator != null) { Object[] values = orderByComparator.getOrderByConditionValues(host); for (Object value : values) { qPos.add(value); } } List<Host> list = q.list(); if (list.size() == 2) { return list.get(1); } else { return null; } } /** * Removes all the hosts where companyId = ? and groupId = ? from the database. * * @param companyId the company ID * @param groupId the group ID * @throws SystemException if a system exception occurred */ @Override public void removeByCompanyIdAndGroupId(long companyId, long groupId) throws SystemException { for (Host host : findByCompanyIdAndGroupId(companyId, groupId, QueryUtil.ALL_POS, QueryUtil.ALL_POS, null)) { remove(host); } } /** * Returns the number of hosts where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @return the number of matching hosts * @throws SystemException if a system exception occurred */ @Override public int countByCompanyIdAndGroupId(long companyId, long groupId) throws SystemException { FinderPath finderPath = FINDER_PATH_COUNT_BY_COMPANYIDANDGROUPID; Object[] finderArgs = new Object[] { companyId, groupId }; Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs, this); if (count == null) { StringBundler query = new StringBundler(3); query.append(_SQL_COUNT_HOST_WHERE); query.append(_FINDER_COLUMN_COMPANYIDANDGROUPID_COMPANYID_2); query.append(_FINDER_COLUMN_COMPANYIDANDGROUPID_GROUPID_2); String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(companyId); qPos.add(groupId); count = (Long)q.uniqueResult(); FinderCacheUtil.putResult(finderPath, finderArgs, count); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return count.intValue(); } private static final String _FINDER_COLUMN_COMPANYIDANDGROUPID_COMPANYID_2 = "host.companyId = ? AND "; private static final String _FINDER_COLUMN_COMPANYIDANDGROUPID_GROUPID_2 = "host.groupId = ?"; public static final FinderPath FINDER_PATH_FETCH_BY_G_H = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_ENTITY, "fetchByG_H", new String[] { Long.class.getName(), Long.class.getName() }, HostModelImpl.GROUPID_COLUMN_BITMASK | HostModelImpl.HOSTID_COLUMN_BITMASK); public static final FinderPath FINDER_PATH_COUNT_BY_G_H = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, Long.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByG_H", new String[] { Long.class.getName(), Long.class.getName() }); /** * Returns the host where groupId = ? and hostId = ? or throws a {@link de.uhh.l2g.plugins.NoSuchHostException} if it could not be found. * * @param groupId the group ID * @param hostId the host ID * @return the matching host * @throws de.uhh.l2g.plugins.NoSuchHostException if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByG_H(long groupId, long hostId) throws NoSuchHostException, SystemException { Host host = fetchByG_H(groupId, hostId); if (host == null) { StringBundler msg = new StringBundler(6); msg.append(_NO_SUCH_ENTITY_WITH_KEY); msg.append("groupId="); msg.append(groupId); msg.append(", hostId="); msg.append(hostId); msg.append(StringPool.CLOSE_CURLY_BRACE); if (_log.isWarnEnabled()) { _log.warn(msg.toString()); } throw new NoSuchHostException(msg.toString()); } return host; } /** * Returns the host where groupId = ? and hostId = ? or returns <code>null</code> if it could not be found. Uses the finder cache. * * @param groupId the group ID * @param hostId the host ID * @return the matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByG_H(long groupId, long hostId) throws SystemException { return fetchByG_H(groupId, hostId, true); } /** * Returns the host where groupId = ? and hostId = ? or returns <code>null</code> if it could not be found, optionally using the finder cache. * * @param groupId the group ID * @param hostId the host ID * @param retrieveFromCache whether to use the finder cache * @return the matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByG_H(long groupId, long hostId, boolean retrieveFromCache) throws SystemException { Object[] finderArgs = new Object[] { groupId, hostId }; Object result = null; if (retrieveFromCache) { result = FinderCacheUtil.getResult(FINDER_PATH_FETCH_BY_G_H, finderArgs, this); } if (result instanceof Host) { Host host = (Host)result; if ((groupId != host.getGroupId()) || (hostId != host.getHostId())) { result = null; } } if (result == null) { StringBundler query = new StringBundler(4); query.append(_SQL_SELECT_HOST_WHERE); query.append(_FINDER_COLUMN_G_H_GROUPID_2); query.append(_FINDER_COLUMN_G_H_HOSTID_2); String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(groupId); qPos.add(hostId); List<Host> list = q.list(); if (list.isEmpty()) { FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_G_H, finderArgs, list); } else { if ((list.size() > 1) && _log.isWarnEnabled()) { _log.warn( "HostPersistenceImpl.fetchByG_H(long, long, boolean) with parameters (" + StringUtil.merge(finderArgs) + ") yields a result set with more than 1 result. This violates the logical unique restriction. There is no order guarantee on which result is returned by this finder."); } Host host = list.get(0); result = host; cacheResult(host); if ((host.getGroupId() != groupId) || (host.getHostId() != hostId)) { FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_G_H, finderArgs, host); } } } catch (Exception e) { FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_G_H, finderArgs); throw processException(e); } finally { closeSession(session); } } if (result instanceof List<?>) { return null; } else { return (Host)result; } } /** * Removes the host where groupId = ? and hostId = ? from the database. * * @param groupId the group ID * @param hostId the host ID * @return the host that was removed * @throws SystemException if a system exception occurred */ @Override public Host removeByG_H(long groupId, long hostId) throws NoSuchHostException, SystemException { Host host = findByG_H(groupId, hostId); return remove(host); } /** * Returns the number of hosts where groupId = ? and hostId = ?. * * @param groupId the group ID * @param hostId the host ID * @return the number of matching hosts * @throws SystemException if a system exception occurred */ @Override public int countByG_H(long groupId, long hostId) throws SystemException { FinderPath finderPath = FINDER_PATH_COUNT_BY_G_H; Object[] finderArgs = new Object[] { groupId, hostId }; Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs, this); if (count == null) { StringBundler query = new StringBundler(3); query.append(_SQL_COUNT_HOST_WHERE); query.append(_FINDER_COLUMN_G_H_GROUPID_2); query.append(_FINDER_COLUMN_G_H_HOSTID_2); String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(groupId); qPos.add(hostId); count = (Long)q.uniqueResult(); FinderCacheUtil.putResult(finderPath, finderArgs, count); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return count.intValue(); } private static final String _FINDER_COLUMN_G_H_GROUPID_2 = "host.groupId = ? AND "; private static final String _FINDER_COLUMN_G_H_HOSTID_2 = "host.hostId = ?"; public static final FinderPath FINDER_PATH_FETCH_BY_DEFAULTHOST = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, HostImpl.class, FINDER_CLASS_NAME_ENTITY, "fetchByDefaultHost", new String[] { Long.class.getName(), Long.class.getName() }, HostModelImpl.COMPANYID_COLUMN_BITMASK | HostModelImpl.GROUPID_COLUMN_BITMASK); public static final FinderPath FINDER_PATH_COUNT_BY_DEFAULTHOST = new FinderPath(HostModelImpl.ENTITY_CACHE_ENABLED, HostModelImpl.FINDER_CACHE_ENABLED, Long.class, FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION, "countByDefaultHost", new String[] { Long.class.getName(), Long.class.getName() }); /** * Returns the host where companyId = ? and groupId = ? or throws a {@link de.uhh.l2g.plugins.NoSuchHostException} if it could not be found. * * @param companyId the company ID * @param groupId the group ID * @return the matching host * @throws de.uhh.l2g.plugins.NoSuchHostException if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByDefaultHost(long companyId, long groupId) throws NoSuchHostException, SystemException { Host host = fetchByDefaultHost(companyId, groupId); if (host == null) { StringBundler msg = new StringBundler(6); msg.append(_NO_SUCH_ENTITY_WITH_KEY); msg.append("companyId="); msg.append(companyId); msg.append(", groupId="); msg.append(groupId); msg.append(StringPool.CLOSE_CURLY_BRACE); if (_log.isWarnEnabled()) { _log.warn(msg.toString()); } throw new NoSuchHostException(msg.toString()); } return host; } /** * Returns the host where companyId = ? and groupId = ? or returns <code>null</code> if it could not be found. Uses the finder cache. * * @param companyId the company ID * @param groupId the group ID * @return the matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByDefaultHost(long companyId, long groupId) throws SystemException { return fetchByDefaultHost(companyId, groupId, true); } /** * Returns the host where companyId = ? and groupId = ? or returns <code>null</code> if it could not be found, optionally using the finder cache. * * @param companyId the company ID * @param groupId the group ID * @param retrieveFromCache whether to use the finder cache * @return the matching host, or <code>null</code> if a matching host could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByDefaultHost(long companyId, long groupId, boolean retrieveFromCache) throws SystemException { Object[] finderArgs = new Object[] { companyId, groupId }; Object result = null; if (retrieveFromCache) { result = FinderCacheUtil.getResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, finderArgs, this); } if (result instanceof Host) { Host host = (Host)result; if ((companyId != host.getCompanyId()) || (groupId != host.getGroupId())) { result = null; } } if (result == null) { StringBundler query = new StringBundler(4); query.append(_SQL_SELECT_HOST_WHERE); query.append(_FINDER_COLUMN_DEFAULTHOST_COMPANYID_2); query.append(_FINDER_COLUMN_DEFAULTHOST_GROUPID_2); String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(companyId); qPos.add(groupId); List<Host> list = q.list(); if (list.isEmpty()) { FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, finderArgs, list); } else { if ((list.size() > 1) && _log.isWarnEnabled()) { _log.warn( "HostPersistenceImpl.fetchByDefaultHost(long, long, boolean) with parameters (" + StringUtil.merge(finderArgs) + ") yields a result set with more than 1 result. This violates the logical unique restriction. There is no order guarantee on which result is returned by this finder."); } Host host = list.get(0); result = host; cacheResult(host); if ((host.getCompanyId() != companyId) || (host.getGroupId() != groupId)) { FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, finderArgs, host); } } } catch (Exception e) { FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, finderArgs); throw processException(e); } finally { closeSession(session); } } if (result instanceof List<?>) { return null; } else { return (Host)result; } } /** * Removes the host where companyId = ? and groupId = ? from the database. * * @param companyId the company ID * @param groupId the group ID * @return the host that was removed * @throws SystemException if a system exception occurred */ @Override public Host removeByDefaultHost(long companyId, long groupId) throws NoSuchHostException, SystemException { Host host = findByDefaultHost(companyId, groupId); return remove(host); } /** * Returns the number of hosts where companyId = ? and groupId = ?. * * @param companyId the company ID * @param groupId the group ID * @return the number of matching hosts * @throws SystemException if a system exception occurred */ @Override public int countByDefaultHost(long companyId, long groupId) throws SystemException { FinderPath finderPath = FINDER_PATH_COUNT_BY_DEFAULTHOST; Object[] finderArgs = new Object[] { companyId, groupId }; Long count = (Long)FinderCacheUtil.getResult(finderPath, finderArgs, this); if (count == null) { StringBundler query = new StringBundler(3); query.append(_SQL_COUNT_HOST_WHERE); query.append(_FINDER_COLUMN_DEFAULTHOST_COMPANYID_2); query.append(_FINDER_COLUMN_DEFAULTHOST_GROUPID_2); String sql = query.toString(); Session session = null; try { session = openSession(); Query q = session.createQuery(sql); QueryPos qPos = QueryPos.getInstance(q); qPos.add(companyId); qPos.add(groupId); count = (Long)q.uniqueResult(); FinderCacheUtil.putResult(finderPath, finderArgs, count); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return count.intValue(); } private static final String _FINDER_COLUMN_DEFAULTHOST_COMPANYID_2 = "host.companyId = ? AND "; private static final String _FINDER_COLUMN_DEFAULTHOST_GROUPID_2 = "host.groupId = ? AND host.defaultHost > 0"; public HostPersistenceImpl() { setModelClass(Host.class); } /** * Caches the host in the entity cache if it is enabled. * * @param host the host */ @Override public void cacheResult(Host host) { EntityCacheUtil.putResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, host.getPrimaryKey(), host); FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_G_H, new Object[] { host.getGroupId(), host.getHostId() }, host); FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, new Object[] { host.getCompanyId(), host.getGroupId() }, host); host.resetOriginalValues(); } /** * Caches the hosts in the entity cache if it is enabled. * * @param hosts the hosts */ @Override public void cacheResult(List<Host> hosts) { for (Host host : hosts) { if (EntityCacheUtil.getResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, host.getPrimaryKey()) == null) { cacheResult(host); } else { host.resetOriginalValues(); } } } /** * Clears the cache for all hosts. * * <p> * The {@link com.liferay.portal.kernel.dao.orm.EntityCache} and {@link com.liferay.portal.kernel.dao.orm.FinderCache} are both cleared by this method. * </p> */ @Override public void clearCache() { if (_HIBERNATE_CACHE_USE_SECOND_LEVEL_CACHE) { CacheRegistryUtil.clear(HostImpl.class.getName()); } EntityCacheUtil.clearCache(HostImpl.class.getName()); FinderCacheUtil.clearCache(FINDER_CLASS_NAME_ENTITY); FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION); FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION); } /** * Clears the cache for the host. * * <p> * The {@link com.liferay.portal.kernel.dao.orm.EntityCache} and {@link com.liferay.portal.kernel.dao.orm.FinderCache} are both cleared by this method. * </p> */ @Override public void clearCache(Host host) { EntityCacheUtil.removeResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, host.getPrimaryKey()); FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION); FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION); clearUniqueFindersCache(host); } @Override public void clearCache(List<Host> hosts) { FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION); FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION); for (Host host : hosts) { EntityCacheUtil.removeResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, host.getPrimaryKey()); clearUniqueFindersCache(host); } } protected void cacheUniqueFindersCache(Host host) { if (host.isNew()) { Object[] args = new Object[] { host.getGroupId(), host.getHostId() }; FinderCacheUtil.putResult(FINDER_PATH_COUNT_BY_G_H, args, Long.valueOf(1)); FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_G_H, args, host); args = new Object[] { host.getCompanyId(), host.getGroupId() }; FinderCacheUtil.putResult(FINDER_PATH_COUNT_BY_DEFAULTHOST, args, Long.valueOf(1)); FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, args, host); } else { HostModelImpl hostModelImpl = (HostModelImpl)host; if ((hostModelImpl.getColumnBitmask() & FINDER_PATH_FETCH_BY_G_H.getColumnBitmask()) != 0) { Object[] args = new Object[] { host.getGroupId(), host.getHostId() }; FinderCacheUtil.putResult(FINDER_PATH_COUNT_BY_G_H, args, Long.valueOf(1)); FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_G_H, args, host); } if ((hostModelImpl.getColumnBitmask() & FINDER_PATH_FETCH_BY_DEFAULTHOST.getColumnBitmask()) != 0) { Object[] args = new Object[] { host.getCompanyId(), host.getGroupId() }; FinderCacheUtil.putResult(FINDER_PATH_COUNT_BY_DEFAULTHOST, args, Long.valueOf(1)); FinderCacheUtil.putResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, args, host); } } } protected void clearUniqueFindersCache(Host host) { HostModelImpl hostModelImpl = (HostModelImpl)host; Object[] args = new Object[] { host.getGroupId(), host.getHostId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_G_H, args); FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_G_H, args); if ((hostModelImpl.getColumnBitmask() & FINDER_PATH_FETCH_BY_G_H.getColumnBitmask()) != 0) { args = new Object[] { hostModelImpl.getOriginalGroupId(), hostModelImpl.getOriginalHostId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_G_H, args); FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_G_H, args); } args = new Object[] { host.getCompanyId(), host.getGroupId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_DEFAULTHOST, args); FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, args); if ((hostModelImpl.getColumnBitmask() & FINDER_PATH_FETCH_BY_DEFAULTHOST.getColumnBitmask()) != 0) { args = new Object[] { hostModelImpl.getOriginalCompanyId(), hostModelImpl.getOriginalGroupId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_DEFAULTHOST, args); FinderCacheUtil.removeResult(FINDER_PATH_FETCH_BY_DEFAULTHOST, args); } } /** * Creates a new host with the primary key. Does not add the host to the database. * * @param hostId the primary key for the new host * @return the new host */ @Override public Host create(long hostId) { Host host = new HostImpl(); host.setNew(true); host.setPrimaryKey(hostId); return host; } /** * Removes the host with the primary key from the database. Also notifies the appropriate model listeners. * * @param hostId the primary key of the host * @return the host that was removed * @throws de.uhh.l2g.plugins.NoSuchHostException if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host remove(long hostId) throws NoSuchHostException, SystemException { return remove((Serializable)hostId); } /** * Removes the host with the primary key from the database. Also notifies the appropriate model listeners. * * @param primaryKey the primary key of the host * @return the host that was removed * @throws de.uhh.l2g.plugins.NoSuchHostException if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host remove(Serializable primaryKey) throws NoSuchHostException, SystemException { Session session = null; try { session = openSession(); Host host = (Host)session.get(HostImpl.class, primaryKey); if (host == null) { if (_log.isWarnEnabled()) { _log.warn(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } throw new NoSuchHostException(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } return remove(host); } catch (NoSuchHostException nsee) { throw nsee; } catch (Exception e) { throw processException(e); } finally { closeSession(session); } } @Override protected Host removeImpl(Host host) throws SystemException { host = toUnwrappedModel(host); Session session = null; try { session = openSession(); if (!session.contains(host)) { host = (Host)session.get(HostImpl.class, host.getPrimaryKeyObj()); } if (host != null) { session.delete(host); } } catch (Exception e) { throw processException(e); } finally { closeSession(session); } if (host != null) { clearCache(host); } return host; } @Override public Host updateImpl(de.uhh.l2g.plugins.model.Host host) throws SystemException { host = toUnwrappedModel(host); boolean isNew = host.isNew(); HostModelImpl hostModelImpl = (HostModelImpl)host; Session session = null; try { session = openSession(); if (host.isNew()) { session.save(host); host.setNew(false); } else { session.merge(host); } } catch (Exception e) { throw processException(e); } finally { closeSession(session); } FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION); if (isNew || !HostModelImpl.COLUMN_BITMASK_ENABLED) { FinderCacheUtil.clearCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION); } else { if ((hostModelImpl.getColumnBitmask() & FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID.getColumnBitmask()) != 0) { Object[] args = new Object[] { hostModelImpl.getOriginalGroupId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_GROUPID, args); FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID, args); args = new Object[] { hostModelImpl.getGroupId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_GROUPID, args); FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_GROUPID, args); } if ((hostModelImpl.getColumnBitmask() & FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYIDANDGROUPID.getColumnBitmask()) != 0) { Object[] args = new Object[] { hostModelImpl.getOriginalCompanyId(), hostModelImpl.getOriginalGroupId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_COMPANYIDANDGROUPID, args); FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYIDANDGROUPID, args); args = new Object[] { hostModelImpl.getCompanyId(), hostModelImpl.getGroupId() }; FinderCacheUtil.removeResult(FINDER_PATH_COUNT_BY_COMPANYIDANDGROUPID, args); FinderCacheUtil.removeResult(FINDER_PATH_WITHOUT_PAGINATION_FIND_BY_COMPANYIDANDGROUPID, args); } } EntityCacheUtil.putResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, host.getPrimaryKey(), host); clearUniqueFindersCache(host); cacheUniqueFindersCache(host); return host; } protected Host toUnwrappedModel(Host host) { if (host instanceof HostImpl) { return host; } HostImpl hostImpl = new HostImpl(); hostImpl.setNew(host.isNew()); hostImpl.setPrimaryKey(host.getPrimaryKey()); hostImpl.setHostId(host.getHostId()); hostImpl.setProtocol(host.getProtocol()); hostImpl.setStreamer(host.getStreamer()); hostImpl.setPort(host.getPort()); hostImpl.setServerRoot(host.getServerRoot()); hostImpl.setName(host.getName()); hostImpl.setGroupId(host.getGroupId()); hostImpl.setCompanyId(host.getCompanyId()); hostImpl.setDefaultHost(host.getDefaultHost()); return hostImpl; } /** * Returns the host with the primary key or throws a {@link com.liferay.portal.NoSuchModelException} if it could not be found. * * @param primaryKey the primary key of the host * @return the host * @throws de.uhh.l2g.plugins.NoSuchHostException if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByPrimaryKey(Serializable primaryKey) throws NoSuchHostException, SystemException { Host host = fetchByPrimaryKey(primaryKey); if (host == null) { if (_log.isWarnEnabled()) { _log.warn(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } throw new NoSuchHostException(_NO_SUCH_ENTITY_WITH_PRIMARY_KEY + primaryKey); } return host; } /** * Returns the host with the primary key or throws a {@link de.uhh.l2g.plugins.NoSuchHostException} if it could not be found. * * @param hostId the primary key of the host * @return the host * @throws de.uhh.l2g.plugins.NoSuchHostException if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host findByPrimaryKey(long hostId) throws NoSuchHostException, SystemException { return findByPrimaryKey((Serializable)hostId); } /** * Returns the host with the primary key or returns <code>null</code> if it could not be found. * * @param primaryKey the primary key of the host * @return the host, or <code>null</code> if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByPrimaryKey(Serializable primaryKey) throws SystemException { Host host = (Host)EntityCacheUtil.getResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, primaryKey); if (host == _nullHost) { return null; } if (host == null) { Session session = null; try { session = openSession(); host = (Host)session.get(HostImpl.class, primaryKey); if (host != null) { cacheResult(host); } else { EntityCacheUtil.putResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, primaryKey, _nullHost); } } catch (Exception e) { EntityCacheUtil.removeResult(HostModelImpl.ENTITY_CACHE_ENABLED, HostImpl.class, primaryKey); throw processException(e); } finally { closeSession(session); } } return host; } /** * Returns the host with the primary key or returns <code>null</code> if it could not be found. * * @param hostId the primary key of the host * @return the host, or <code>null</code> if a host with the primary key could not be found * @throws SystemException if a system exception occurred */ @Override public Host fetchByPrimaryKey(long hostId) throws SystemException { return fetchByPrimaryKey((Serializable)hostId); } /** * Returns all the hosts. * * @return the hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findAll() throws SystemException { return findAll(QueryUtil.ALL_POS, QueryUtil.ALL_POS, null); } /** * Returns a range of all the hosts. * * <p> * Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link de.uhh.l2g.plugins.model.impl.HostModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order. * </p> * * @param start the lower bound of the range of hosts * @param end the upper bound of the range of hosts (not inclusive) * @return the range of hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findAll(int start, int end) throws SystemException { return findAll(start, end, null); } /** * Returns an ordered range of all the hosts. * * <p> * Useful when paginating results. Returns a maximum of <code>end - start</code> instances. <code>start</code> and <code>end</code> are not primary keys, they are indexes in the result set. Thus, <code>0</code> refers to the first result in the set. Setting both <code>start</code> and <code>end</code> to {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS} will return the full result set. If <code>orderByComparator</code> is specified, then the query will include the given ORDER BY logic. If <code>orderByComparator</code> is absent and pagination is required (<code>start</code> and <code>end</code> are not {@link com.liferay.portal.kernel.dao.orm.QueryUtil#ALL_POS}), then the query will include the default ORDER BY logic from {@link de.uhh.l2g.plugins.model.impl.HostModelImpl}. If both <code>orderByComparator</code> and pagination are absent, for performance reasons, the query will not have an ORDER BY clause and the returned result set will be sorted on by the primary key in an ascending order. * </p> * * @param start the lower bound of the range of hosts * @param end the upper bound of the range of hosts (not inclusive) * @param orderByComparator the comparator to order the results by (optionally <code>null</code>) * @return the ordered range of hosts * @throws SystemException if a system exception occurred */ @Override public List<Host> findAll(int start, int end, OrderByComparator orderByComparator) throws SystemException { boolean pagination = true; FinderPath finderPath = null; Object[] finderArgs = null; if ((start == QueryUtil.ALL_POS) && (end == QueryUtil.ALL_POS) && (orderByComparator == null)) { pagination = false; finderPath = FINDER_PATH_WITHOUT_PAGINATION_FIND_ALL; finderArgs = FINDER_ARGS_EMPTY; } else { finderPath = FINDER_PATH_WITH_PAGINATION_FIND_ALL; finderArgs = new Object[] { start, end, orderByComparator }; } List<Host> list = (List<Host>)FinderCacheUtil.getResult(finderPath, finderArgs, this); if (list == null) { StringBundler query = null; String sql = null; if (orderByComparator != null) { query = new StringBundler(2 + (orderByComparator.getOrderByFields().length * 3)); query.append(_SQL_SELECT_HOST); appendOrderByComparator(query, _ORDER_BY_ENTITY_ALIAS, orderByComparator); sql = query.toString(); } else { sql = _SQL_SELECT_HOST; if (pagination) { sql = sql.concat(HostModelImpl.ORDER_BY_JPQL); } } Session session = null; try { session = openSession(); Query q = session.createQuery(sql); if (!pagination) { list = (List<Host>)QueryUtil.list(q, getDialect(), start, end, false); Collections.sort(list); list = new UnmodifiableList<Host>(list); } else { list = (List<Host>)QueryUtil.list(q, getDialect(), start, end); } cacheResult(list); FinderCacheUtil.putResult(finderPath, finderArgs, list); } catch (Exception e) { FinderCacheUtil.removeResult(finderPath, finderArgs); throw processException(e); } finally { closeSession(session); } } return list; } /** * Removes all the hosts from the database. * * @throws SystemException if a system exception occurred */ @Override public void removeAll() throws SystemException { for (Host host : findAll()) { remove(host); } } /** * Returns the number of hosts. * * @return the number of hosts * @throws SystemException if a system exception occurred */ @Override public int countAll() throws SystemException { Long count = (Long)FinderCacheUtil.getResult(FINDER_PATH_COUNT_ALL, FINDER_ARGS_EMPTY, this); if (count == null) { Session session = null; try { session = openSession(); Query q = session.createQuery(_SQL_COUNT_HOST); count = (Long)q.uniqueResult(); FinderCacheUtil.putResult(FINDER_PATH_COUNT_ALL, FINDER_ARGS_EMPTY, count); } catch (Exception e) { FinderCacheUtil.removeResult(FINDER_PATH_COUNT_ALL, FINDER_ARGS_EMPTY); throw processException(e); } finally { closeSession(session); } } return count.intValue(); } /** * Initializes the host persistence. */ public void afterPropertiesSet() { String[] listenerClassNames = StringUtil.split(GetterUtil.getString( com.liferay.util.service.ServiceProps.get( "value.object.listener.de.uhh.l2g.plugins.model.Host"))); if (listenerClassNames.length > 0) { try { List<ModelListener<Host>> listenersList = new ArrayList<ModelListener<Host>>(); for (String listenerClassName : listenerClassNames) { listenersList.add((ModelListener<Host>)InstanceFactory.newInstance( getClassLoader(), listenerClassName)); } listeners = listenersList.toArray(new ModelListener[listenersList.size()]); } catch (Exception e) { _log.error(e); } } } public void destroy() { EntityCacheUtil.removeCache(HostImpl.class.getName()); FinderCacheUtil.removeCache(FINDER_CLASS_NAME_ENTITY); FinderCacheUtil.removeCache(FINDER_CLASS_NAME_LIST_WITH_PAGINATION); FinderCacheUtil.removeCache(FINDER_CLASS_NAME_LIST_WITHOUT_PAGINATION); } private static final String _SQL_SELECT_HOST = "SELECT host FROM Host host"; private static final String _SQL_SELECT_HOST_WHERE = "SELECT host FROM Host host WHERE "; private static final String _SQL_COUNT_HOST = "SELECT COUNT(host) FROM Host host"; private static final String _SQL_COUNT_HOST_WHERE = "SELECT COUNT(host) FROM Host host WHERE "; private static final String _ORDER_BY_ENTITY_ALIAS = "host."; private static final String _NO_SUCH_ENTITY_WITH_PRIMARY_KEY = "No Host exists with the primary key "; private static final String _NO_SUCH_ENTITY_WITH_KEY = "No Host exists with the key {"; private static final boolean _HIBERNATE_CACHE_USE_SECOND_LEVEL_CACHE = GetterUtil.getBoolean(PropsUtil.get( PropsKeys.HIBERNATE_CACHE_USE_SECOND_LEVEL_CACHE)); private static Log _log = LogFactoryUtil.getLog(HostPersistenceImpl.class); private static Host _nullHost = new HostImpl() { @Override public Object clone() { return this; } @Override public CacheModel<Host> toCacheModel() { return _nullHostCacheModel; } }; private static CacheModel<Host> _nullHostCacheModel = new CacheModel<Host>() { @Override public Host toEntityModel() { return _nullHost; } }; }