Skip to content

Commit

Permalink
Wrap "Pattern too complex" exception into an IllegalArgumentException
Browse files Browse the repository at this point in the history
  • Loading branch information
afoucret committed May 29, 2024
1 parent 849c33e commit 3deb7d9
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,32 @@
- match: { tokens.0.token: sha }
- match: { tokens.1.token: hay }

---
"Too complex regex pattern":
- do:
catch: bad_request
indices.create:
index: test_too_complex_regex_pattern
body:
settings:
index:
analysis:
analyzer:
my_analyzer:
tokenizer: standard
char_filter:
- my_char_filter
char_filter:
my_char_filter:
type: "pattern_replace"
pattern: "(\\d+)-(?=\\d\nͭͭͭͭͭͭͭͭͭͭͭͭͭͭͭ"
flags: CASE_INSENSITIVE|MULTILINE|DOTALL|UNICODE_CASE|CANON_EQ
replacement: "_$1"
- match: { status: 400 }
- match: { error.type: illegal_argument_exception }
- match: { error.reason: "Too complex regex pattern" }


---
"Custom normalizer in request":
- do:
Expand Down
22 changes: 20 additions & 2 deletions server/src/main/java/org/elasticsearch/common/regex/Regex.java
Original file line number Diff line number Diff line change
Expand Up @@ -230,8 +230,26 @@ public static boolean simpleMatch(final List<String> patterns, final String str)
}

public static Pattern compile(String regex, String flags) {
int pFlags = flags == null ? 0 : flagsFromString(flags);
return Pattern.compile(regex, pFlags);
try {
int pFlags = flags == null ? 0 : flagsFromString(flags);
return Pattern.compile(regex, pFlags);
} catch (OutOfMemoryError e) {
if (e.getMessage().equals("Pattern too complex")) {
// Normally, we do try to handle OutOfMemoryError errors, as they typically indicate the JVM is not healthy.
//
// In the context of Pattern::compile, an OutOfMemoryError can occur if the pattern is too complex.
// In this case, the OutOfMemoryError is thrown by a pre-check rather than actual memory exhaustion.
//
// Because the JVM has not encountered a real memory issue, we can treat this as a recoverable exception by wrapping
// the original OutOfMemoryError in an IllegalArgumentException.
//
// For additional details, see:
// - https://bugs.openjdk.org/browse/JDK-8300207
// - https://github.com/openjdk/jdk/commit/030b071db1fb6197a2633a04b20aa95432a903bc
throw new IllegalArgumentException("Too complex regex pattern", e);
}
throw e;
}
}

public static int flagsFromString(String flags) {
Expand Down

0 comments on commit 3deb7d9

Please sign in to comment.