de.alpharogroup.crypto.obfuscation.rule.ObfuscationOperationRule Maven / Gradle / Ivy
/**
* The MIT License
*
* Copyright (C) 2015 Asterios Raptis
*
* Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, sublicense, and/or sell copies of the Software, and to
* permit persons to whom the Software is furnished to do so, subject to
* the following conditions:
*
* The above copyright notice and this permission notice shall be
* included in all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
package de.alpharogroup.crypto.obfuscation.rule;
import java.io.Serializable;
import java.util.Optional;
import java.util.Set;
import de.alpharogroup.collections.set.SetFactory;
import lombok.AccessLevel;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.NonNull;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.FieldDefaults;
/**
* The class {@link ObfuscationOperationRule} builds a complex rule for
* obfuscating a single character.
*/
@Getter
@Setter
@EqualsAndHashCode
@ToString
@NoArgsConstructor
@AllArgsConstructor
@Builder(toBuilder = true)
@FieldDefaults(level = AccessLevel.PRIVATE)
public class ObfuscationOperationRule implements Serializable
{
/** The Constant serialVersionUID. */
private static final long serialVersionUID = 1L;
/** The character. */
@NonNull
C character;
/** The index where this rule will execute. */
@Builder.Default
Set indexes = SetFactory.newHashSet();
/** The flag that shows if the character is inverted with replaceWith. */
boolean inverted;
/** The operated character. */
@Builder.Default
Optional operatedCharacter = Optional.empty();
/** The type of operation for the obfuscation. */
@Builder.Default
Operation operation = Operation.NONE;
/** The character(s) that will be replaced with. */
@NonNull
RW replaceWith;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy