/* * 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.SigmaValueError; import org.opensearch.securityanalytics.rules.objects.SigmaDetectionItem; import org.opensearch.securityanalytics.rules.types.SigmaString; import org.opensearch.securityanalytics.rules.types.SigmaType; import org.opensearch.securityanalytics.rules.utils.Either; import java.util.Base64; import java.util.List; public class SigmaBase64Modifier extends SigmaValueModifier { public SigmaBase64Modifier(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 { if (val.isLeft() && val.getLeft() instanceof SigmaString) { if (((SigmaString) val.getLeft()).containsSpecial()) { throw new SigmaValueError("Base64 encoding of strings with wildcards is not allowed"); } return Either.left(new SigmaString(Base64.getEncoder().encodeToString(((SigmaString) val.getLeft()).getBytes()))); } return null; } }