/**
* Licensed to Apereo under one or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information regarding copyright ownership. Apereo
* licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use
* this file except in compliance with the License. You may obtain a copy of the License at the
* following location:
*
* <p>http://www.apache.org/licenses/LICENSE-2.0
*
* <p>Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apereo.portal.events.aggr.action;
import java.util.List;
import java.util.Map;
import org.apache.commons.lang.StringUtils;
import org.apereo.portal.events.PortalEvent;
import org.apereo.portal.events.PortletActionExecutionEvent;
import org.apereo.portal.events.aggr.AggregationInterval;
import org.apereo.portal.events.aggr.AggregationIntervalInfo;
import org.apereo.portal.events.aggr.BaseAggregationPrivateDao;
import org.apereo.portal.events.aggr.BaseIntervalAwarePortalEventAggregator;
import org.apereo.portal.events.aggr.DateDimension;
import org.apereo.portal.events.aggr.EventAggregationContext;
import org.apereo.portal.events.aggr.TimeDimension;
import org.apereo.portal.events.aggr.groups.AggregatedGroupMapping;
import org.springframework.beans.factory.annotation.Autowired;
public class SearchRequestAggregator
extends BaseIntervalAwarePortalEventAggregator<
PortletActionExecutionEvent, SearchRequestAggregationImpl,
SearchRequestAggregationKey> {
private static final String TARGET_FNAME = "search";
private static final String TARGET_PARAM = "query";
private SearchRequestAggregationPrivateDao searchRequestAggregationDao;
@Autowired
public void setSearchRequestAggregationDao(
SearchRequestAggregationPrivateDao searchRequestAggregationDao) {
this.searchRequestAggregationDao = searchRequestAggregationDao;
}
@Override
public boolean supports(Class<? extends PortalEvent> type) {
return PortletActionExecutionEvent.class.isAssignableFrom(type);
}
@Override
public boolean supports(PortalEvent event) {
if (event instanceof PortletActionExecutionEvent) {
PortletActionExecutionEvent paee = (PortletActionExecutionEvent) event;
if (paee.getFname().equals(TARGET_FNAME)) {
Map<String, List<String>> params = paee.getParameters();
if (params.containsKey(TARGET_PARAM)) {
if ((params.get(TARGET_PARAM) != null) && !params.get(TARGET_PARAM).isEmpty()) {
if (!StringUtils.isBlank(params.get(TARGET_PARAM).get(0))) {
return true;
}
}
}
}
}
return false;
}
@Override
protected BaseAggregationPrivateDao<SearchRequestAggregationImpl, SearchRequestAggregationKey>
getAggregationDao() {
return this.searchRequestAggregationDao;
}
@Override
protected void updateAggregation(
PortletActionExecutionEvent e,
EventAggregationContext eventAggregationContext,
AggregationIntervalInfo intervalInfo,
SearchRequestAggregationImpl aggregation) {
final int duration = intervalInfo.getDurationTo(e.getTimestampAsDate());
aggregation.setDuration(duration);
aggregation.increment();
}
@Override
protected SearchRequestAggregationKey createAggregationKey(
PortletActionExecutionEvent e,
EventAggregationContext eventAggregationContext,
AggregationIntervalInfo intervalInfo,
AggregatedGroupMapping aggregatedGroup) {
final TimeDimension timeDimension = intervalInfo.getTimeDimension();
final DateDimension dateDimension = intervalInfo.getDateDimension();
final AggregationInterval aggregationInterval = intervalInfo.getAggregationInterval();
String query = e.getParameters().get(TARGET_PARAM).get(0);
SearchRequestAggregationKey key =
new SearchRequestAggregationKeyImpl(
dateDimension, timeDimension, aggregationInterval, aggregatedGroup, query);
return key;
}
}