pcre2 compile_pattern(): Actually pass the anchored pattern to pcre2_compile()
authorFabian Keil <fk@fabiankeil.de>
Sun, 27 Aug 2023 10:26:02 +0000 (12:26 +0200)
committerFabian Keil <fk@fabiankeil.de>
Sun, 27 Aug 2023 10:55:06 +0000 (12:55 +0200)
Previously the un-anchoring pattern was compiled resulting
in incorrect matches.

For example requests to:

    https://www.privoxy.org/user-manual/config.html

were redirected because of the default.action section:

    {+redirect{http://config.privoxy.org/}}
    # Sticky Actions = +redirect{http://config.privoxy.org/}
    # URL = http://www.privoxy.org/config
    # Redirected URL = http://www.privoxy.org/config
    # Redirect Destination = http://config.privoxy.org/
    .privoxy.org/config

As the path pattern is left-anchored it should not match.

urlmatch.c

index 22feb9c..494a69a 100644 (file)
@@ -666,7 +666,7 @@ static jb_err compile_pattern(const char *pattern, enum regex_anchoring anchorin
 
    snprintf(rebuf, rebuf_size, fmt, pattern);
 
-   *regex = pcre2_compile((const unsigned char *)pattern,
+   *regex = pcre2_compile((const unsigned char *)rebuf,
       PCRE2_ZERO_TERMINATED, PCRE2_CASELESS, &errcode,
       &error_offset, NULL);
    if (*regex == NULL)