wp/wp-includes/class-pop3.php
author ymh <ymh.work@gmail.com>
Fri, 05 Sep 2025 18:52:52 +0200
changeset 22 8c2e4d02f4ef
parent 21 48c4eec2b7e6
permissions -rw-r--r--
Update WordPress to latest version (6.7) - Sync WordPress core files from latest release - Updated admin interface, blocks, and core functionality - Enhanced block editor features and performance - Security updates and bug fixes - Preserved custom wp-content directory and configuration 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     1
<?php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     2
/**
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     3
 * mail_fetch/setup.php
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     4
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     5
 * Copyright (c) 1999-2011 CDI (cdi@thewebmasters.net) All Rights Reserved
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     6
 * Modified by Philippe Mingo 2001-2009 mingo@rotedic.com
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     7
 * An RFC 1939 compliant wrapper class for the POP3 protocol.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     8
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
     9
 * Licensed under the GNU GPL. For full terms see the file COPYING.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    10
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    11
 * POP3 class
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    12
 *
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    13
 * @copyright 1999-2011 The SquirrelMail Project Team
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    14
 * @license https://opensource.org/licenses/gpl-license.php GNU Public License
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    15
 * @package plugins
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    16
 * @subpackage mail_fetch
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    17
 */
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    18
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    19
class POP3 {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    20
    var $ERROR      = '';       //  Error string.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    21
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    22
    var $TIMEOUT    = 60;       //  Default timeout before giving up on a
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    23
                                //  network operation.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    24
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    25
    var $COUNT      = -1;       //  Mailbox msg count
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    26
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    27
    var $BUFFER     = 512;      //  Socket buffer for socket fgets() calls.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    28
                                //  Per RFC 1939 the returned line a POP3
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    29
                                //  server can send is 512 bytes.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    30
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    31
    var $FP         = '';       //  The connection to the server's
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    32
                                //  file descriptor
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    33
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    34
    var $MAILSERVER = '';       // Set this to hard code the server name
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    35
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    36
    var $DEBUG      = FALSE;    // set to true to echo pop3
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    37
                                // commands and responses to error_log
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    38
                                // this WILL log passwords!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    39
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    40
    var $BANNER     = '';       //  Holds the banner returned by the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    41
                                //  pop server - used for apop()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    42
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    43
    var $ALLOWAPOP  = FALSE;    //  Allow or disallow apop()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    44
                                //  This must be set to true
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    45
                                //  manually
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    46
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    47
	/**
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    48
	 * PHP5 constructor.
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    49
	 */
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    50
    function __construct ( $server = '', $timeout = '' ) {
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    51
        settype($this->BUFFER,"integer");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    52
        if( !empty($server) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    53
            // Do not allow programs to alter MAILSERVER
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    54
            // if it is already specified. They can get around
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    55
            // this if they -really- want to, so don't count on it.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    56
            if(empty($this->MAILSERVER))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    57
                $this->MAILSERVER = $server;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    58
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    59
        if(!empty($timeout)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    60
            settype($timeout,"integer");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    61
            $this->TIMEOUT = $timeout;
22
8c2e4d02f4ef Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents: 21
diff changeset
    62
            // Extend POP3 request timeout to the specified TIMEOUT property.
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    63
            if(function_exists("set_time_limit")){
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    64
                set_time_limit($timeout);
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    65
            }
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    66
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    67
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    68
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    69
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    70
	/**
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    71
	 * PHP4 constructor.
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    72
	 */
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    73
	public function POP3( $server = '', $timeout = '' ) {
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    74
		self::__construct( $server, $timeout );
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    75
	}
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    76
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    77
    function update_timer () {
22
8c2e4d02f4ef Update WordPress to latest version (6.7)
ymh <ymh.work@gmail.com>
parents: 21
diff changeset
    78
        // Extend POP3 request timeout to the specified TIMEOUT property.
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    79
        if(function_exists("set_time_limit")){
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    80
            set_time_limit($this->TIMEOUT);
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
    81
        }
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    82
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    83
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    84
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    85
    function connect ($server, $port = 110)  {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    86
        //  Opens a socket to the specified server. Unless overridden,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    87
        //  port defaults to 110. Returns true on success, false on fail
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    88
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
    89
        // If MAILSERVER is set, override $server with its value.
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    90
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    91
    if (!isset($port) || !$port) {$port = 110;}
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    92
        if(!empty($this->MAILSERVER))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    93
            $server = $this->MAILSERVER;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    94
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    95
        if(empty($server)){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    96
            $this->ERROR = "POP3 connect: " . _("No server specified");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    97
            unset($this->FP);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    98
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
    99
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   100
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   101
        $fp = @fsockopen("$server", $port, $errno, $errstr);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   102
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   103
        if(!$fp) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   104
            $this->ERROR = "POP3 connect: " . _("Error ") . "[$errno] [$errstr]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   105
            unset($this->FP);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   106
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   107
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   108
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   109
        socket_set_blocking($fp,-1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   110
        $this->update_timer();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   111
        $reply = fgets($fp,$this->BUFFER);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   112
        $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   113
        if($this->DEBUG)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   114
            error_log("POP3 SEND [connect: $server] GOT [$reply]",0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   115
        if(!$this->is_ok($reply)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   116
            $this->ERROR = "POP3 connect: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   117
            unset($this->FP);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   118
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   119
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   120
        $this->FP = $fp;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   121
        $this->BANNER = $this->parse_banner($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   122
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   123
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   124
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   125
    function user ($user = "") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   126
        // Sends the USER command, returns true or false
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   127
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   128
        if( empty($user) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   129
            $this->ERROR = "POP3 user: " . _("no login ID submitted");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   130
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   131
        } elseif(!isset($this->FP)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   132
            $this->ERROR = "POP3 user: " . _("connection not established");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   133
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   134
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   135
            $reply = $this->send_cmd("USER $user");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   136
            if(!$this->is_ok($reply)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   137
                $this->ERROR = "POP3 user: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   138
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   139
            } else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   140
                return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   141
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   142
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   143
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   144
    function pass ($pass = "")     {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   145
        // Sends the PASS command, returns # of msgs in mailbox,
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   146
        // returns false (undef) on Auth failure
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   147
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   148
        if(empty($pass)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   149
            $this->ERROR = "POP3 pass: " . _("No password submitted");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   150
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   151
        } elseif(!isset($this->FP)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   152
            $this->ERROR = "POP3 pass: " . _("connection not established");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   153
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   154
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   155
            $reply = $this->send_cmd("PASS $pass");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   156
            if(!$this->is_ok($reply)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   157
                $this->ERROR = "POP3 pass: " . _("Authentication failed") . " [$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   158
                $this->quit();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   159
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   160
            } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   161
                //  Auth successful.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   162
                $count = $this->last("count");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   163
                $this->COUNT = $count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   164
                return $count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   165
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   166
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   167
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   168
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   169
    function apop ($login,$pass) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   170
        //  Attempts an APOP login. If this fails, it'll
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   171
        //  try a standard login. YOUR SERVER MUST SUPPORT
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   172
        //  THE USE OF THE APOP COMMAND!
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   173
        //  (apop is optional per rfc1939)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   174
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   175
        if(!isset($this->FP)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   176
            $this->ERROR = "POP3 apop: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   177
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   178
        } elseif(!$this->ALLOWAPOP) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   179
            $retVal = $this->login($login,$pass);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   180
            return $retVal;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   181
        } elseif(empty($login)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   182
            $this->ERROR = "POP3 apop: " . _("No login ID submitted");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   183
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   184
        } elseif(empty($pass)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   185
            $this->ERROR = "POP3 apop: " . _("No password submitted");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   186
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   187
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   188
            $banner = $this->BANNER;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   189
            if( (!$banner) or (empty($banner)) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   190
                $this->ERROR = "POP3 apop: " . _("No server banner") . ' - ' . _("abort");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   191
                $retVal = $this->login($login,$pass);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   192
                return $retVal;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   193
            } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   194
                $AuthString = $banner;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   195
                $AuthString .= $pass;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   196
                $APOPString = md5($AuthString);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   197
                $cmd = "APOP $login $APOPString";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   198
                $reply = $this->send_cmd($cmd);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   199
                if(!$this->is_ok($reply)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   200
                    $this->ERROR = "POP3 apop: " . _("apop authentication failed") . ' - ' . _("abort");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   201
                    $retVal = $this->login($login,$pass);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   202
                    return $retVal;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   203
                } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   204
                    //  Auth successful.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   205
                    $count = $this->last("count");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   206
                    $this->COUNT = $count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   207
                    return $count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   208
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   209
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   210
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   211
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   212
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   213
    function login ($login = "", $pass = "") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   214
        // Sends both user and pass. Returns # of msgs in mailbox or
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   215
        // false on failure (or -1, if the error occurs while getting
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   216
        // the number of messages.)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   217
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   218
        if( !isset($this->FP) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   219
            $this->ERROR = "POP3 login: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   220
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   221
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   222
            $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   223
            if( !$this->user( $login ) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   224
                //  Preserve the error generated by user()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   225
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   226
            } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   227
                $count = $this->pass($pass);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   228
                if( (!$count) || ($count == -1) ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   229
                    //  Preserve the error generated by last() and pass()
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   230
                    return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   231
                } else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   232
                    return $count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   233
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   234
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   235
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   236
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   237
    function top ($msgNum, $numLines = "0") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   238
        //  Gets the header and first $numLines of the msg body
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   239
        //  returns data in an array with each returned line being
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   240
        //  an array element. If $numLines is empty, returns
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   241
        //  only the header information, and none of the body.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   242
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   243
        if(!isset($this->FP)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   244
            $this->ERROR = "POP3 top: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   245
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   246
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   247
        $this->update_timer();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   248
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   249
        $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   250
        $buffer = $this->BUFFER;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   251
        $cmd = "TOP $msgNum $numLines";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   252
        fwrite($fp, "TOP $msgNum $numLines\r\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   253
        $reply = fgets($fp, $buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   254
        $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   255
        if($this->DEBUG) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   256
            @error_log("POP3 SEND [$cmd] GOT [$reply]",0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   257
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   258
        if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   259
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   260
            $this->ERROR = "POP3 top: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   261
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   262
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   263
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   264
        $count = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   265
        $MsgArray = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   266
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   267
        $line = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   268
        while ( !preg_match('/^\.\r\n/',$line))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   269
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   270
            $MsgArray[$count] = $line;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   271
            $count++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   272
            $line = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   273
            if(empty($line))    { break; }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   274
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   275
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   276
        return $MsgArray;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   277
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   278
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   279
    function pop_list ($msgNum = "") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   280
        //  If called with an argument, returns that msgs' size in octets
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   281
        //  No argument returns an associative array of undeleted
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   282
        //  msg numbers and their sizes in octets
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   283
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   284
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   285
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   286
            $this->ERROR = "POP3 pop_list: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   287
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   288
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   289
        $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   290
        $Total = $this->COUNT;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   291
        if( (!$Total) or ($Total == -1) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   292
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   293
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   294
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   295
        if($Total == 0)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   296
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   297
            return array("0","0");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   298
            // return -1;   // mailbox empty
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   299
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   300
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   301
        $this->update_timer();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   302
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   303
        if(!empty($msgNum))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   304
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   305
            $cmd = "LIST $msgNum";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   306
            fwrite($fp,"$cmd\r\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   307
            $reply = fgets($fp,$this->BUFFER);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   308
            $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   309
            if($this->DEBUG) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   310
                @error_log("POP3 SEND [$cmd] GOT [$reply]",0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   311
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   312
            if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   313
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   314
                $this->ERROR = "POP3 pop_list: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   315
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   316
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   317
            list($junk,$num,$size) = preg_split('/\s+/',$reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   318
            return $size;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   319
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   320
        $cmd = "LIST";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   321
        $reply = $this->send_cmd($cmd);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   322
        if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   323
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   324
            $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   325
            $this->ERROR = "POP3 pop_list: " . _("Error ") .  "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   326
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   327
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   328
        $MsgArray = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   329
        $MsgArray[0] = $Total;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   330
        for($msgC=1;$msgC <= $Total; $msgC++)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   331
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   332
            if($msgC > $Total) { break; }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   333
            $line = fgets($fp,$this->BUFFER);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   334
            $line = $this->strip_clf($line);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   335
            if(strpos($line, '.') === 0)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   336
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   337
                $this->ERROR = "POP3 pop_list: " . _("Premature end of list");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   338
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   339
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   340
            list($thisMsg,$msgSize) = preg_split('/\s+/',$line);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   341
            settype($thisMsg,"integer");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   342
            if($thisMsg != $msgC)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   343
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   344
                $MsgArray[$msgC] = "deleted";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   345
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   346
            else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   347
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   348
                $MsgArray[$msgC] = $msgSize;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   349
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   350
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   351
        return $MsgArray;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   352
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   353
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   354
    function get ($msgNum) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   355
        //  Retrieve the specified msg number. Returns an array
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   356
        //  where each line of the msg is an array element.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   357
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   358
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   359
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   360
            $this->ERROR = "POP3 get: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   361
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   362
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   363
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   364
        $this->update_timer();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   365
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   366
        $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   367
        $buffer = $this->BUFFER;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   368
        $cmd = "RETR $msgNum";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   369
        $reply = $this->send_cmd($cmd);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   370
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   371
        if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   372
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   373
            $this->ERROR = "POP3 get: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   374
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   375
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   376
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   377
        $count = 0;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   378
        $MsgArray = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   379
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   380
        $line = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   381
        while ( !preg_match('/^\.\r\n/',$line))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   382
        {
16
a86126ab1dd4 update enmi-conf
ymh <ymh.work@gmail.com>
parents: 7
diff changeset
   383
            if ( $line[0] == '.' ) { $line = substr($line,1); }
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   384
            $MsgArray[$count] = $line;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   385
            $count++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   386
            $line = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   387
            if(empty($line))    { break; }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   388
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   389
        return $MsgArray;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   390
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   391
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   392
    function last ( $type = "count" ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   393
        //  Returns the highest msg number in the mailbox.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   394
        //  returns -1 on error, 0+ on success, if type != count
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   395
        //  results in a popstat() call (2 element array returned)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   396
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   397
        $last = -1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   398
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   399
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   400
            $this->ERROR = "POP3 last: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   401
            return $last;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   402
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   403
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   404
        $reply = $this->send_cmd("STAT");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   405
        if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   406
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   407
            $this->ERROR = "POP3 last: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   408
            return $last;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   409
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   410
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   411
        $Vars = preg_split('/\s+/',$reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   412
        $count = $Vars[1];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   413
        $size = $Vars[2];
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   414
        settype($count,"integer");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   415
        settype($size,"integer");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   416
        if($type != "count")
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   417
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   418
            return array($count,$size);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   419
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   420
        return $count;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   421
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   422
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   423
    function reset () {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   424
        //  Resets the status of the remote server. This includes
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   425
        //  resetting the status of ALL msgs to not be deleted.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   426
        //  This method automatically closes the connection to the server.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   427
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   428
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   429
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   430
            $this->ERROR = "POP3 reset: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   431
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   432
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   433
        $reply = $this->send_cmd("RSET");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   434
        if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   435
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   436
            //  The POP3 RSET command -never- gives a -ERR
7
cf61fcea0001 resynchronize code repo with production
ymh <ymh.work@gmail.com>
parents: 0
diff changeset
   437
            //  response - if it ever does, something truly
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   438
            //  wild is going on.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   439
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   440
            $this->ERROR = "POP3 reset: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   441
            @error_log("POP3 reset: ERROR [$reply]",0);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   442
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   443
        $this->quit();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   444
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   445
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   446
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   447
    function send_cmd ( $cmd = "" )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   448
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   449
        //  Sends a user defined command string to the
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   450
        //  POP server and returns the results. Useful for
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   451
        //  non-compliant or custom POP servers.
21
48c4eec2b7e6 Add CLAUDE.md documentation and sync WordPress core files
ymh <ymh.work@gmail.com>
parents: 16
diff changeset
   452
        //  Do NOT include the \r\n as part of your command
0
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   453
        //  string - it will be appended automatically.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   454
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   455
        //  The return value is a standard fgets() call, which
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   456
        //  will read up to $this->BUFFER bytes of data, until it
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   457
        //  encounters a new line, or EOF, whichever happens first.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   458
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   459
        //  This method works best if $cmd responds with only
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   460
        //  one line of data.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   461
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   462
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   463
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   464
            $this->ERROR = "POP3 send_cmd: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   465
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   466
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   467
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   468
        if(empty($cmd))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   469
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   470
            $this->ERROR = "POP3 send_cmd: " . _("Empty command string");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   471
            return "";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   472
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   473
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   474
        $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   475
        $buffer = $this->BUFFER;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   476
        $this->update_timer();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   477
        fwrite($fp,"$cmd\r\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   478
        $reply = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   479
        $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   480
        if($this->DEBUG) { @error_log("POP3 SEND [$cmd] GOT [$reply]",0); }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   481
        return $reply;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   482
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   483
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   484
    function quit() {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   485
        //  Closes the connection to the POP3 server, deleting
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   486
        //  any msgs marked as deleted.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   487
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   488
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   489
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   490
            $this->ERROR = "POP3 quit: " . _("connection does not exist");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   491
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   492
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   493
        $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   494
        $cmd = "QUIT";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   495
        fwrite($fp,"$cmd\r\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   496
        $reply = fgets($fp,$this->BUFFER);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   497
        $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   498
        if($this->DEBUG) { @error_log("POP3 SEND [$cmd] GOT [$reply]",0); }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   499
        fclose($fp);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   500
        unset($this->FP);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   501
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   502
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   503
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   504
    function popstat () {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   505
        //  Returns an array of 2 elements. The number of undeleted
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   506
        //  msgs in the mailbox, and the size of the mbox in octets.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   507
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   508
        $PopArray = $this->last("array");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   509
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   510
        if($PopArray == -1) { return false; }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   511
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   512
        if( (!$PopArray) or (empty($PopArray)) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   513
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   514
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   515
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   516
        return $PopArray;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   517
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   518
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   519
    function uidl ($msgNum = "")
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   520
    {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   521
        //  Returns the UIDL of the msg specified. If called with
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   522
        //  no arguments, returns an associative array where each
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   523
        //  undeleted msg num is a key, and the msg's uidl is the element
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   524
        //  Array element 0 will contain the total number of msgs
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   525
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   526
        if(!isset($this->FP)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   527
            $this->ERROR = "POP3 uidl: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   528
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   529
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   530
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   531
        $fp = $this->FP;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   532
        $buffer = $this->BUFFER;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   533
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   534
        if(!empty($msgNum)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   535
            $cmd = "UIDL $msgNum";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   536
            $reply = $this->send_cmd($cmd);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   537
            if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   538
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   539
                $this->ERROR = "POP3 uidl: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   540
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   541
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   542
            list ($ok,$num,$myUidl) = preg_split('/\s+/',$reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   543
            return $myUidl;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   544
        } else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   545
            $this->update_timer();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   546
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   547
            $UIDLArray = array();
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   548
            $Total = $this->COUNT;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   549
            $UIDLArray[0] = $Total;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   550
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   551
            if ($Total < 1)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   552
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   553
                return $UIDLArray;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   554
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   555
            $cmd = "UIDL";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   556
            fwrite($fp, "UIDL\r\n");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   557
            $reply = fgets($fp, $buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   558
            $reply = $this->strip_clf($reply);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   559
            if($this->DEBUG) { @error_log("POP3 SEND [$cmd] GOT [$reply]",0); }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   560
            if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   561
            {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   562
                $this->ERROR = "POP3 uidl: " . _("Error ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   563
                return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   564
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   565
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   566
            $line = "";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   567
            $count = 1;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   568
            $line = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   569
            while ( !preg_match('/^\.\r\n/',$line)) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   570
                list ($msg,$msgUidl) = preg_split('/\s+/',$line);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   571
                $msgUidl = $this->strip_clf($msgUidl);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   572
                if($count == $msg) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   573
                    $UIDLArray[$msg] = $msgUidl;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   574
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   575
                else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   576
                {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   577
                    $UIDLArray[$count] = 'deleted';
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   578
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   579
                $count++;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   580
                $line = fgets($fp,$buffer);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   581
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   582
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   583
        return $UIDLArray;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   584
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   585
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   586
    function delete ($msgNum = "") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   587
        //  Flags a specified msg as deleted. The msg will not
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   588
        //  be deleted until a quit() method is called.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   589
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   590
        if(!isset($this->FP))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   591
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   592
            $this->ERROR = "POP3 delete: " . _("No connection to server");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   593
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   594
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   595
        if(empty($msgNum))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   596
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   597
            $this->ERROR = "POP3 delete: " . _("No msg number submitted");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   598
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   599
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   600
        $reply = $this->send_cmd("DELE $msgNum");
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   601
        if(!$this->is_ok($reply))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   602
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   603
            $this->ERROR = "POP3 delete: " . _("Command failed ") . "[$reply]";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   604
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   605
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   606
        return true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   607
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   608
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   609
    //  *********************************************************
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   610
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   611
    //  The following methods are internal to the class.
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   612
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   613
    function is_ok ($cmd = "") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   614
        //  Return true or false on +OK or -ERR
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   615
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   616
        if( empty($cmd) )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   617
            return false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   618
        else
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   619
            return( stripos($cmd, '+OK') !== false );
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   620
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   621
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   622
    function strip_clf ($text = "") {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   623
        // Strips \r\n from server responses
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   624
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   625
        if(empty($text))
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   626
            return $text;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   627
        else {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   628
            $stripped = str_replace(array("\r","\n"),'',$text);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   629
            return $stripped;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   630
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   631
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   632
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   633
    function parse_banner ( $server_text ) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   634
        $outside = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   635
        $banner = "";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   636
        $length = strlen($server_text);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   637
        for($count =0; $count < $length; $count++)
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   638
        {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   639
            $digit = substr($server_text,$count,1);
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   640
            if(!empty($digit))             {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   641
                if( (!$outside) && ($digit != '<') && ($digit != '>') )
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   642
                {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   643
                    $banner .= $digit;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   644
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   645
                if ($digit == '<')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   646
                {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   647
                    $outside = false;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   648
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   649
                if($digit == '>')
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   650
                {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   651
                    $outside = true;
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   652
                }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   653
            }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   654
        }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   655
        $banner = $this->strip_clf($banner);    // Just in case
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   656
        return "<$banner>";
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   657
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   658
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   659
}   // End class
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   660
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   661
// For php4 compatibility
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   662
if (!function_exists("stripos")) {
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   663
    function stripos($haystack, $needle){
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   664
        return strpos($haystack, stristr( $haystack, $needle ));
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   665
    }
d970ebf37754 first import
ymh <ymh.work@gmail.com>
parents:
diff changeset
   666
}