On Fri, 31 Dec 2021 at 18:30, <[email protected]> wrote:
>
> This is an automated email from the ASF dual-hosted git repository.
>
> humbedooh pushed a commit to branch master
> in repository https://gitbox.apache.org/repos/asf/incubator-ponymail-foal.git
>
>
> The following commit(s) were added to refs/heads/master by this push:
>      new 3d78afb  allow for + in message-id here
> 3d78afb is described below
>
> commit 3d78afbf62d15bf7af3e822791d3dab5d36f0316
> Author: Daniel Gruno <[email protected]>
> AuthorDate: Fri Dec 31 19:30:43 2021 +0100
>
>     allow for + in message-id here
> ---
>  server/endpoints/source.py | 6 +++++-
>  1 file changed, 5 insertions(+), 1 deletion(-)
>
> diff --git a/server/endpoints/source.py b/server/endpoints/source.py
> index ce25d68..9fa1b3e 100644
> --- a/server/endpoints/source.py
> +++ b/server/endpoints/source.py
> @@ -27,12 +27,16 @@ import plugins.aaa
>  async def process(
>      server: plugins.server.BaseServer, session: 
> plugins.session.SessionObject, indata: dict,
>  ) -> aiohttp.web.Response:
> +    listid = indata.get("list", "")
>      # First, assume permalink and look up the email based on that
>      email = await plugins.messages.get_email(session, 
> permalink=indata.get("id"))
>
>      # If not found via permalink, it might be message-id instead, so try that
>      if email is None:
> -        email = await plugins.messages.get_email(session, 
> messageid=indata.get("id"), listid=indata.get("list", ""))
> +        email = await plugins.messages.get_email(session, 
> messageid=indata.get("id"), listid=listid)
> +    if not email and ' ' in mailid: # only try again if we need to due to 
> space in url
> +        mailid = mailid.replace(" ", "+")

-1

This will not work if there is a mix of space and plus.

The proper solution is to ensure that the correct encoding is used in the URL.
e.g. '+' must be encoded if it is used in a query

The code that generates the URL needs to ensure it applies the correct
encoding depending on which part of the URL is being constructed.

> +        email = await plugins.messages.get_email(session, 
> messageid=indata.get("id"), listid=listid)
>
>      if email and isinstance(email, dict) and not email.get("deleted"):
>          if plugins.aaa.can_access_email(session, email):

Reply via email to