org.graylog.plugins.pipelineprocessor.functions.GrokExists Maven / Gradle / Ivy
/*
* Copyright (C) 2020 Graylog, Inc.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the Server Side Public License, version 1,
* as published by MongoDB, Inc.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Server Side Public License for more details.
*
* You should have received a copy of the Server Side Public License
* along with this program. If not, see
* .
*/
package org.graylog.plugins.pipelineprocessor.functions;
import com.swrve.ratelimitedlogger.RateLimitedLog;
import org.graylog.plugins.pipelineprocessor.EvaluationContext;
import org.graylog.plugins.pipelineprocessor.ast.functions.AbstractFunction;
import org.graylog.plugins.pipelineprocessor.ast.functions.FunctionArgs;
import org.graylog.plugins.pipelineprocessor.ast.functions.FunctionDescriptor;
import org.graylog.plugins.pipelineprocessor.ast.functions.ParameterDescriptor;
import org.graylog.plugins.pipelineprocessor.rulebuilder.RuleBuilderFunctionGroup;
import org.graylog2.grok.GrokPatternRegistry;
import javax.inject.Inject;
import static com.google.common.collect.ImmutableList.of;
import static org.graylog.plugins.pipelineprocessor.processors.PipelineInterpreter.getRateLimitedLog;
public class GrokExists extends AbstractFunction {
private static final RateLimitedLog log = getRateLimitedLog(GrokExists.class);
public static final String NAME = "grok_exists";
private final ParameterDescriptor patternParam;
private final ParameterDescriptor doLog;
private final GrokPatternRegistry grokPatternRegistry;
@Inject
public GrokExists(GrokPatternRegistry grokPatternRegistry) {
this.grokPatternRegistry = grokPatternRegistry;
patternParam = ParameterDescriptor.string("pattern")
.description("The Grok Pattern which is to be tested for existence.").build();
doLog = ParameterDescriptor.bool("log_missing").optional()
.description("Log if the Grok Pattern is missing. Warning: Switching on this flag can lead" +
" to a high volume of logs.").build();
}
@Override
public Boolean evaluate(FunctionArgs args, EvaluationContext context) {
final String pattern = patternParam.required(args, context);
final boolean logWhenNotFound = doLog.optional(args, context).orElse(false);
if (pattern == null) {
return null;
}
final boolean patternExists = grokPatternRegistry.grokPatternExists(pattern);
if (!patternExists && logWhenNotFound) {
log.info(context.pipelineErrorMessage("Grok Pattern " + pattern + " does not exist."));
}
return patternExists;
}
@Override
public FunctionDescriptor descriptor() {
return FunctionDescriptor.builder()
.name(NAME)
.returnType(Boolean.class)
.params(of(patternParam, doLog))
.description("Checks if the given Grok pattern exists in Graylog.")
.ruleBuilderEnabled()
.ruleBuilderName("Check for grok pattern")
.ruleBuilderTitle("Check if grok pattern named '${pattern}' exists in Graylog")
.ruleBuilderFunctionGroup(RuleBuilderFunctionGroup.PATTERN)
.build();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy