| | |
| | | $this->debug('C: ' . $log); |
| | | } |
| | | |
| | | $res = fwrite($this->fp, $string . ($endln ? "\r\n" : '')); |
| | | if ($endln) { |
| | | $string .= "\r\n"; |
| | | } |
| | | |
| | | $res = fwrite($this->fp, $string); |
| | | |
| | | if ($res === false) { |
| | | @fclose($this->fp); |
| | |
| | | } |
| | | } |
| | | } |
| | | |
| | | return $res; |
| | | } |
| | | |
| | |
| | | return false; |
| | | } |
| | | |
| | | // There is no flag to enable all TLS methods. Net_SMTP |
| | | // handles enabling TLS similarly. |
| | | $crypto_method = STREAM_CRYPTO_METHOD_TLS_CLIENT |
| | | | @STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT |
| | | | @STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT; |
| | | if (isset($this->prefs['socket_options']['ssl']['crypto_method'])) { |
| | | $crypto_method = $this->prefs['socket_options']['ssl']['crypto_method']; |
| | | } |
| | | else { |
| | | // There is no flag to enable all TLS methods. Net_SMTP |
| | | // handles enabling TLS similarly. |
| | | $crypto_method = STREAM_CRYPTO_METHOD_TLS_CLIENT |
| | | | @STREAM_CRYPTO_METHOD_TLSv1_1_CLIENT |
| | | | @STREAM_CRYPTO_METHOD_TLSv1_2_CLIENT; |
| | | } |
| | | |
| | | if (!stream_socket_enable_crypto($this->fp, true, $crypto_method)) { |
| | | $this->setError(self::ERROR_BAD, "Unable to negotiate TLS"); |
| | |
| | | */ |
| | | public function connected() |
| | | { |
| | | return ($this->fp && $this->logged) ? true : false; |
| | | return $this->fp && $this->logged; |
| | | } |
| | | |
| | | /** |
| | |
| | | if (!is_array($entries)) { |
| | | $entries = array($entries); |
| | | } |
| | | |
| | | // create entries string |
| | | // ANNOTATEMORE drafts before version 08 require quoted parameters |
| | | foreach ($entries as $idx => $name) { |
| | |
| | | if (!is_array($attribs)) { |
| | | $attribs = array($attribs); |
| | | } |
| | | // create entries string |
| | | |
| | | // create attributes string |
| | | foreach ($attribs as $idx => $name) { |
| | | $attribs[$idx] = $this->escape($name, true); |
| | | } |
| | |
| | | if (!is_numeric(($bytes = substr($str, 1, $epos - 1)))) { |
| | | // error |
| | | } |
| | | |
| | | $result[] = $bytes ? substr($str, $epos + 3, $bytes) : ''; |
| | | // Advance the string |
| | | $str = substr($str, $epos + 3 + $bytes); |
| | | $str = substr($str, $epos + 3 + $bytes); |
| | | break; |
| | | |
| | | // Quoted string |
| | |
| | | } |
| | | } |
| | | } |
| | | if ($str[$pos] != '"') { |
| | | // error |
| | | } |
| | | |
| | | // we need to strip slashes for a quoted string |
| | | $result[] = stripslashes(substr($str, 1, $pos - 1)); |
| | | $str = substr($str, $pos + 1); |
| | |
| | | |
| | | // Parenthesized list |
| | | case '(': |
| | | $str = substr($str, 1); |
| | | $str = substr($str, 1); |
| | | $result[] = self::tokenizeResponse($str); |
| | | break; |
| | | |
| | | case ')': |
| | | $str = substr($str, 1); |
| | | return $result; |
| | | break; |
| | | |
| | | // String atom, number, astring, NIL, *, % |
| | | default: |
| | |
| | | // we do not exclude [ and ] (#1489223) |
| | | if (preg_match('/^([^\x00-\x20\x29\x7F]+)/', $str, $m)) { |
| | | $result[] = $m[1] == 'NIL' ? null : $m[1]; |
| | | $str = substr($str, strlen($m[1])); |
| | | $str = substr($str, strlen($m[1])); |
| | | } |
| | | break; |
| | | } |