
com.liferay.mobile.device.rules.service.persistence.impl.MDRRuleGroupFinderImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of com.liferay.mobile.device.rules.service Show documentation
Show all versions of com.liferay.mobile.device.rules.service Show documentation
Liferay Mobile Device Rules Service
/**
* 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 com.liferay.mobile.device.rules.service.persistence.impl;
import com.liferay.mobile.device.rules.model.MDRRuleGroup;
import com.liferay.mobile.device.rules.model.impl.MDRRuleGroupImpl;
import com.liferay.mobile.device.rules.service.persistence.MDRRuleGroupFinder;
import com.liferay.mobile.device.rules.util.comparator.RuleGroupCreateDateComparator;
import com.liferay.portal.dao.orm.custom.sql.CustomSQLUtil;
import com.liferay.portal.kernel.dao.orm.QueryPos;
import com.liferay.portal.kernel.dao.orm.QueryUtil;
import com.liferay.portal.kernel.dao.orm.SQLQuery;
import com.liferay.portal.kernel.dao.orm.Session;
import com.liferay.portal.kernel.dao.orm.Type;
import com.liferay.portal.kernel.exception.PortalException;
import com.liferay.portal.kernel.exception.SystemException;
import com.liferay.portal.kernel.model.Group;
import com.liferay.portal.kernel.service.GroupLocalServiceUtil;
import com.liferay.portal.kernel.util.OrderByComparator;
import com.liferay.portal.kernel.util.StringPool;
import com.liferay.portal.kernel.util.StringUtil;
import com.liferay.portal.kernel.util.Validator;
import java.util.Iterator;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
/**
* @author Edward Han
* @author Eduardo Lundgren
* @author Manuel de la Peña
*/
public class MDRRuleGroupFinderImpl
extends MDRRuleGroupFinderBaseImpl implements MDRRuleGroupFinder {
public static final String COUNT_BY_G_N =
MDRRuleGroupFinder.class.getName() + ".countByG_N";
public static final String FIND_BY_G_N =
MDRRuleGroupFinder.class.getName() + ".findByG_N";
@Override
public int countByKeywords(
long groupId, String keywords, LinkedHashMap params) {
String[] names = null;
boolean andOperator = false;
if (Validator.isNotNull(keywords)) {
names = CustomSQLUtil.keywords(keywords);
}
else {
andOperator = true;
}
return countByG_N(groupId, names, params, andOperator);
}
@Override
public int countByG_N(
long groupId, String name, LinkedHashMap params,
boolean andOperator) {
String[] names = CustomSQLUtil.keywords(name);
return countByG_N(groupId, names, params, andOperator);
}
@Override
public int countByG_N(
long groupId, String[] names, LinkedHashMap params,
boolean andOperator) {
names = CustomSQLUtil.keywords(names);
if (params == null) {
params = _emptyLinkedHashMap;
}
Session session = null;
try {
session = openSession();
String sql = CustomSQLUtil.get(getClass(), COUNT_BY_G_N);
sql = StringUtil.replace(sql, "[$GROUP_ID$]", getGroupIds(params));
sql = CustomSQLUtil.replaceKeywords(
sql, "lower(name)", StringPool.LIKE, true, names);
sql = CustomSQLUtil.replaceAndOperator(sql, true);
SQLQuery q = session.createSynchronizedSQLQuery(sql);
q.addScalar(COUNT_COLUMN_NAME, Type.LONG);
QueryPos qPos = QueryPos.getInstance(q);
setGroupIds(qPos, groupId, params);
qPos.add(names, 2);
Iterator itr = q.iterate();
if (itr.hasNext()) {
Long count = itr.next();
if (count != null) {
return count.intValue();
}
}
return 0;
}
catch (Exception e) {
throw new SystemException(e);
}
finally {
closeSession(session);
}
}
@Override
public List findByKeywords(
long groupId, String keywords, LinkedHashMap params,
int start, int end) {
return findByKeywords(
groupId, keywords, params, start, end,
new RuleGroupCreateDateComparator());
}
@Override
public List findByKeywords(
long groupId, String keywords, LinkedHashMap params,
int start, int end, OrderByComparator obc) {
String[] names = null;
boolean andOperator = false;
if (Validator.isNotNull(keywords)) {
names = CustomSQLUtil.keywords(keywords);
}
else {
andOperator = true;
}
return findByG_N(groupId, names, params, andOperator, start, end, obc);
}
@Override
public List findByG_N(
long groupId, String name, LinkedHashMap params,
boolean andOperator) {
return findByG_N(
groupId, name, params, andOperator, QueryUtil.ALL_POS,
QueryUtil.ALL_POS);
}
@Override
public List findByG_N(
long groupId, String name, LinkedHashMap params,
boolean andOperator, int start, int end) {
String[] names = CustomSQLUtil.keywords(name);
return findByG_N(groupId, names, params, andOperator, start, end);
}
@Override
public List findByG_N(
long groupId, String[] names, LinkedHashMap params,
boolean andOperator, int start, int end) {
return findByG_N(
groupId, names, params, andOperator, start, end,
new RuleGroupCreateDateComparator());
}
@Override
public List findByG_N(
long groupId, String[] names, LinkedHashMap params,
boolean andOperator, int start, int end,
OrderByComparator obc) {
names = CustomSQLUtil.keywords(names);
if (params == null) {
params = _emptyLinkedHashMap;
}
Session session = null;
try {
session = openSession();
String sql = CustomSQLUtil.get(getClass(), FIND_BY_G_N);
sql = StringUtil.replace(sql, "[$GROUP_ID$]", getGroupIds(params));
sql = CustomSQLUtil.replaceKeywords(
sql, "lower(name)", StringPool.LIKE, true, names);
sql = CustomSQLUtil.replaceAndOperator(sql, andOperator);
sql = CustomSQLUtil.replaceOrderBy(sql, obc);
SQLQuery q = session.createSynchronizedSQLQuery(sql);
q.addEntity("MDRRuleGroup", MDRRuleGroupImpl.class);
QueryPos qPos = QueryPos.getInstance(q);
setGroupIds(qPos, groupId, params);
qPos.add(names, 2);
return (List)QueryUtil.list(
q, getDialect(), start, end);
}
catch (Exception e) {
throw new SystemException(e);
}
finally {
closeSession(session);
}
}
protected String getGroupIds(Map params) {
Boolean includeGlobalScope = (Boolean)params.get("includeGlobalScope");
if ((includeGlobalScope != null) && includeGlobalScope) {
return "((groupId = ?) OR (groupId = ?))";
}
else {
return "(groupId = ?)";
}
}
protected void setGroupIds(
QueryPos qPos, long groupId, Map params)
throws PortalException {
Boolean includeGlobalScope = (Boolean)params.get("includeGlobalScope");
if ((includeGlobalScope != null) && includeGlobalScope) {
qPos.add(groupId);
Group group = GroupLocalServiceUtil.getGroup(groupId);
Group companyGroup = GroupLocalServiceUtil.getCompanyGroup(
group.getCompanyId());
qPos.add(companyGroup.getGroupId());
}
else {
qPos.add(groupId);
}
}
private final LinkedHashMap _emptyLinkedHashMap =
new LinkedHashMap<>(0);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy