/**
* 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;
import java.io.Serializable;
import org.apereo.portal.events.aggr.groups.AggregatedGroupMapping;
import org.joda.time.DateTime;
/**
* Base of all aggregations which includes time, date, interval, group, and duration
*
*/
public interface BaseAggregation<
K extends BaseAggregationKey, D extends BaseGroupedAggregationDiscriminator>
extends Serializable {
/**
* @return The {@link DateTime} the aggregation is for, short cut for getting the same info from
* {@link #getDateDimension()} and {@link #getTimeDimension()}
*/
DateTime getDateTime();
/** @return The day the aggregation is for */
DateDimension getDateDimension();
/** @return The time of day the aggregation is for */
TimeDimension getTimeDimension();
/** @return The interval the aggregation is for */
AggregationInterval getInterval();
/** @return The group this aggregation is for, null if it is for all users */
AggregatedGroupMapping getAggregatedGroup();
/** @return Duration in minutes of the aggregated time span */
int getDuration();
/** @return The key for this aggregation */
K getAggregationKey();
/**
* Return a discriminator used for organizing aggregation data into separate columns for
* reporting purposes
*
* @return aggregation discriminator
*/
D getAggregationDiscriminator();
}