/**
* 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.user.groups.admin.web.internal.search;
import com.liferay.portal.kernel.dao.orm.ActionableDynamicQuery;
import com.liferay.portal.kernel.dao.orm.IndexableActionableDynamicQuery;
import com.liferay.portal.kernel.exception.PortalException;
import com.liferay.portal.kernel.log.Log;
import com.liferay.portal.kernel.log.LogFactoryUtil;
import com.liferay.portal.kernel.model.UserGroup;
import com.liferay.portal.kernel.search.BaseIndexer;
import com.liferay.portal.kernel.search.BooleanQuery;
import com.liferay.portal.kernel.search.Document;
import com.liferay.portal.kernel.search.Field;
import com.liferay.portal.kernel.search.IndexWriterHelper;
import com.liferay.portal.kernel.search.Indexer;
import com.liferay.portal.kernel.search.SearchContext;
import com.liferay.portal.kernel.search.Summary;
import com.liferay.portal.kernel.search.filter.BooleanFilter;
import com.liferay.portal.kernel.security.permission.PermissionChecker;
import com.liferay.portal.kernel.service.UserGroupLocalService;
import com.liferay.portal.kernel.service.permission.UserGroupPermission;
import com.liferay.portal.kernel.util.GetterUtil;
import com.liferay.portal.kernel.util.Validator;
import com.liferay.user.groups.admin.constants.UserGroupsAdminPortletKeys;
import java.util.LinkedHashMap;
import java.util.Locale;
import javax.portlet.PortletRequest;
import javax.portlet.PortletResponse;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Reference;
/**
* @author Hugo Huijser
*/
@Component(
immediate = true,
property = {
"javax.portlet.name=" + UserGroupsAdminPortletKeys.USER_GROUPS_ADMIN
},
service = Indexer.class
)
public class UserGroupIndexer extends BaseIndexer<UserGroup> {
public static final String CLASS_NAME = UserGroup.class.getName();
public UserGroupIndexer() {
setDefaultSelectedFieldNames(
Field.COMPANY_ID, Field.UID, Field.USER_GROUP_ID);
setFilterSearch(true);
setPermissionAware(true);
setStagingAware(false);
}
@Override
public String getClassName() {
return CLASS_NAME;
}
@Override
public boolean hasPermission(
PermissionChecker permissionChecker, String entryClassName,
long entryClassPK, String actionId)
throws Exception {
UserGroup userGroup = _userGroupLocalService.getUserGroup(entryClassPK);
return _userGroupPermission.contains(
permissionChecker, userGroup.getUserGroupId(), actionId);
}
@Override
public void postProcessSearchQuery(
BooleanQuery searchQuery, BooleanFilter fullQueryBooleanFilter,
SearchContext searchContext)
throws Exception {
addSearchTerm(searchQuery, searchContext, "description", false);
addSearchTerm(searchQuery, searchContext, "name", false);
LinkedHashMap<String, Object> params =
(LinkedHashMap<String, Object>)searchContext.getAttribute("params");
if (params != null) {
String expandoAttributes = (String)params.get("expandoAttributes");
if (Validator.isNotNull(expandoAttributes)) {
addSearchExpando(searchQuery, searchContext, expandoAttributes);
}
}
}
@Override
protected void doDelete(UserGroup userGroup) throws Exception {
deleteDocument(userGroup.getCompanyId(), userGroup.getUserGroupId());
}
@Override
protected Document doGetDocument(UserGroup userGroup) throws Exception {
Document document = getBaseModelDocument(CLASS_NAME, userGroup);
document.addKeyword(Field.COMPANY_ID, userGroup.getCompanyId());
document.addText(Field.DESCRIPTION, userGroup.getDescription());
document.addText(Field.NAME, userGroup.getName());
document.addKeyword(Field.USER_GROUP_ID, userGroup.getUserGroupId());
return document;
}
@Override
protected String doGetSortField(String orderByCol) {
if (orderByCol.equals("description")) {
return "description";
}
else if (orderByCol.equals("name")) {
return "name";
}
else {
return orderByCol;
}
}
@Override
protected Summary doGetSummary(
Document document, Locale locale, String snippet,
PortletRequest portletRequest, PortletResponse portletResponse) {
String title = document.get("name");
String content = null;
return new Summary(title, content);
}
@Override
protected void doReindex(String className, long classPK) throws Exception {
UserGroup userGroup = _userGroupLocalService.getUserGroup(classPK);
doReindex(userGroup);
}
@Override
protected void doReindex(String[] ids) throws Exception {
long companyId = GetterUtil.getLong(ids[0]);
reindexUserGroups(companyId);
}
@Override
protected void doReindex(UserGroup userGroup) throws Exception {
Document document = getDocument(userGroup);
_indexWriterHelper.updateDocument(
getSearchEngineId(), userGroup.getCompanyId(), document,
isCommitImmediately());
}
protected void reindexUserGroups(long companyId) throws PortalException {
final IndexableActionableDynamicQuery indexableActionableDynamicQuery =
_userGroupLocalService.getIndexableActionableDynamicQuery();
indexableActionableDynamicQuery.setCompanyId(companyId);
indexableActionableDynamicQuery.setPerformActionMethod(
new ActionableDynamicQuery.PerformActionMethod<UserGroup>() {
@Override
public void performAction(UserGroup userGroup) {
try {
Document document = getDocument(userGroup);
indexableActionableDynamicQuery.addDocuments(document);
}
catch (PortalException pe) {
if (_log.isWarnEnabled()) {
_log.warn(
"Unable to index user group " +
userGroup.getUserGroupId(),
pe);
}
}
}
});
indexableActionableDynamicQuery.setSearchEngineId(getSearchEngineId());
indexableActionableDynamicQuery.performActions();
}
private static final Log _log = LogFactoryUtil.getLog(
UserGroupIndexer.class);
@Reference
private IndexWriterHelper _indexWriterHelper;
@Reference
private UserGroupLocalService _userGroupLocalService;
@Reference
private UserGroupPermission _userGroupPermission;
}