summaryrefslogtreecommitdiff
path: root/win32
diff options
context:
space:
mode:
authorMarkus Fischer <mfischer@php.net>2002-05-14 15:29:28 +0000
committerMarkus Fischer <mfischer@php.net>2002-05-14 15:29:28 +0000
commit0815b55950df34aa1dfd63fad56edbf1940752c3 (patch)
treebc58327e55862af4d0c46aafca2adf9ca6944582 /win32
parent87286cdb3fbef1c6856c2431283f3186689d7c65 (diff)
downloadphp-git-0815b55950df34aa1dfd63fad56edbf1940752c3.tar.gz
- Try to find From: field in header, fallback to sendmail_from php.ini setting
(Original patch by Michael Sisolak <msisolak@yahoo.com>, enhanced a bit). @- Win32 mail() supports parsing 'From:' field from header (msisolak@yahoo.com, Markus).
Diffstat (limited to 'win32')
-rw-r--r--win32/sendmail.c32
1 files changed, 29 insertions, 3 deletions
diff --git a/win32/sendmail.c b/win32/sendmail.c
index 4ccebfe12d..481b603012 100644
--- a/win32/sendmail.c
+++ b/win32/sendmail.c
@@ -88,7 +88,7 @@ static char *ErrorMessages[] =
{"Bad Message Return Path"},
{"Bad Mail Host"},
{"Bad Message File"},
- {"\"sendmail_from\" NOT set in php.ini"},
+ {"\"sendmail_from\" not set in php.ini"},
{"Mailserver rejected our \"sendmail_from\" setting"} /* 20 */
};
@@ -125,11 +125,37 @@ int TSendMail(char *host, int *error,
strcpy(MailHost, host);
}
- if (INI_STR("sendmail_from")){
- RPath = estrdup(INI_STR("sendmail_from"));
+ /* use from address as return path (if specified in headers) */
+ if (headers) {
+ char *pos = NULL;
+ /* Try to match 'From:' only at start of the string or after following a \r\n */
+ if (strstr(headers, "\r\nFrom:")) {
+ pos = strstr(headers, "\r\nFrom:") + 7;
+ } else if (!strncmp(headers, "From:", 5)) {
+ pos = headers + 5;
+ }
+ if (pos) {
+ char *pos_end;
+ /* Ignore any whitespaces */
+ while (pos && ((*pos == ' ' || *pos == '\t')))
+ pos++;
+ /* Match until \r\n or end of header string */
+ if (pos_end = strstr(pos, "\r\n")) {
+ RPath = estrndup(pos, pos_end - pos);
+ } else {
+ RPath = estrndup(pos, strlen(pos));
+ }
+ }
+ }
+
+ /* Fall back to sendmail_from php.ini setting */
+ if (!RPath) {
+ if (INI_STR("sendmail_from")) {
+ RPath = estrdup(INI_STR("sendmail_from"));
} else {
*error = W32_SM_SENDMAIL_FROM_NOT_SET;
return FAILURE;
+ }
}
/* attempt to connect with mail host */