1
Fork 0
mirror of git://git.sv.gnu.org/emacs.git synced 2025-12-15 10:30:25 -08:00

Only look at the headers when computing the envelope from address

* lisp/mail/smtpmail.el (smtpmail-send-it)
(smtpmail-send-queued-mail, smtpmail-via-smtp):
* lisp/mail/sendmail.el (sendmail-send-it): Only look at the
headers when computing the envelope from (bug#47616).
This commit is contained in:
Lars Ingebrigtsen 2021-05-06 12:21:11 +02:00
parent c8c27864aa
commit b69e2699aa
2 changed files with 33 additions and 14 deletions

View file

@ -30,6 +30,7 @@
(require 'mail-utils)
(require 'rfc2047)
(autoload 'message-make-date "message")
(autoload 'message-narrow-to-headers "message")
(defgroup sendmail nil
"Mail sending commands for Emacs."
@ -1177,7 +1178,12 @@ external program defined by `sendmail-program'."
;; local binding in the mail buffer will take effect.
(envelope-from
(and mail-specify-envelope-from
(or (mail-envelope-from) user-mail-address))))
(or (save-restriction
;; Only look at the headers when fetching the
;; envelope address.
(message-narrow-to-headers)
(mail-envelope-from))
user-mail-address))))
(unwind-protect
(with-current-buffer tembuf
(erase-buffer)

View file

@ -207,11 +207,15 @@ for `smtpmail-try-auth-method'.")
;; Examine this variable now, so that
;; local binding in the mail buffer will take effect.
(smtpmail-mail-address
(or (and mail-specify-envelope-from (mail-envelope-from))
(let ((from (mail-fetch-field "from")))
(and from
(cadr (mail-extract-address-components from))))
(smtpmail-user-mail-address)))
(save-restriction
;; Only look at the headers when fetching the
;; envelope address.
(message-narrow-to-headers)
(or (and mail-specify-envelope-from (mail-envelope-from))
(let ((from (mail-fetch-field "from")))
(and from
(cadr (mail-extract-address-components from))))
(smtpmail-user-mail-address))))
(smtpmail-code-conv-from
(if enable-multibyte-characters
(let ((sendmail-coding-system smtpmail-code-conv-from))
@ -434,7 +438,12 @@ for `smtpmail-try-auth-method'.")
(let ((coding-system-for-read 'no-conversion))
(insert-file-contents file-data))
(let ((smtpmail-mail-address
(or (and mail-specify-envelope-from (mail-envelope-from))
(or (and mail-specify-envelope-from
(save-restriction
;; Only look at the headers when fetching the
;; envelope address.
(message-narrow-to-headers)
(mail-envelope-from)))
user-mail-address)))
(if (not (null smtpmail-recipient-address-list))
(when (setq result (smtpmail-via-smtp
@ -677,13 +686,17 @@ Returns an error if the server cannot be contacted."
;; `smtpmail-mail-address' should be set to the appropriate
;; buffer-local value by the caller, but in case not:
(envelope-from
(or smtpmail-mail-address
(and mail-specify-envelope-from
(mail-envelope-from))
(let ((from (mail-fetch-field "from")))
(and from
(cadr (mail-extract-address-components from))))
(smtpmail-user-mail-address)))
(save-restriction
;; Only look at the headers when fetching the
;; envelope address.
(message-narrow-to-headers)
(or smtpmail-mail-address
(and mail-specify-envelope-from
(mail-envelope-from))
(let ((from (mail-fetch-field "from")))
(and from
(cadr (mail-extract-address-components from))))
(smtpmail-user-mail-address))))
process-buffer
result
auth-mechanisms