nl.topicus.jdbc.shaded.io.opencensus.stats.ViewData Maven / Gradle / Ivy
/*
* Copyright 2016-17, OpenCensus Authors
*
* Licensed 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
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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 nl.topicus.jdbc.shaded.io.opencensus.stats;
import nl.topicus.jdbc.shaded.com.google.auto.value.AutoValue;
import nl.topicus.jdbc.shaded.com.google.common.collect.Maps;
import nl.topicus.jdbc.shaded.io.opencensus.common.Function;
import nl.topicus.jdbc.shaded.io.opencensus.common.Functions;
import nl.topicus.jdbc.shaded.io.opencensus.common.Timestamp;
import nl.topicus.jdbc.shaded.io.opencensus.tags.TagValue;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import nl.topicus.jdbc.shaded.javax.annotation.concurrent.Immutable;
/** The aggregated data for a particular {@link View}. */
@Immutable
@AutoValue
public abstract class ViewData {
// Prevents this class from being subclassed anywhere else.
ViewData() {}
/** The {@link View} associated with this {@link ViewData}. */
public abstract View getView();
/**
* The {@link AggregationData} grouped by combination of tag values, associated with this {@link
* ViewData}.
*/
public abstract Map, AggregationData> getAggregationMap();
/**
* Returns the {@link AggregationWindowData} associated with this {@link ViewData}.
*
* @return the {@code AggregationWindowData}.
*/
public abstract AggregationWindowData getWindowData();
/** Constructs a new {@link ViewData}. */
public static ViewData create(
View view,
Map, ? extends AggregationData> map,
final AggregationWindowData windowData) {
view.getWindow()
.match(
new Function() {
@Override
public Void apply(View.AggregationWindow.Cumulative arg) {
if (!(windowData instanceof AggregationWindowData.CumulativeData)) {
throw new IllegalArgumentException(
"AggregationWindow and AggregationWindowData types mismatch. "
+ "AggregationWindow: "
+ arg
+ " AggregationWindowData: "
+ windowData);
}
return null;
}
},
new Function() {
@Override
public Void apply(View.AggregationWindow.Interval arg) {
if (!(windowData instanceof AggregationWindowData.IntervalData)) {
throw new IllegalArgumentException(
"AggregationWindow and AggregationWindowData types mismatch. "
+ "AggregationWindow: "
+ arg
+ " AggregationWindowData: "
+ windowData);
}
return null;
}
},
Functions.throwIllegalArgumentException());
Map, AggregationData> deepCopy = Maps.newHashMap();
for (Entry, ? extends AggregationData> entry : map.entrySet()) {
deepCopy.put(
Collections.unmodifiableList(new ArrayList(entry.getKey())), entry.getValue());
}
return new AutoValue_ViewData(view, Collections.unmodifiableMap(deepCopy), windowData);
}
/** The {@code AggregationWindowData} for a {@link ViewData}. */
@Immutable
public abstract static class AggregationWindowData {
private AggregationWindowData() {}
/** Applies the given match function to the underlying data type. */
public abstract T match(
Function p0,
Function p1,
Function defaultFunction);
/** Cumulative {@code AggregationWindowData.} */
@Immutable
@AutoValue
public abstract static class CumulativeData extends AggregationWindowData {
CumulativeData() {}
/**
* Returns the start {@code Timestamp} for a {@link CumulativeData}.
*
* @return the start {@code Timestamp}.
*/
public abstract Timestamp getStart();
/**
* Returns the end {@code Timestamp} for a {@link CumulativeData}.
*
* @return the end {@code Timestamp}.
*/
public abstract Timestamp getEnd();
@Override
public final T match(
Function p0,
Function p1,
Function defaultFunction) {
return p0.apply(this);
}
/** Constructs a new {@link CumulativeData}. */
public static CumulativeData create(Timestamp start, Timestamp end) {
if (start.compareTo(end) > 0) {
throw new IllegalArgumentException("Start time is later than end time.");
}
return new AutoValue_ViewData_AggregationWindowData_CumulativeData(start, end);
}
}
/** Interval {@code AggregationWindowData.} */
@Immutable
@AutoValue
public abstract static class IntervalData extends AggregationWindowData {
IntervalData() {}
/**
* Returns the end {@code Timestamp} for an {@link IntervalData}.
*
* @return the end {@code Timestamp}.
*/
public abstract Timestamp getEnd();
@Override
public final T match(
Function p0,
Function p1,
Function defaultFunction) {
return p1.apply(this);
}
/** Constructs a new {@link IntervalData}. */
public static IntervalData create(Timestamp end) {
return new AutoValue_ViewData_AggregationWindowData_IntervalData(end);
}
}
}
}