From ff3fb5e431e72b008461a62398644d92068d3aa1 Mon Sep 17 00:00:00 2001 From: revsuine Date: Wed, 6 Nov 2024 20:47:12 +0000 Subject: [PATCH] move encoding to a constant and have same encoding for both encryption and decryption --- gpgmymail | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/gpgmymail b/gpgmymail index 1125fe0..721cc6a 100755 --- a/gpgmymail +++ b/gpgmymail @@ -38,6 +38,9 @@ import typing # see: https://gnupg.readthedocs.io/en/latest/ import gnupg +# constants +ENCODING='utf-8' # default is latin-1 which fails w some unicode chars + def is_message_encrypted(message: email.message.Message) -> bool: """Determines whether or not an email message is encrypted. @@ -69,7 +72,7 @@ def encrypt( return message.as_string() gpg = gnupg.GPG() - # gpg.encoding = 'utf-8' # default is latin-1 which fails w some unicode chars + gpg.encoding = ENCODING encrypted_content = gpg.encrypt(message.as_string(), recipients, armor=True) if not encrypted_content: raise ValueError(encrypted_content.status) @@ -108,7 +111,9 @@ def encrypt( def decrypt(message: email.message.Message) -> str: """Decrypt the given message Likely won't work on this server as I don't store private keys""" - return str(gnupg.GPG().decrypt(message.as_string())) + gpg = gnupg.GPG() + gpg.encoding = ENCODING + return str(gpg.decrypt(message.as_string())) def main() -> None: """Program entry"""