From b4b0e36ca9650a655c83aa139a90dad620da6726 Mon Sep 17 00:00:00 2001 From: Enno Date: Thu, 11 Jan 2024 19:06:37 +0100 Subject: [PATCH] offer to set sendmail command instead of guessing this addresses https://github.com/marvinthepa/mutt-ical/issues/17 also, the sendmail command may contain an equal sign `=`, for example to set an account using msmtp (for users using more than one email account), so rather split using the full `sendmail=` string marking the beginning of the sendmail command --- mutt-ical.py | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/mutt-ical.py b/mutt-ical.py index 1979e83..e1cd98c 100755 --- a/mutt-ical.py +++ b/mutt-ical.py @@ -27,6 +27,7 @@ -d decline -t tentatively accept (accept is default, last one wins) + -s -D display only """ % sys.argv[0] @@ -146,7 +147,7 @@ def display(ical): def sendmail(): mutt_setting = subprocess.check_output(["mutt", "-Q", "sendmail"]) - return mutt_setting.strip().decode().split("=")[1].replace('"', '').split() + return mutt_setting.strip().decode().split('sendmail=')[1].replace('"', '').split() def organizer(ical): if 'organizer' in ical.vevent.contents: @@ -158,9 +159,10 @@ def organizer(ical): raise("no organizer in event") if __name__=="__main__": + sendmail = None email_address = None accept_decline = 'ACCEPTED' - opts, args=getopt(sys.argv[1:],"e:aidtD") + opts, args=getopt(sys.argv[1:],"s:e:aidtD") if len(args) < 1: sys.stderr.write(usage) @@ -172,6 +174,8 @@ def organizer(ical): for opt,arg in opts: if opt == '-D': sys.exit(0) + if opt == '-s': + sendmail = arg.split() if opt == '-e': email_address = arg if opt == '-i': @@ -220,5 +224,6 @@ def organizer(ical): message.add_alternative(ans.serialize(), subtype='calendar', params={ 'method': 'REPLY' }) - - execute(sendmail() + ['--', to], message.as_bytes()) + if not sendmail: + sendmail = sendmail() + execute(sendmail + ['--', to], message.as_bytes())