
com.wavefront.agent.preprocessor.ReportPointLimitLengthTransformer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of proxy Show documentation
Show all versions of proxy Show documentation
Service for batching and relaying metric traffic to Wavefront
package com.wavefront.agent.preprocessor;
import static com.wavefront.agent.preprocessor.PreprocessorUtil.truncate;
import com.google.common.base.Function;
import com.google.common.base.Preconditions;
import java.util.function.Predicate;
import java.util.regex.Pattern;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import wavefront.report.ReportPoint;
public class ReportPointLimitLengthTransformer implements Function {
private final String scope;
private final int maxLength;
private final LengthLimitActionType actionSubtype;
@Nullable private final Pattern compiledMatchPattern;
private final Predicate v2Predicate;
private final PreprocessorRuleMetrics ruleMetrics;
public ReportPointLimitLengthTransformer(
@Nonnull final String scope,
final int maxLength,
@Nonnull final LengthLimitActionType actionSubtype,
@Nullable final String patternMatch,
@Nullable final Predicate v2Predicate,
@Nonnull final PreprocessorRuleMetrics ruleMetrics) {
this.scope = Preconditions.checkNotNull(scope, "[scope] can't be null");
Preconditions.checkArgument(!scope.isEmpty(), "[scope] can't be blank");
if (actionSubtype == LengthLimitActionType.DROP
&& (scope.equals("metricName") || scope.equals("sourceName"))) {
throw new IllegalArgumentException(
"'drop' action type can't be used in metricName and sourceName scope!");
}
if (actionSubtype == LengthLimitActionType.TRUNCATE_WITH_ELLIPSIS && maxLength < 3) {
throw new IllegalArgumentException(
"'maxLength' must be at least 3 for 'truncateWithEllipsis' action type!");
}
Preconditions.checkArgument(maxLength > 0, "[maxLength] needs to be > 0!");
this.maxLength = maxLength;
this.actionSubtype = actionSubtype;
this.compiledMatchPattern = patternMatch != null ? Pattern.compile(patternMatch) : null;
this.ruleMetrics = ruleMetrics;
this.v2Predicate = v2Predicate != null ? v2Predicate : x -> true;
}
@Nullable
@Override
public ReportPoint apply(@Nullable ReportPoint reportPoint) {
if (reportPoint == null) return null;
long startNanos = ruleMetrics.ruleStart();
try {
if (!v2Predicate.test(reportPoint)) return reportPoint;
switch (scope) {
case "metricName":
if (reportPoint.getMetric().length() > maxLength
&& (compiledMatchPattern == null
|| compiledMatchPattern.matcher(reportPoint.getMetric()).matches())) {
reportPoint.setMetric(truncate(reportPoint.getMetric(), maxLength, actionSubtype));
ruleMetrics.incrementRuleAppliedCounter();
}
break;
case "sourceName":
if (reportPoint.getHost().length() > maxLength
&& (compiledMatchPattern == null
|| compiledMatchPattern.matcher(reportPoint.getHost()).matches())) {
reportPoint.setHost(truncate(reportPoint.getHost(), maxLength, actionSubtype));
ruleMetrics.incrementRuleAppliedCounter();
}
break;
default:
if (reportPoint.getAnnotations() != null) {
String tagValue = reportPoint.getAnnotations().get(scope);
if (tagValue != null && tagValue.length() > maxLength) {
if (actionSubtype == LengthLimitActionType.DROP) {
reportPoint.getAnnotations().remove(scope);
ruleMetrics.incrementRuleAppliedCounter();
} else {
if (compiledMatchPattern == null
|| compiledMatchPattern.matcher(tagValue).matches()) {
reportPoint
.getAnnotations()
.put(scope, truncate(tagValue, maxLength, actionSubtype));
ruleMetrics.incrementRuleAppliedCounter();
}
}
}
}
}
return reportPoint;
} finally {
ruleMetrics.ruleEnd(startNanos);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy