Regression: ImportError for HeaderWriteError in long-running process post-Python update for CVE-2024-6923
#124170
Labels
HeaderWriteError in long-running process post-Python update for CVE-2024-6923
#124170
Bug report
Bug description:
Pull request #122233 introduced a new class
HeaderWriteErrorin commit 0976339 and imports that fromemail.generator.This breaks running applications that have imported other parts of
emailbefore the update, and then try to import the generator past the update.Now this is a bit silly, but it is what
email.message.Message.as_string()does, it importsemail.generatorinside the function - which may happen at any point of the program run-time rather than at startup.For example, the following pseudo-code will fail, assuming it has not generated another email earlier or manually imported the
email.generatormodule.A particular instance of the issue is the
unattended-upgradespackage in Ubuntu and Debian, which will install the security update and then may send an email and fail there due to the ImportError, see https://bugs.launchpad.net/ubuntu/+source/python3.8/+bug/2080940.I'm wondering if it's feasible to add a workaround to the stable branches:
Cchange the email.generator module import:
to graciously support the previous version email.errors:
This is a safe change, existing applications, where the import fails can't be having
except HeaderWriteErrorstatements anyway.Thanks.
CPython versions tested on:
3.12
Operating systems tested on:
No response
The text was updated successfully, but these errors were encountered: