芝麻web文件管理V1.00
编辑当前文件:/home2/sdektunc/.trash/cepali/lib/horde/framework/Horde/Mail/Transport/Smtphorde.php
* @category Horde * @copyright 2013-2017 Horde LLC * @license http://www.horde.org/licenses/bsd New BSD License * @package Mail */ class Horde_Mail_Transport_Smtphorde extends Horde_Mail_Transport { /** * @deprecated */ public $send8bit = false; /** * SMTP object. * * @var Horde_Smtp */ protected $_smtp = null; /** * Constructor. * * @param array $params Additional parameters: * - chunk_size: (integer) If CHUNKING is supported on the server, the * chunk size (in octets) to send. 0 will disable chunking. * @since Horde_Smtp 1.7.0 * - context: (array) Any context parameters passed to * stream_create_context(). @since Horde_Smtp 1.9.0 * - debug: (string) If set, will output debug information to the stream * provided. The value can be any PHP supported wrapper that * can be opened via fopen(). * DEFAULT: No debug output * - host: (string) The SMTP server. * DEFAULT: localhost * - localhost: (string) The hostname of the localhost. (since Horde_Smtp 1.9.0) * DEFAULT: Auto-determined. * - password: (string) The SMTP password. * DEFAULT: NONE * - port: (string) The SMTP port. * DEFAULT: 587 * - secure: (string) Use SSL or TLS to connect. * DEFAULT: true (use 'tls' option, if available) * - false (No encryption) * - 'ssl' (Auto-detect SSL version) * - 'sslv2' (Force SSL version 2) * - 'sslv3' (Force SSL version 3) * - 'tls' (TLS; started via protocol-level negotation over * unencrypted channel; RECOMMENDED way of initiating secure * connection) * - 'tlsv1' (TLS direct version 1.x connection to server) [@since * Horde_Smtp .3.0] * - true (Use TLS, if available) [@since Horde_Smtp 1.2.0] * DEFAULT: No encryption * - timeout: (integer) Connection timeout, in seconds. * DEFAULT: 30 seconds * - username: (string) The SMTP username. * DEFAULT: NONE * - xoauth2_token: (string) If set, will authenticate via the XOAUTH2 * mechanism (if available) with this token. Either a * string or a Horde_Smtp_Password object (since * Horde_Smtp 1.1.0). */ public function __construct(array $params = array()) { $this->_params = $params; /* SMTP requires CRLF line endings. */ $this->sep = "\r\n"; } /** */ public function __get($name) { switch ($name) { case 'eai': $this->getSMTPObject(); return $this->_smtp->data_intl; } return parent::__get($name); } /** */ public function send($recipients, array $headers, $body) { /* If we don't already have an SMTP object, create one. */ $this->getSMTPObject(); $headers = $this->_sanitizeHeaders($headers); list($from, $textHeaders) = $this->prepareHeaders($headers); $from = $this->_getFrom($from, $headers); $combine = Horde_Stream_Wrapper_Combine::getStream(array( rtrim($textHeaders, $this->sep), $this->sep . $this->sep, $body )); try { $this->_smtp->send($from, $recipients, $combine); } catch (Horde_Smtp_Exception $e) { throw new Horde_Mail_Exception($e); } } /** * Connect to the SMTP server by instantiating a Horde_Smtp object. * * @return Horde_Smtp The SMTP object. * @throws Horde_Mail_Exception */ public function getSMTPObject() { if (!$this->_smtp) { $this->_smtp = new Horde_Smtp($this->_params); try { $this->_smtp->login(); } catch (Horde_Smtp_Exception $e) { throw new Horde_Mail_Exception($e); } } return $this->_smtp; } }