/* * Copyright OpenSearch Contributors * SPDX-License-Identifier: Apache-2.0 */ package org.opensearch.securityanalytics.rules.modifiers; import org.apache.commons.lang3.tuple.Pair; import org.opensearch.securityanalytics.rules.exceptions.SigmaTypeError; import org.opensearch.securityanalytics.rules.exceptions.SigmaValueError; import org.opensearch.securityanalytics.rules.objects.SigmaDetectionItem; import org.opensearch.securityanalytics.rules.types.SigmaCIDRExpression; import org.opensearch.securityanalytics.rules.types.SigmaString; import org.opensearch.securityanalytics.rules.types.SigmaType; import org.opensearch.securityanalytics.rules.utils.Either; import java.util.List; public class SigmaCIDRModifier extends SigmaValueModifier { public SigmaCIDRModifier(SigmaDetectionItem detectionItem, List> appliedModifiers) { super(detectionItem, appliedModifiers); } @Override public Pair, Class> getTypeHints() { return Pair.of(SigmaString.class, null); } @Override public Either> modify(Either> val) throws SigmaValueError, SigmaTypeError { if (val.isLeft() && val.getLeft() instanceof SigmaString) { if (this.getAppliedModifiers().size() > 0) { throw new SigmaValueError("CIDR expression modifier only applicable to unmodified values"); } return Either.left(new SigmaCIDRExpression(val.getLeft().toString())); } return null; } }