mirror of
https://github.com/elastic/elasticsearch.git
synced 2025-04-19 04:45:07 -04:00
Workaround max name limit imposed by Jackson 2.17 (#126806)
In Jackson 2.15 a maximum string length of 50k characters was introduced. We worked around that by override the length to max int on all parsers created by xcontent. Jackson 2.17 introduced a similar limit on field names. This commit mimics the workaround for string length by overriding the max name length to be unlimited. relates #58952
This commit is contained in:
parent
bf53927d71
commit
6174acdc39
2 changed files with 10 additions and 1 deletions
5
docs/changelog/126806.yaml
Normal file
5
docs/changelog/126806.yaml
Normal file
|
@ -0,0 +1,5 @@
|
|||
pr: 126806
|
||||
summary: Workaround max name limit imposed by Jackson 2.17
|
||||
area: Infra/Core
|
||||
type: bug
|
||||
issues: []
|
|
@ -17,6 +17,10 @@ public class XContentImplUtils {
|
|||
public static <F extends JsonFactory, B extends TSFBuilder<F, B>> F configure(TSFBuilder<F, B> builder) {
|
||||
// jackson 2.15 introduced a max string length. We have other limits in place to constrain max doc size,
|
||||
// so here we set to max value (2GiB) so as not to constrain further than those existing limits.
|
||||
return builder.streamReadConstraints(StreamReadConstraints.builder().maxStringLength(Integer.MAX_VALUE).build()).build();
|
||||
// jackson 2.16 further introduced a max name length, which we also relax here temporarily.
|
||||
// see https://github.com/elastic/elasticsearch/issues/58952
|
||||
return builder.streamReadConstraints(
|
||||
StreamReadConstraints.builder().maxStringLength(Integer.MAX_VALUE).maxNameLength(Integer.MAX_VALUE).build()
|
||||
).build();
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue