aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKonstantin Ryabitsev <konstantin@linuxfoundation.org>2020-04-07 12:27:28 -0400
committerKonstantin Ryabitsev <konstantin@linuxfoundation.org>2020-04-07 12:27:28 -0400
commit8ec42165108db3b28c3af7dff9dee9540b61f3a8 (patch)
tree5288aa97af25832458f59a151557b15061070eeb
parentce0af26e41461d7cfe6bbacf7e16c66c4967075e (diff)
downloadb4-8ec42165108db3b28c3af7dff9dee9540b61f3a8.tar.gz
Better deal with urlescaped msgids
Message-IDs that are using escaped characters are breaking our lookup due to the refactoring that was necessary for backfilling. This should help deal with such cases. Signed-off-by: Konstantin Ryabitsev <konstantin@linuxfoundation.org>
-rw-r--r--b4/__init__.py10
1 files changed, 7 insertions, 3 deletions
diff --git a/b4/__init__.py b/b4/__init__.py
index 96fa08c..91078ef 100644
--- a/b4/__init__.py
+++ b/b4/__init__.py
@@ -1573,6 +1573,7 @@ def get_pi_thread_by_url(t_mbx_url, savefile):
def get_pi_thread_by_msgid(msgid, savefile, useproject=None, nocache=False):
+ qmsgid = urllib.parse.quote_plus(msgid)
config = get_main_config()
cachedir = get_cache_dir()
base = msgid
@@ -1585,7 +1586,7 @@ def get_pi_thread_by_msgid(msgid, savefile, useproject=None, nocache=False):
return savefile
# Grab the head from lore, to see where we are redirected
- midmask = config['midmask'] % msgid
+ midmask = config['midmask'] % qmsgid
loc = urllib.parse.urlparse(midmask)
if useproject:
projurl = '%s://%s/%s' % (loc.scheme, loc.netloc, useproject)
@@ -1596,9 +1597,12 @@ def get_pi_thread_by_msgid(msgid, savefile, useproject=None, nocache=False):
if resp.status_code < 300 or resp.status_code > 400:
logger.critical('That message-id is not known.')
return None
- projurl = resp.headers['Location'].replace(msgid, '').rstrip('/')
+ # Pop msgid from the end of the redirect
+ chunks = resp.headers['Location'].rstrip('/').split('/')
+ projurl = '/'.join(chunks[:-1])
resp.close()
- t_mbx_url = '%s/%s/t.mbox.gz' % (projurl, msgid)
+ t_mbx_url = '%s/%s/t.mbox.gz' % (projurl, qmsgid)
+ logger.debug('t_mbx_url=%s', t_mbx_url)
logger.critical('Grabbing thread from %s', projurl.split('://')[1])
in_mbxf = get_pi_thread_by_url(t_mbx_url, '%s-loose' % savefile)