
preprocessor.EscapeSequenceExpansionRule Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of regex-static-analysis Show documentation
Show all versions of regex-static-analysis Show documentation
A tool to perform static analysis on regexes to determine whether they are vulnerable to ReDoS.
package preprocessor;
import java.util.List;
import preprocessor.ParsingPreprocessor.EscapeFactor;
import preprocessor.ParsingPreprocessor.GroupFactor;
import preprocessor.ParsingPreprocessor.GroupFactor.GroupType;
import preprocessor.ParsingPreprocessor.RegexFactor;
import preprocessor.ParsingPreprocessor.RegexFactor.FactorType;
import preprocessor.ParsingPreprocessor.RegexToken;
import preprocessor.ParsingPreprocessor.RegexToken.TokenType;
public class EscapeSequenceExpansionRule implements PreprocessorRule {
@Override
public String process(List tokenStream) {
StringBuilder regexBuilder = new StringBuilder();
RegexToken tokens[] = new RegexToken[tokenStream.size()];
tokens = tokenStream.toArray(tokens);
int numTokens = tokens.length;
int i = 0;
while (i < numTokens) {
if (tokens[i].getTokenType() == TokenType.REGEX_FACTOR) {
RegexFactor> factorToken = (RegexFactor>) tokens[i];
if (factorToken.getFactorType() == FactorType.ESCAPED_CHARACTER) {
EscapeFactor escapeFactorToken = (EscapeFactor) factorToken;
regexBuilder.append("[" + escapeFactorToken.getRepresentation() + "]");
} else if (factorToken.getFactorType() == FactorType.GROUP) {
GroupFactor groupFactorToken = (GroupFactor) factorToken;
GroupType type = groupFactorToken.getGroupType();
StringBuilder groupBuilder = new StringBuilder();
groupBuilder.append(process(groupFactorToken.factorContent));
switch (type) {
case NORMAL:
regexBuilder.append("(" + groupBuilder.toString() + ")");
break;
case NONCAPTURING:
regexBuilder.append("(" + groupBuilder.toString() + ")");
break;
case NEGLOOKAHEAD:
regexBuilder.append("(?!" + groupBuilder.toString() + ")");
break;
case NEGLOOKBEHIND:
regexBuilder.append("(?
© 2015 - 2025 Weber Informatics LLC | Privacy Policy