Alex Vandiver
e2d303c1bb
CVE-2021-41115: Use re2 for user-supplied linkifier patterns.
...
Zulip attempts to validate that the regular expressions that admins
enter for linkifiers are well-formatted, and only contain a specific
subset of regex grammar. The process of checking these
properties (via a regex!) can cause denial-of-service via
backtracking.
Furthermore, this validation itself does not prevent the creation of
linkifiers which themselves cause denial-of-service when they are
executed. As the validator accepts literally anything inside of a
`(?P<word>...)` block, any quadratic backtracking expression can be
hidden therein.
Switch user-provided linkifier patterns to be matched in the Markdown
processor by the `re2` library, which is guaranteed constant-time.
This somewhat limits the possible features of the regular
expression (notably, look-head and -behind, and back-references);
however, these features had never been advertised as working in the
context of linkifiers.
A migration removes any existing linkifiers which would not function
under re2, after printing them for posterity during the upgrade; they
are unlikely to be common, and are impossible to fix automatically.
The denial-of-service in the linkifier validator was discovered by
@erik-krogh and @yoff, as GHSL-2021-118.
2021-10-04 17:24:37 +00:00
..
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-29 21:18:13 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-04-22 14:53:00 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-09-07 13:56:41 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-08-04 12:52:22 -07:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-03-03 21:46:05 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-01-29 09:35:52 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-02-12 13:11:19 -08:00
2021-03-03 21:46:05 -08:00
2021-03-11 18:09:08 -08:00
2021-03-30 09:19:03 -07:00
2021-03-30 09:29:36 -07:00
2021-04-06 18:44:08 -07:00
2021-04-07 08:20:53 +05:30
2021-04-07 09:02:33 -07:00
2021-04-07 09:02:33 -07:00
2021-04-07 09:02:33 -07:00
2021-04-14 10:29:39 -07:00
2021-04-16 15:10:39 -07:00
2021-04-27 21:36:09 -07:00
2021-04-30 09:25:11 -07:00
2021-05-01 07:27:08 -07:00
2021-05-06 20:41:49 -07:00
2021-05-26 18:17:24 -07:00
2021-10-04 17:24:37 +00:00