Fixed issue #14098: When sending mail, use TYPO3_CONF_VAR for default from address...
authorIngo Renner <ingo.renner@typo3.org>
Thu, 20 Jan 2011 18:24:17 +0000 (18:24 +0000)
committerIngo Renner <ingo.renner@typo3.org>
Thu, 20 Jan 2011 18:24:17 +0000 (18:24 +0000)
git-svn-id: https://svn.typo3.org/TYPO3v4/Core/trunk@10167 709f56b5-9817-0410-a4d7-c38de5d9e867

ChangeLog
t3lib/config_default.php
t3lib/utility/class.t3lib_utility_mail.php

index 38a1ab1..cfbdca3 100755 (executable)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+2011-01-20  Ingo Renner  <ingo@typo3.org>
+
+       * Fixed issue #14098: When sending mail, use TYPO3_CONF_VAR for default from address if no other address is provided, credits Jeff Segars and Marcus Krause
+
 2011-01-20  Tolleiv Nietsch  <typo3@tolleiv.de>
 
        * Fixed bug #17105: deprecate "disable_autocreate" feature
@@ -17,7 +21,7 @@
 
 2011-01-20  Steffen Kamper  <steffen@typo3.org>
 
-       * Fixed bug #17162: Missing localization in t3lib_tsstyleconfig 
+       * Fixed bug #17162: Missing localization in t3lib_tsstyleconfig
 
 2011-01-20  Steffen Gebert  <steffen@steffen-gebert.de>
 
index 047874a..d6ad0de 100644 (file)
@@ -92,6 +92,7 @@ $TYPO3_CONF_VARS = array(
                'dbClientCompress' => FALSE,                    // Boolean: if true, data exchange between TYPO3 and database server will be compressed. This may improve performance if (1) database serever is on the different server and (2) network connection speed to database server is 100mbps or less. CPU usage will be higher if this option is used but database operations will be executed faster due to much less (up to 3 times) database network traffic. This option has no effect if MySQL server is localhost.
                'setMemoryLimit' => 0,                                  // Integer: memory_limit in MB: If more than 16, TYPO3 will try to use ini_set() to set the memory limit of PHP to the value. This works only if the function ini_set() is not disabled by your sysadmin.
                'forceReturnPath' => FALSE,                             // Boolean: Force return path to be applied in mail() calls. If this is set, all calls to mail() done by t3lib_htmlmail will be called with '-f&lt;return_path&gt; as the 5th parameter. This will make the return path correct on almost all Unix systems. There is a known problem with Postfix below version 2: Mails are not sent if this option is set and Postfix is used. On Windows platforms, the return path is set via a call to ini_set. This has no effect if safe_mode in PHP is on.
+               'defaultMailFromAddress' => '',                 // String: This default name and email address is used when no other "from" value is set for a TYPO3-generated email. You can specify an email address only (ex. info@test.test) or a name and email address (ex. My Website <info@test.test>).
                'serverTimeZone' => 1,                                  // Integer: GMT offset of servers time (from time()). Default is "1" which is "GMT+1" (central european time). This value can be used in extensions that are GMT aware and wants to convert times to/from other timezones.
                'phpTimeZone' => '',                                    // String: timezone to force for all date() and mktime() functions. A list of supported values can be found at <a href="http://php.net/manual/en/timezones.php" target="_blank">php.net</a>. If this is not set, a valid fallback will be searched for by PHP (php.ini's <a href="http://www.php.net/manual/en/datetime.configuration.php#ini.date.timezone" target="_blank">date.timezone</a> setting, server defaults, etc); and if no fallback is found, the value of "UTC" is used instead.
                'systemLog' => '',                                              // <p>String: semi-colon separated list. Defines one or more logging methods. Possible methods:</p><dl><dt>file,&lt;abs-path-to-file&gt;[,&lt;level&gt;]</dt><dd>logs to a file</dd><dt>mail,&lt;to&gt;[/&lt;from&gt;][,&lt;level&gt;]</dt><dd>sends the log entries via mail</dd><dt>syslog,&lt;facility&gt;,[,&lt;level&gt;]</dt><dd>uses the operating system's log. Facility may be one of LOCAL0..LOCAL7, USER (on Windows USER is the only valid type).</dd><dt>error_log[,,&lt;level&gt;]</dt><dd>uses the PHP error log</dd></dl><p>The &lt;level&gt; is the individual logging level (see <a href="#SYS-systemLogLevel">[SYS][systemLogLevel]</a>).</p>
index d78aaad..f2b7aff 100644 (file)
@@ -53,6 +53,15 @@ final class t3lib_utility_Mail {
         */
        public static function mail($to, $subject, $messageBody, $additionalHeaders = NULL, $additionalParameters = NULL) {
                $success = TRUE;
+
+                       // If the mail does not have a From: header, fall back to the default in TYPO3_CONF_VARS.
+               if (!preg_match('/^From:/im', $additionalHeaders) && $GLOBALS['TYPO3_CONF_VARS']['SYS']['defaultMailFromAddress']) {
+                       if (!is_null($additionalHeaders) && substr($additionalHeaders, -1) != LF) {
+                               $additionalHeaders .= LF;
+                       }
+                       $additionalHeaders .= 'From: ' . $GLOBALS['TYPO3_CONF_VARS']['SYS']['defaultMailFromAddress'];
+               }
+
                if (is_array($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['t3lib/utility/class.t3lib_utility_mail.php']['substituteMailDelivery'])) {
                        $parameters = array(
                                'to' => $to,