123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816 |
- <?php
- /**
- * @file
- * SMTP mail transport class for the smtp module,based on code of the phpmailer
- * library, customized and relicensed to GPLv2
- *
- */
- /*~ class.smtp.php
- Original release information:
- .---------------------------------------------------------------------------.
- | Software: PHPMailer - PHP email class |
- | Version: 5.1 |
- | Contact: via sourceforge.net support pages (also www.codeworxtech.com) |
- | Info: http://phpmailer.sourceforge.net |
- | Support: http://sourceforge.net/projects/phpmailer/ |
- | ------------------------------------------------------------------------- |
- | Admin: Andy Prevost (project admininistrator) |
- | Authors: Andy Prevost (codeworxtech) codeworxtech@users.sourceforge.net |
- | : Marcus Bointon (coolbru) coolbru@users.sourceforge.net |
- | Founder: Brent R. Matzelle (original founder) |
- | Copyright (c) 2004-2009, Andy Prevost. All Rights Reserved. |
- | Copyright (c) 2001-2003, Brent R. Matzelle |
- | ------------------------------------------------------------------------- |
- | License: Distributed under the Lesser General Public License (LGPL) |
- | http://www.gnu.org/copyleft/lesser.html |
- | This program is distributed in the hope that it will be useful - WITHOUT |
- | ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
- | FITNESS FOR A PARTICULAR PURPOSE. |
- | ------------------------------------------------------------------------- |
- | We offer a number of paid services (www.codeworxtech.com): |
- | - Web Hosting on highly optimized fast and secure servers |
- | - Technology Consulting |
- | - Oursourcing (highly qualified programmers and graphic designers) |
- '---------------------------------------------------------------------------'
- */
- /**
- * PHPMailer - PHP SMTP email transport class
- * NOTE: Designed for use with PHP version 5 and up
- * @package PHPMailer
- * @author Andy Prevost
- * @author Marcus Bointon
- * @copyright 2004 - 2008 Andy Prevost
- */
- /**
- * SMTP is rfc 821 compliant and implements all the rfc 821 SMTP
- * commands except TURN which will always return a not implemented
- * error. SMTP also provides some utility methods for sending mail
- * to an SMTP server.
- * original author: Chris Ryan
- */
- class SMTP {
- /**
- * SMTP server port
- * @var int
- */
- public $SMTP_PORT = 25;
- /**
- * SMTP reply line ending
- * @var string
- */
- public $CRLF = "\r\n";
- /**
- * Sets whether debugging is turned on
- * @var bool
- */
- public $do_debug; // the level of debug to perform
- /**
- * Sets VERP use on/off (default is off)
- * @var bool
- */
- public $do_verp = FALSE;
- /////////////////////////////////////////////////
- // PROPERTIES, PRIVATE AND PROTECTED
- /////////////////////////////////////////////////
- private $smtp_conn; // the socket to the server
- private $error; // error if any on the last call
- private $helo_rply; // the reply the server sent to us for HELO
- /**
- * Initialize the class so that the data is in a known state.
- * @access public
- * @return void
- */
- public function __construct() {
- $this->smtp_conn = 0;
- $this->error = NULL;
- $this->helo_rply = NULL;
- $this->do_debug = 0;
- }
- /////////////////////////////////////////////////
- // CONNECTION FUNCTIONS
- /////////////////////////////////////////////////
- /**
- * Connect to the server specified on the port specified.
- * If the port is not specified use the default SMTP_PORT.
- * If tval is specified then a connection will try and be
- * established with the server for that number of seconds.
- * If tval is not specified the default is 30 seconds to
- * try on the connection.
- *
- * SMTP CODE SUCCESS: 220
- * SMTP CODE FAILURE: 421
- * @access public
- * @return bool
- */
- public function Connect($host, $port = 0, $tval = 30) {
- // set the error val to NULL so there is no confusion
- $this->error = NULL;
- // make sure we are __not__ connected
- if ($this->connected()) {
- // already connected, generate error
- $this->error = array("error" => "Already connected to a server");
- return FALSE;
- }
- if (empty($port)) {
- $port = $this->SMTP_PORT;
- }
- // connect to the smtp server
- $this->smtp_conn = @fsockopen($host, // the host of the server
- $port, // the port to use
- $errno, // error number if any
- $errstr, // error message if any
- $tval); // give up after ? secs
- // verify we connected properly
- if (empty($this->smtp_conn)) {
- $this->error = array("error" => "Failed to connect to server",
- "errno" => $errno,
- "errstr" => $errstr);
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @errstr (@errno)", array("@error" => $this->error["error"], "@errstr" => $errstr, "@errno" => $errno)));
- }
- return FALSE;
- }
- // SMTP server can take longer to respond, give longer timeout for first read
- // Windows does not have support for this timeout function
- if (substr(PHP_OS, 0, 3) != "WIN")
- socket_set_timeout($this->smtp_conn, $tval, 0);
- // get any announcement
- $announce = $this->get_lines();
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @announce", array("@announce" => $announce)));
- }
- return TRUE;
- }
- /**
- * Initiate a TLS communication with the server.
- *
- * SMTP CODE 220 Ready to start TLS
- * SMTP CODE 501 Syntax error (no parameters allowed)
- * SMTP CODE 454 TLS not available due to temporary reason
- * @access public
- * @return bool success
- */
- public function StartTLS() {
- $this->error = NULL; # to avoid confusion
- if (!$this->connected()) {
- $this->error = array("error" => "Called StartTLS() without being connected");
- return FALSE;
- }
- fputs($this->smtp_conn, "STARTTLS" . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 220) {
- $this->error =
- array("error" => "STARTTLS not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- // Begin encrypted connection
- if (!stream_socket_enable_crypto($this->smtp_conn, TRUE, STREAM_CRYPTO_METHOD_TLS_CLIENT)) {
- return FALSE;
- }
- return TRUE;
- }
- /**
- * Performs SMTP authentication. Must be run after running the
- * Hello() method. Returns TRUE if successfully authenticated.
- * @access public
- * @return bool
- */
- public function Authenticate($username, $password) {
- // Start authentication
- fputs($this->smtp_conn, "AUTH LOGIN" . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($code != 334) {
- $this->error =
- array("error" => "AUTH not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- // Send encoded username
- fputs($this->smtp_conn, base64_encode($username) . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($code != 334) {
- $this->error =
- array("error" => "Username not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- // Send encoded password
- fputs($this->smtp_conn, base64_encode($password) . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($code != 235) {
- $this->error =
- array("error" => "Password not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- return TRUE;
- }
- /**
- * Returns TRUE if connected to a server otherwise FALSE
- * @access public
- * @return bool
- */
- public function Connected() {
- if (!empty($this->smtp_conn)) {
- $sock_status = socket_get_status($this->smtp_conn);
- if ($sock_status["eof"]) {
- // the socket is valid but we are not connected
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> NOTICE: EOF caught while checking if connected"));
- }
- $this->Close();
- return FALSE;
- }
- return TRUE; // everything looks good
- }
- return FALSE;
- }
- /**
- * Closes the socket and cleans up the state of the class.
- * It is not considered good to use this function without
- * first trying to use QUIT.
- * @access public
- * @return void
- */
- public function Close() {
- $this->error = NULL; // so there is no confusion
- $this->helo_rply = NULL;
- if (!empty($this->smtp_conn)) {
- // close the connection and cleanup
- fclose($this->smtp_conn);
- $this->smtp_conn = 0;
- }
- }
- /////////////////////////////////////////////////
- // SMTP COMMANDS
- /////////////////////////////////////////////////
- /**
- * Issues a data command and sends the msg_data to the server
- * finializing the mail transaction. $msg_data is the message
- * that is to be send with the headers. Each header needs to be
- * on a single line followed by a <CRLF> with the message headers
- * and the message body being separated by and additional <CRLF>.
- *
- * Implements rfc 821: DATA <CRLF>
- *
- * SMTP CODE INTERMEDIATE: 354
- * [data]
- * <CRLF>.<CRLF>
- * SMTP CODE SUCCESS: 250
- * SMTP CODE FAILURE: 552,554,451,452
- * SMTP CODE FAILURE: 451,554
- * SMTP CODE ERROR : 500,501,503,421
- * @access public
- * @return bool
- */
- public function Data($msg_data) {
- $this->error = NULL; // so no confusion is caused
- if (!$this->connected()) {
- $this->error = array(
- "error" => "Called Data() without being connected");
- return FALSE;
- }
- fputs($this->smtp_conn, "DATA" . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 354) {
- $this->error =
- array("error" => "DATA command not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- /* the server is ready to accept data!
- * according to rfc 821 we should not send more than 1000
- * including the CRLF
- * characters on a single line so we will break the data up
- * into lines by \r and/or \n then if needed we will break
- * each of those into smaller lines to fit within the limit.
- * in addition we will be looking for lines that start with
- * a period '.' and append and additional period '.' to that
- * line. NOTE: this does not count towards limit.
- */
- // normalize the line breaks so we know the explode works
- $msg_data = str_replace("\r\n", "\n", $msg_data);
- $msg_data = str_replace("\r", "\n", $msg_data);
- $lines = explode("\n", $msg_data);
- /* we need to find a good way to determine is headers are
- * in the msg_data or if it is a straight msg body
- * currently I am assuming rfc 822 definitions of msg headers
- * and if the first field of the first line (':' sperated)
- * does not contain a space then it _should_ be a header
- * and we can process all lines before a blank "" line as
- * headers.
- */
- $field = substr($lines[0], 0, strpos($lines[0], ":"));
- $in_headers = FALSE;
- if (!empty($field) && !strstr($field, " ")) {
- $in_headers = TRUE;
- }
- $max_line_length = 998; // used below; set here for ease in change
- while (list(, $line) = @each($lines)) {
- $lines_out = NULL;
- if ($line == "" && $in_headers) {
- $in_headers = FALSE;
- }
- // ok we need to break this line up into several smaller lines
- while (strlen($line) > $max_line_length) {
- $pos = strrpos(substr($line, 0, $max_line_length), " ");
- // Patch to fix DOS attack
- if (!$pos) {
- $pos = $max_line_length - 1;
- $lines_out[] = substr($line, 0, $pos);
- $line = substr($line, $pos);
- }
- else {
- $lines_out[] = substr($line, 0, $pos);
- $line = substr($line, $pos + 1);
- }
- /* if processing headers add a LWSP-char to the front of new line
- * rfc 822 on long msg headers
- */
- if ($in_headers) {
- $line = "\t" . $line;
- }
- }
- $lines_out[] = $line;
- // send the lines to the server
- while (list(, $line_out) = @each($lines_out)) {
- if (strlen($line_out) > 0) {
- if (substr($line_out, 0, 1) == ".") {
- $line_out = "." . $line_out;
- }
- }
- fputs($this->smtp_conn, $line_out . $this->CRLF);
- }
- }
- // message data has been sent
- fputs($this->smtp_conn, $this->CRLF . "." . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 250) {
- $this->error =
- array("error" => "DATA not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- return TRUE;
- }
- /**
- * Sends the HELO command to the smtp server.
- * This makes sure that we and the server are in
- * the same known state.
- *
- * Implements from rfc 821: HELO <SP> <domain> <CRLF>
- *
- * SMTP CODE SUCCESS: 250
- * SMTP CODE ERROR : 500, 501, 504, 421
- * @access public
- * @return bool
- */
- public function Hello($host = '') {
- $this->error = NULL; // so no confusion is caused
- if (!$this->connected()) {
- $this->error = array(
- "error" => "Called Hello() without being connected");
- return FALSE;
- }
- // if hostname for HELO was not specified send default
- if (empty($host)) {
- // determine appropriate default to send to server
- $host = "localhost";
- }
- // Send extended hello first (RFC 2821)
- if (!$this->SendHello("EHLO", $host)) {
- if (!$this->SendHello("HELO", $host)) {
- return FALSE;
- }
- }
- return TRUE;
- }
- /**
- * Sends a HELO/EHLO command.
- * @access private
- * @return bool
- */
- private function SendHello($hello, $host) {
- fputs($this->smtp_conn, $hello . " " . $host . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 250) {
- $this->error =
- array("error" => $hello . " not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- $this->helo_rply = $rply;
- return TRUE;
- }
- /**
- * Starts a mail transaction from the email address specified in
- * $from. Returns TRUE if successful or FALSE otherwise. If True
- * the mail transaction is started and then one or more Recipient
- * commands may be called followed by a Data command.
- *
- * Implements rfc 821: MAIL <SP> FROM:<reverse-path> <CRLF>
- *
- * SMTP CODE SUCCESS: 250
- * SMTP CODE SUCCESS: 552,451,452
- * SMTP CODE SUCCESS: 500,501,421
- * @access public
- * @return bool
- */
- public function Mail($from) {
- $this->error = NULL; // so no confusion is caused
- if (!$this->connected()) {
- $this->error = array(
- "error" => "Called Mail() without being connected");
- return FALSE;
- }
- $useVerp = ($this->do_verp ? "XVERP" : "");
- fputs($this->smtp_conn, "MAIL FROM:<" . $from . ">" . $useVerp . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 250) {
- $this->error =
- array("error" => "MAIL not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- return TRUE;
- }
- /**
- * Sends the quit command to the server and then closes the socket
- * if there is no error or the $close_on_error argument is TRUE.
- *
- * Implements from rfc 821: QUIT <CRLF>
- *
- * SMTP CODE SUCCESS: 221
- * SMTP CODE ERROR : 500
- * @access public
- * @return bool
- */
- public function Quit($close_on_error = TRUE) {
- $this->error = NULL; // so there is no confusion
- if (!$this->connected()) {
- $this->error = array(
- "error" => "Called Quit() without being connected");
- return FALSE;
- }
- // send the quit command to the server
- fputs($this->smtp_conn, "quit" . $this->CRLF);
- // get any good-bye messages
- $byemsg = $this->get_lines();
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @byemsg", array("@rply" => $byemsg)));
- }
- $rval = TRUE;
- $e = NULL;
- $code = substr($byemsg, 0, 3);
- if ($code != 221) {
- // use e as a tmp var cause Close will overwrite $this->error
- $e = array("error" => "SMTP server rejected quit command",
- "smtp_code" => $code,
- "smtp_rply" => substr($byemsg, 4));
- $rval = FALSE;
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- }
- if (empty($e) || $close_on_error) {
- $this->Close();
- }
- return $rval;
- }
- /**
- * Sends the command RCPT to the SMTP server with the TO: argument of $to.
- * Returns TRUE if the recipient was accepted FALSE if it was rejected.
- *
- * Implements from rfc 821: RCPT <SP> TO:<forward-path> <CRLF>
- *
- * SMTP CODE SUCCESS: 250,251
- * SMTP CODE FAILURE: 550,551,552,553,450,451,452
- * SMTP CODE ERROR : 500,501,503,421
- * @access public
- * @return bool
- */
- public function Recipient($to) {
- $this->error = NULL; // so no confusion is caused
- if (!$this->connected()) {
- $this->error = array(
- "error" => "Called Recipient() without being connected");
- return FALSE;
- }
- fputs($this->smtp_conn, "RCPT TO:<" . $to . ">" . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 250 && $code != 251) {
- $this->error =
- array("error" => "RCPT not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- return TRUE;
- }
- /**
- * Sends the RSET command to abort and transaction that is
- * currently in progress. Returns TRUE if successful FALSE
- * otherwise.
- *
- * Implements rfc 821: RSET <CRLF>
- *
- * SMTP CODE SUCCESS: 250
- * SMTP CODE ERROR : 500,501,504,421
- * @access public
- * @return bool
- */
- public function Reset() {
- $this->error = NULL; // so no confusion is caused
- if (!$this->connected()) {
- $this->error = array(
- "error" => "Called Reset() without being connected");
- return FALSE;
- }
- fputs($this->smtp_conn, "RSET" . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 250) {
- $this->error =
- array("error" => "RSET failed",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- return TRUE;
- }
- /**
- * Starts a mail transaction from the email address specified in
- * $from. Returns TRUE if successful or FALSE otherwise. If True
- * the mail transaction is started and then one or more Recipient
- * commands may be called followed by a Data command. This command
- * will send the message to the users terminal if they are logged
- * in and send them an email.
- *
- * Implements rfc 821: SAML <SP> FROM:<reverse-path> <CRLF>
- *
- * SMTP CODE SUCCESS: 250
- * SMTP CODE SUCCESS: 552,451,452
- * SMTP CODE SUCCESS: 500,501,502,421
- * @access public
- * @return bool
- */
- public function SendAndMail($from) {
- $this->error = NULL; // so no confusion is caused
- if (!$this->connected()) {
- $this->error = array("error" => "Called SendAndMail() without being connected");
- return FALSE;
- }
- fputs($this->smtp_conn, "SAML FROM:" . $from . $this->CRLF);
- $rply = $this->get_lines();
- $code = substr($rply, 0, 3);
- if ($this->do_debug >= 2) {
- drupal_set_message(t("SMTP -> FROM SERVER: @rply", array("@rply" => $rply)));
- }
- if ($code != 250) {
- $this->error =
- array("error" => "SAML not accepted from server",
- "smtp_code" => $code,
- "smtp_msg" => substr($rply, 4));
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> ERROR: @error: @rply", array("@error" => $this->error["error"], "@rply" => $rply)));
- }
- return FALSE;
- }
- return TRUE;
- }
- /**
- * This is an optional command for SMTP that this class does not
- * support. This method is here to make the RFC821 Definition
- * complete for this class and __may__ be implemented in the future
- *
- * Implements from rfc 821: TURN <CRLF>
- *
- * SMTP CODE SUCCESS: 250
- * SMTP CODE FAILURE: 502
- * SMTP CODE ERROR : 500, 503
- * @access public
- * @return bool
- */
- public function Turn() {
- $this->error = array("error" => "This method, TURN, of the SMTP is not implemented");
- if ($this->do_debug >= 1) {
- drupal_set_message(t("SMTP -> NOTICE: @error", array("@error" => $this->error["error"])));
- }
- return FALSE;
- }
- /**
- * Get the current error
- * @access public
- * @return array
- */
- public function getError() {
- return $this->error;
- }
- /////////////////////////////////////////////////
- // INTERNAL FUNCTIONS
- /////////////////////////////////////////////////
- /**
- * Read in as many lines as possible
- * either before eof or socket timeout occurs on the operation.
- * With SMTP we can tell if we have more lines to read if the
- * 4th character is '-' symbol. If it is a space then we don't
- * need to read anything else.
- * @access private
- * @return string
- */
- private function get_lines() {
- $data = "";
- while ($str = @fgets($this->smtp_conn, 515)) {
- if ($this->do_debug >= 4) {
- drupal_set_message(t("SMTP -> get_lines(): \$data was \"@data\"", array("@data" => $data)));
- drupal_set_message(t("SMTP -> get_lines(): \$str is \"@str\"", array("@str" => $str)));
- }
- $data .= $str;
- if ($this->do_debug >= 4) {
- drupal_set_message(t("SMTP -> get_lines(): \$data was \"@data\"", array("@data" => $data)));
- }
- // if 4th character is a space, we are done reading, break the loop
- if (substr($str, 3, 1) == " ") {
- break;
- }
- }
- return $data;
- }
- }
|