home *** CD-ROM | disk | FTP | other *** search
/ PC World 2003 March / PCWorld_2003-03_cd.bin / Software / Vyzkuste / phptriad / phptriad2-2-1.exe / php / pear / Mail / smtp.php < prev    next >
Encoding:
PHP Script  |  2001-11-13  |  5.7 KB  |  143 lines

  1. <?php
  2. //
  3. // +----------------------------------------------------------------------+
  4. // | PHP version 4.0                                                      |
  5. // +----------------------------------------------------------------------+
  6. // | Copyright (c) 1997-2001 The PHP Group                                |
  7. // +----------------------------------------------------------------------+
  8. // | This source file is subject to version 2.02 of the PHP license,      |
  9. // | that is bundled with this package in the file LICENSE, and is        |
  10. // | available at through the world-wide-web at                           |
  11. // | http://www.php.net/license/2_02.txt.                                 |
  12. // | If you did not receive a copy of the PHP license and are unable to   |
  13. // | obtain it through the world-wide-web, please send a note to          |
  14. // | license@php.net so we can mail you a copy immediately.               |
  15. // +----------------------------------------------------------------------+
  16. // | Authors: Chuck Hagenbuch <chuck@horde.org>                           |
  17. // +----------------------------------------------------------------------+
  18.  
  19. require_once 'Mail.php';
  20.  
  21. /**
  22.  * SMTP implementation of the PEAR Mail:: interface. Requires the PEAR
  23.  * Net_SMTP:: class.
  24.  * @access public
  25.  * @package Mail
  26.  * @version $Revision: 1.6.2.3 $ 
  27.  */
  28. class Mail_smtp extends Mail {
  29.     
  30.     /**
  31.      * The SMTP host to connect to.
  32.      * @var    string
  33.      */
  34.     var $host = 'localhost';
  35.     
  36.     /**
  37.      * The port the SMTP server is on.
  38.      * @var    integer
  39.      */
  40.     var $port = 25;
  41.     
  42.     /**
  43.      * Whether or not to attempt to authenticate to the SMTP server.
  44.      * @var boolean
  45.      */
  46.     var $auth = false;
  47.     
  48.     /**
  49.      * The username to use if the SMTP server requires authentication.
  50.      * @var string
  51.      */
  52.     var $username = '';
  53.     
  54.     /**
  55.      * The password to use if the SMTP server requires authentication.
  56.      * @var string
  57.      */
  58.     var $password = '';
  59.     
  60.     /**
  61.      * Constructor.
  62.      * 
  63.      * Instantiates a new Mail_smtp:: object based on the parameters
  64.      * passed in. It looks for the following parameters:
  65.      *     host        The server to connect to. Defaults to localhost.
  66.      *     port        The port to connect to. Defaults to 25.
  67.      *     auth        Whether or not to use SMTP auth. Defaults to false.
  68.      *     username    The username to use for SMTP auth. No default.
  69.      *     password    The password to use for SMTP auth. No default.
  70.      *
  71.      * If a parameter is present in the $params array, it replaces the
  72.      * default.
  73.      *
  74.      * @param array Hash containing any parameters different from the
  75.      *              defaults.
  76.      * @access public
  77.      */    
  78.     function Mail_smtp($params)
  79.     {
  80.         if (isset($params['host'])) $this->host = $params['host'];
  81.         if (isset($params['port'])) $this->port = $params['port'];
  82.         if (isset($params['auth'])) $this->auth = $params['auth'];
  83.         if (isset($params['username'])) $this->username = $params['username'];
  84.         if (isset($params['password'])) $this->password = $params['password'];
  85.     }
  86.     
  87.     /**
  88.      * Implements Mail::send() function using SMTP.
  89.      * 
  90.      * @param mixed $recipients Either a comma-seperated list of recipients
  91.      *              (RFC822 compliant), or an array of recipients,
  92.      *              each RFC822 valid. This may contain recipients not
  93.      *              specified in the headers, for Bcc:, resending
  94.      *              messages, etc.
  95.      *
  96.      * @param array $headers The array of headers to send with the mail, in an
  97.      *              associative array, where the array key is the
  98.      *              header name (ie, 'Subject'), and the array value
  99.      *              is the header value (ie, 'test'). The header
  100.      *              produced from those values would be 'Subject:
  101.      *              test'.
  102.      *
  103.      * @param string $body The full text of the message body, including any
  104.      *               Mime parts, etc.
  105.      *
  106.      * @return mixed Returns true on success, or a PEAR_Error
  107.      *               containing a descriptive error message on
  108.      *               failure.
  109.      * @access public
  110.      */
  111.     function send($recipients, $headers, $body)
  112.     {
  113.         include_once 'Net/SMTP.php';
  114.         
  115.         if (!($smtp = new Net_SMTP($this->host, $this->port))) { return new PEAR_Error('unable to instantiate Net_SMTP object'); }
  116.         if (PEAR::isError($smtp->connect())) { return new PEAR_Error('unable to connect to smtp server ' . $this->host . ':' . $this->port); }
  117.         
  118.         if ($this->auth) {
  119.             if (PEAR::isError($smtp->auth($this->username, $this->password))) { return new PEAR_Error('unable to authenticate to smtp server'); }
  120.             if (PEAR::isError($smtp->identifySender())) { return new PEAR_Error('unable to identify smtp server'); }
  121.         }
  122.         
  123.         list($from, $text_headers) = $this->prepareHeaders($headers);
  124.         if (!isset($from)) {
  125.             return new PEAR_Error('No from address given');
  126.         }
  127.         
  128.         if (PEAR::isError($smtp->mailFrom($from))) { return new PEAR_Error('unable to set sender to [' . $from . ']'); }
  129.         
  130.         $recipients = $this->parseRecipients($recipients);
  131.         foreach($recipients as $recipient) {
  132.             if (PEAR::isError($res = $smtp->rcptTo($recipient))) { return new PEAR_Error('unable to add recipient [' . $recipient . ']: ' . $res->getMessage()); }
  133.         }
  134.         
  135.         if (PEAR::isError($smtp->data($text_headers . "\n" . $body))) { return new PEAR_Error('unable to send data'); }
  136.         
  137.         $smtp->disconnect();
  138.         return true;
  139.     }
  140.     
  141. }
  142. ?>
  143.