/**
* 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.portletexec;
import org.apereo.portal.events.aggr.AggregationInterval;
import org.apereo.portal.events.aggr.BaseAggregationKeyImpl;
import org.apereo.portal.events.aggr.DateDimension;
import org.apereo.portal.events.aggr.TimeDimension;
import org.apereo.portal.events.aggr.groups.AggregatedGroupMapping;
import org.apereo.portal.events.aggr.portlets.AggregatedPortletMapping;
/**
* Basic impl of {@link PortletExecutionAggregationKey}
*
*/
public final class PortletExecutionAggregationKeyImpl extends BaseAggregationKeyImpl
implements PortletExecutionAggregationKey {
private static final long serialVersionUID = 1L;
private final AggregatedPortletMapping portletMapping;
private final ExecutionType executionType;
private int hashCode = 0;
public PortletExecutionAggregationKeyImpl(PortletExecutionAggregation baseAggregation) {
super(baseAggregation);
this.portletMapping = baseAggregation.getPortletMapping();
this.executionType = baseAggregation.getExecutionType();
}
public PortletExecutionAggregationKeyImpl(
AggregationInterval aggregationInterval,
AggregatedGroupMapping aggregatedGroupMapping,
AggregatedPortletMapping portletMapping,
ExecutionType executionType) {
super(aggregationInterval, aggregatedGroupMapping);
this.portletMapping = portletMapping;
this.executionType = executionType;
}
public PortletExecutionAggregationKeyImpl(
DateDimension dateDimension,
TimeDimension timeDimension,
AggregationInterval aggregationInterval,
AggregatedGroupMapping aggregatedGroupMapping,
AggregatedPortletMapping portletMapping,
ExecutionType executionType) {
super(dateDimension, timeDimension, aggregationInterval, aggregatedGroupMapping);
this.portletMapping = portletMapping;
this.executionType = executionType;
}
@Override
public final AggregatedPortletMapping getPortletMapping() {
return this.portletMapping;
}
@Override
public final ExecutionType getExecutionType() {
return this.executionType;
}
@Override
public int hashCode() {
int h = this.hashCode;
if (h == 0) {
final int prime = 31;
h = super.hashCode();
h = prime * h + ((executionType == null) ? 0 : executionType.hashCode());
h = prime * h + ((portletMapping == null) ? 0 : portletMapping.hashCode());
this.hashCode = h;
}
return h;
}
@Override
public boolean equals(Object obj) {
if (this == obj) return true;
if (!super.equals(obj)) return false;
if (!(obj instanceof PortletExecutionAggregationKey)) return false;
PortletExecutionAggregationKey other = (PortletExecutionAggregationKey) obj;
if (executionType != other.getExecutionType()) return false;
if (portletMapping == null) {
if (other.getPortletMapping() != null) return false;
} else if (!portletMapping.equals(other.getPortletMapping())) return false;
return true;
}
@Override
public String toString() {
return "PortletExecutionAggregationKey [dateDimension="
+ getDateDimension()
+ ", timeDimension="
+ getTimeDimension()
+ ", interval="
+ getInterval()
+ ", aggregatedGroup="
+ getAggregatedGroup()
+ ", executionType="
+ executionType
+ ", portletMapping="
+ portletMapping
+ "]";
}
}