PhpImap\Mailbox

未匹配的标注

PhpImap\Mailbox

介绍

这篇文章介绍 PhpImap\Mailbox 中成员

方法

名称 说明
PhpImap\Mailbox::__construct() -
PhpImap\Mailbox::setPathDelimiter() -
PhpImap\Mailbox::getPathDelimiter() -
PhpImap\Mailbox::validatePathDelimiter() -
PhpImap\Mailbox::getServerEncoding() -
PhpImap\Mailbox::setServerEncoding() -
PhpImap\Mailbox::getImapSearchOption() -
PhpImap\Mailbox::setImapSearchOption() -
PhpImap\Mailbox::setAttachmentsIgnore() -
PhpImap\Mailbox::getAttachmentsIgnore() -
PhpImap\Mailbox::setTimeouts() -
PhpImap\Mailbox::getLogin() -
PhpImap\Mailbox::setConnectionArgs() -
PhpImap\Mailbox::setAttachmentsDir() -
PhpImap\Mailbox::getAttachmentsDir() -
PhpImap\Mailbox::setConnectionRetry() -
PhpImap\Mailbox::setConnectionRetryDelay() -
PhpImap\Mailbox::getImapStream() -
PhpImap\Mailbox::encodeStringToUtf7Imap() -
PhpImap\Mailbox::decodeStringFromUtf7ImapToUtf8() -
PhpImap\Mailbox::switchMailbox() -
PhpImap\Mailbox::disconnect() -
PhpImap\Mailbox::setExpungeOnDisconnect() -
PhpImap\Mailbox::checkMailbox() -
PhpImap\Mailbox::createMailbox() -
PhpImap\Mailbox::deleteMailbox() -
PhpImap\Mailbox::renameMailbox() -
PhpImap\Mailbox::statusMailbox() -
PhpImap\Mailbox::getListingFolders() -
PhpImap\Mailbox::searchMailbox() -
PhpImap\Mailbox::saveMail() -
PhpImap\Mailbox::deleteMail() -
PhpImap\Mailbox::moveMail() -
PhpImap\Mailbox::copyMail() -
PhpImap\Mailbox::expungeDeletedMails() -
PhpImap\Mailbox::markMailAsRead() -
PhpImap\Mailbox::markMailAsUnread() -
PhpImap\Mailbox::markMailAsImportant() -
PhpImap\Mailbox::markMailsAsRead() -
PhpImap\Mailbox::markMailsAsUnread() -
PhpImap\Mailbox::markMailsAsImportant() -
PhpImap\Mailbox::setFlag() -
PhpImap\Mailbox::clearFlag() -
PhpImap\Mailbox::getMailsInfo() -
PhpImap\Mailbox::getMailboxHeaders() -
PhpImap\Mailbox::getMailboxInfo() -
PhpImap\Mailbox::sortMails() -
PhpImap\Mailbox::countMails() -
PhpImap\Mailbox::getQuotaLimit() -
PhpImap\Mailbox::getQuotaUsage() -
PhpImap\Mailbox::getRawMail() -
PhpImap\Mailbox::getMailHeader() -
PhpImap\Mailbox::flattenParts() -
PhpImap\Mailbox::getMail() -
PhpImap\Mailbox::downloadAttachment() -
PhpImap\Mailbox::decodeMimeStr() -
PhpImap\Mailbox::isUrlEncoded() -
PhpImap\Mailbox::parseDateTime() -
PhpImap\Mailbox::convertStringEncoding() -
PhpImap\Mailbox::__destruct() -
PhpImap\Mailbox::getImapPath() -
PhpImap\Mailbox::getMailMboxFormat() -
PhpImap\Mailbox::getMailboxes() -
PhpImap\Mailbox::getSubscribedMailboxes() -
PhpImap\Mailbox::subscribeMailbox() -
PhpImap\Mailbox::unsubscribeMailbox() -
PhpImap\Mailbox::imap() -

PhpImap\Mailbox::__construct()

/**
 * @param string $imapPath
 * @param string $login
 * @param string $password
 * @param string $attachmentsDir
 * @param string $serverEncoding
 *
 * @throws InvalidParameterException
 */
public function __construct($imapPath, $login, $password, $attachmentsDir = null, $serverEncoding = 'UTF-8')
{
    $this->imapPath = trim($imapPath);
    $this->imapLogin = trim($login);
    $this->imapPassword = $password;
    $this->setServerEncoding($serverEncoding);
    if (null != $attachmentsDir) {
        $this->setAttachmentsDir($attachmentsDir);
    }
}

PhpImap\Mailbox::setPathDelimiter()

/**
 * Sets / Changes the path delimiter character (Supported values: '.', '/').
 *
 * @param string $delimiter Path delimiter
 *
 * @throws InvalidParameterException
 */
public function setPathDelimiter($delimiter)
{
    if (!$this->validatePathDelimiter($delimiter)) {
        throw new InvalidParameterException('setPathDelimiter() can only set the delimiter to these characters: ".", "/"');
    }
    $this->pathDelimiter = $delimiter;
}

PhpImap\Mailbox::getPathDelimiter()

/**
 * Returns the current set path delimiter character.
 *
 * @return string Path delimiter
 */
public function getPathDelimiter()
{
    return $this->pathDelimiter;
}

PhpImap\Mailbox::validatePathDelimiter()

/**
 * Validates the given path delimiter character.
 *
 * @param string Path delimiter
 *
 * @return bool true (supported) or false (unsupported)
 */
public function validatePathDelimiter($delimiter)
{
    $supported_delimiters = ['.', '/'];
    if (!\in_array($delimiter, $supported_delimiters)) {
        return false;
    }
    return true;
}

PhpImap\Mailbox::getServerEncoding()

/**
 * Returns the current set server encoding.
 *
 * @return string Server encoding (eg. 'UTF-8')
 */
public function getServerEncoding()
{
    return $this->serverEncoding;
}

PhpImap\Mailbox::setServerEncoding()

/**
 * Sets / Changes the server encoding.
 *
 * @param string Server encoding (eg. 'UTF-8')
 *
 * @throws InvalidParameterException
 */
public function setServerEncoding($serverEncoding)
{
    $serverEncoding = strtoupper(trim($serverEncoding));
    // https://github.com/barbushin/php-imap/issues/336
    $supported_encodings = [];
    if (\extension_loaded('mbstring')) {
        $supported_encodings = mb_list_encodings();
    }
    if (!\in_array($serverEncoding, $supported_encodings) && 'US-ASCII' != $serverEncoding) {
        throw new InvalidParameterException('"'.$serverEncoding.'" is not supported by setServerEncoding(). Your system only supports these encodings: US-ASCII, '.implode(', ', $supported_encodings));
    }
    $this->serverEncoding = $serverEncoding;
}

PhpImap\Mailbox::getImapSearchOption()

/**
 * Returns the current set IMAP search option.
 *
 * @return string IMAP search option (eg. 'SE_UID')
 */
public function getImapSearchOption()
{
    return $this->imapSearchOption;
}

PhpImap\Mailbox::setImapSearchOption()

/**
 * Sets / Changes the IMAP search option.
 *
 * @param string IMAP search option (eg. 'SE_UID')
 *
 * @throws InvalidParameterException
 */
public function setImapSearchOption($imapSearchOption)
{
    $imapSearchOption = strtoupper(trim($imapSearchOption));
    $supported_options = [SE_FREE, SE_UID];
    if (!\in_array($imapSearchOption, $supported_options)) {
        throw new InvalidParameterException('"'.$imapSearchOption.'" is not supported by setImapSearchOption(). Supported options are SE_FREE and SE_UID.');
    }
    $this->imapSearchOption = $imapSearchOption;
}

PhpImap\Mailbox::setAttachmentsIgnore()

/**
 * Set $this->attachmentsIgnore param. Allow to ignore attachments when they are not required and boost performance.
 *
 * @param bool $attachmentsIgnore
 *
 * @throws InvalidParameterException
 */
public function setAttachmentsIgnore($attachmentsIgnore)
{
    if (!\is_bool($attachmentsIgnore)) {
        throw new InvalidParameterException('setAttachmentsIgnore() expects a boolean: true or false');
    }
    $this->attachmentsIgnore = $attachmentsIgnore;
}

PhpImap\Mailbox::getAttachmentsIgnore()

/**
 * Get $this->attachmentsIgnore param.
 *
 * @return bool $attachmentsIgnore
 */
public function getAttachmentsIgnore()
{
    return $this->attachmentsIgnore;
}

PhpImap\Mailbox::setTimeouts()

/**
 * Sets the timeout of all or one specific type.
 *
 * @param int   $timeout Timeout in seconds
 * @param array $types   One of the following: IMAP_OPENTIMEOUT, IMAP_READTIMEOUT, IMAP_WRITETIMEOUT, IMAP_CLOSETIMEOUT
 *
 * @throws InvalidParameterException
 */
public function setTimeouts($timeout, $types = [IMAP_OPENTIMEOUT, IMAP_READTIMEOUT, IMAP_WRITETIMEOUT, IMAP_CLOSETIMEOUT])
{
    $supported_types = [IMAP_OPENTIMEOUT, IMAP_READTIMEOUT, IMAP_WRITETIMEOUT, IMAP_CLOSETIMEOUT];
    $found_types = array_intersect($types, $supported_types);
    if (\count($types) != \count($found_types)) {
        throw new InvalidParameterException('You have provided at least one unsupported timeout type. Supported types are: IMAP_OPENTIMEOUT, IMAP_READTIMEOUT, IMAP_WRITETIMEOUT, IMAP_CLOSETIMEOUT');
    }
    $this->timeouts = array_fill_keys($types, $timeout);
}

PhpImap\Mailbox::getLogin()

/**
 * Returns the IMAP login (usually an email address).
 *
 * @return string IMAP login
 */
public function getLogin()
{
    return $this->imapLogin;
}

PhpImap\Mailbox::setConnectionArgs()

/**
 * Set custom connection arguments of imap_open method. See http://php.net/imap_open.
 *
 * @param int   $options
 * @param int   $retriesNum
 * @param array $params
 *
 * @throws InvalidParameterException
 */
public function setConnectionArgs($options = 0, $retriesNum = 0, $params = null)
{
    if (0 != $options) {
        $supported_options = [OP_READONLY, OP_ANONYMOUS, OP_HALFOPEN, CL_EXPUNGE, OP_DEBUG, OP_SHORTCACHE, OP_SILENT, OP_PROTOTYPE, OP_SECURE];
        if (!\in_array($options, $supported_options)) {
            throw new InvalidParameterException('Please check your option for setConnectionArgs()! Unsupported option "'.$options.'". Available options: https://www.php.net/manual/de/function.imap-open.php');
        }
        $this->imapOptions = $options;
    }
    if (0 != $retriesNum) {
        if (!\is_int($retriesNum) or $retriesNum < 0) {
            throw new InvalidParameterException('Invalid number of retries provided for setConnectionArgs()! It must be a positive integer. (eg. 1 or 3)');
        }
        $this->imapRetriesNum = $retriesNum;
    }
    if (null != $params and !empty($params)) {
        $supported_params = ['DISABLE_AUTHENTICATOR'];
        if (!\is_array($params)) {
            throw new InvalidParameterException('setConnectionArgs() requires $params to be an array!');
        }
        foreach ($params as $key => $value) {
            if (!\in_array($key, $supported_params)) {
                throw new InvalidParameterException('Invalid array key of params provided for setConnectionArgs()! Only DISABLE_AUTHENTICATOR is currently valid.');
            }
        }
        $this->imapParams = $params;
    }
}

PhpImap\Mailbox::setAttachmentsDir()

/**
 * Set custom folder for attachments in case you want to have tree of folders for each email
 * i.e. a/1 b/1 c/1 where a,b,c - senders, i.e. john@smith.com.
 *
 * @param string $attachmentsDir Folder where to save attachments
 *
 * @throws InvalidParameterException
 */
public function setAttachmentsDir($attachmentsDir)
{
    if (empty(trim($attachmentsDir))) {
        throw new InvalidParameterException('setAttachmentsDir() expects a string as first parameter!');
    }
    if (!is_dir($attachmentsDir)) {
        throw new InvalidParameterException('Directory "'.$attachmentsDir.'" not found');
    }
    $this->attachmentsDir = rtrim(realpath($attachmentsDir), '\\/');
}

PhpImap\Mailbox::getAttachmentsDir()

/**
 * Get current saving folder for attachments.
 *
 * @return string Attachments dir
 */
public function getAttachmentsDir()
{
    return $this->attachmentsDir;
}

PhpImap\Mailbox::setConnectionRetry()

/*
    * Sets / Changes the attempts / retries to connect
    * @param int $maxAttempts
    * @return void
*/
public function setConnectionRetry($maxAttempts)
{
    $this->connectionRetry = $maxAttempts;
}

PhpImap\Mailbox::setConnectionRetryDelay()

/*
    * Sets / Changes the delay between each attempt / retry to connect
    * @param int $milliseconds
    * @return void
*/
public function setConnectionRetryDelay($milliseconds)
{
    $this->connectionRetryDelay = $milliseconds;
}

PhpImap\Mailbox::getImapStream()

/**
 * Get IMAP mailbox connection stream.
 *
 * @param bool $forceConnection Initialize connection if it's not initialized
 *
 * @return resource|null
 */
public function getImapStream($forceConnection = true)
{
    if ($forceConnection) {
        if ($this->imapStream && (!\is_resource($this->imapStream) || !imap_ping($this->imapStream))) {
            $this->disconnect();
            $this->imapStream = null;
        }
        if (!$this->imapStream) {
            $this->imapStream = $this->initImapStreamWithRetry();
        }
    }
    return $this->imapStream;
}

PhpImap\Mailbox::encodeStringToUtf7Imap()

/**
 * Returns the provided string in UTF7-IMAP encoded format.
 *
 * @return string $str UTF-7 encoded string or same as before, when it's no string
 */
public function encodeStringToUtf7Imap($str)
{
    if (\is_string($str)) {
        return mb_convert_encoding($str, 'UTF7-IMAP', mb_detect_encoding($str, 'UTF-8, ISO-8859-1, ISO-8859-15', true));
    }
    // Return $str as it is, when it is no string
    return $str;
}

PhpImap\Mailbox::decodeStringFromUtf7ImapToUtf8()

/**
 * Returns the provided string in UTF-8 encoded format.
 *
 * @return string $str UTF-7 encoded string or same as before, when it's no string
 */
public function decodeStringFromUtf7ImapToUtf8($str)
{
    if (\is_string($str)) {
        return mb_convert_encoding($str, 'UTF-8', 'UTF7-IMAP');
    }
    // Return $str as it is, when it is no string
    return $str;
}

PhpImap\Mailbox::switchMailbox()

/**
 * Switch mailbox without opening a new connection.
 *
 * @param string $imapPath
 *
 * @throws Exception
 */
public function switchMailbox($imapPath)
{
    if (strpos($imapPath, '}') > 0) {
        $this->imapPath = $imapPath;
    } else {
        $this->imapPath = $this->getCombinedPath($imapPath, true);
    }
    $this->imap('reopen', $this->imapPath);
}
protected function initImapStreamWithRetry()
{
    $retry = $this->connectionRetry;
    do {
        try {
            return $this->initImapStream();
        } catch (ConnectionException $exception) {
        }
    } while (--$retry > 0 && (!$this->connectionRetryDelay || !usleep($this->connectionRetryDelay * 1000)));
    throw $exception;
}

PhpImap\Mailbox::disconnect()

/**
 * Disconnects from IMAP server / mailbox.
 */
public function disconnect()
{
    $imapStream = $this->getImapStream(false);
    if ($imapStream && \is_resource($imapStream)) {
        $this->imap('close', [$imapStream, $this->expungeOnDisconnect ? CL_EXPUNGE : 0], false, null);
    }
}

PhpImap\Mailbox::setExpungeOnDisconnect()

/**
 * Sets 'expunge on disconnect' parameter.
 *
 * @param bool $isEnabled
 */
public function setExpungeOnDisconnect($isEnabled)
{
    $this->expungeOnDisconnect = $isEnabled;
}

PhpImap\Mailbox::checkMailbox()

/**
 * Get information about the current mailbox.
 *
 * Returns the information in an object with following properties:
 *  Date - current system time formatted according to RFC2822
 *  Driver - protocol used to access this mailbox: POP3, IMAP, NNTP
 *  Mailbox - the mailbox name
 *  Nmsgs - number of mails in the mailbox
 *  Recent - number of recent mails in the mailbox
 *
 * @return stdClass
 *
 * @see    imap_check
 */
public function checkMailbox()
{
    return $this->imap('check');
}

PhpImap\Mailbox::createMailbox()

/**
 * Creates a new mailbox.
 *
 * @param string $name Name of new mailbox (eg. 'PhpImap')
 *
 * @see   imap_createmailbox()
 */
public function createMailbox($name)
{
    $this->imap('createmailbox', $this->getCombinedPath($name));
}

PhpImap\Mailbox::deleteMailbox()

/**
 * Deletes a specific mailbox.
 *
 * @param string $name Name of mailbox, which you want to delete (eg. 'PhpImap')
 *
 * @see   imap_deletemailbox()
 */
public function deleteMailbox($name)
{
    $this->imap('deletemailbox', $this->getCombinedPath($name));
}

PhpImap\Mailbox::renameMailbox()

/**
 * Rename an existing mailbox from $oldName to $newName.
 *
 * @param string $oldName Current name of mailbox, which you want to rename (eg. 'PhpImap')
 * @param string $newName New name of mailbox, to which you want to rename it (eg. 'PhpImapTests')
 */
public function renameMailbox($oldName, $newName)
{
    $this->imap('renamemailbox', [$this->getCombinedPath($oldName), $this->getCombinedPath($newName)]);
}

PhpImap\Mailbox::statusMailbox()

/**
 * Gets status information about the given mailbox.
 *
 * This function returns an object containing status information.
 * The object has the following properties: messages, recent, unseen, uidnext, and uidvalidity.
 *
 * @return stdClass
 */
public function statusMailbox()
{
    return $this->imap('status', [$this->imapPath, SA_ALL]);
}

PhpImap\Mailbox::getListingFolders()

/**
 * Gets listing the folders.
 *
 * This function returns an object containing listing the folders.
 * The object has the following properties: messages, recent, unseen, uidnext, and uidvalidity.
 *
 * @param string $pattern
 *
 * @return array listing the folders
 */
public function getListingFolders($pattern = '*')
{
    $folders = $this->imap('list', [$this->imapPath, $pattern]) ?: [];
    foreach ($folders as &$folder) {
        $folder = $this->decodeStringFromUtf7ImapToUtf8($folder);
    }
    return $folders;
}

PhpImap\Mailbox::searchMailbox()

/**
 * This function uses imap_search() to perform a search on the mailbox currently opened in the given IMAP stream.
 * For example, to match all unanswered mails sent by Mom, you'd use: "UNANSWERED FROM mom".
 *
 * @param string $criteria              See http://php.net/imap_search for a complete list of available criteria
 * @param bool   $disableServerEncoding Disables server encoding while searching for mails (can be useful on Exchange servers)
 *
 * @return array mailsIds (or empty array)
 */
public function searchMailbox($criteria = 'ALL', $disableServerEncoding = false)
{
    if ($disableServerEncoding) {
        return $this->imap('search', [$criteria, $this->imapSearchOption]) ?: [];
    }
    return $this->imap('search', [$criteria, $this->imapSearchOption, $this->getServerEncoding()]) ?: [];
}

PhpImap\Mailbox::saveMail()

/**
 * Save a specific body section to a file.
 *
 * @param int    $mailId   message number
 * @param string $filename
 *
 * @see   imap_savebody()
 */
public function saveMail($mailId, $filename = 'email.eml')
{
    $this->imap('savebody', [$filename, $mailId, '', (SE_UID == $this->imapSearchOption) ? FT_UID : 0]);
}

PhpImap\Mailbox::deleteMail()

/**
 * Marks mails listed in mailId for deletion.
 *
 * @param int $mailId message number
 *
 * @see   imap_delete()
 */
public function deleteMail($mailId)
{
    $this->imap('delete', [$mailId.':'.$mailId, (SE_UID == $this->imapSearchOption) ? FT_UID : 0]);
}

PhpImap\Mailbox::moveMail()

/**
 * Moves mails listed in mailId into new mailbox.
 *
 * @param string $mailId  a range or message number
 * @param string $mailBox Mailbox name
 *
 * @see imap_mail_move()
 *
 * @return void
 */
public function moveMail($mailId, $mailBox)
{
    $this->imap('mail_move', [$mailId, $mailBox, CP_UID]) && $this->expungeDeletedMails();
}

PhpImap\Mailbox::copyMail()

/**
 * Copies mails listed in mailId into new mailbox.
 *
 * @param string $mailId  a range or message number
 * @param string $mailBox Mailbox name
 *
 * @see   imap_mail_copy()
 */
public function copyMail($mailId, $mailBox)
{
    $this->imap('mail_copy', [$mailId, $mailBox, CP_UID]) && $this->expungeDeletedMails();
}

PhpImap\Mailbox::expungeDeletedMails()

/**
 * Deletes all the mails marked for deletion by imap_delete(), imap_mail_move(), or imap_setflag_full().
 *
 * @see imap_expunge()
 */
public function expungeDeletedMails()
{
    $this->imap('expunge');
}

PhpImap\Mailbox::markMailAsRead()

/**
 * Add the flag \Seen to a mail.
 *
 * @param $mailId
 */
public function markMailAsRead($mailId)
{
    $this->setFlag([$mailId], '\\Seen');
}

PhpImap\Mailbox::markMailAsUnread()

/**
 * Remove the flag \Seen from a mail.
 *
 * @param $mailId
 */
public function markMailAsUnread($mailId)
{
    $this->clearFlag([$mailId], '\\Seen');
}

PhpImap\Mailbox::markMailAsImportant()

/**
 * Add the flag \Flagged to a mail.
 *
 * @param $mailId
 */
public function markMailAsImportant($mailId)
{
    $this->setFlag([$mailId], '\\Flagged');
}

PhpImap\Mailbox::markMailsAsRead()

/**
 * Add the flag \Seen to a mails.
 */
public function markMailsAsRead(array $mailId)
{
    $this->setFlag($mailId, '\\Seen');
}

PhpImap\Mailbox::markMailsAsUnread()

/**
 * Remove the flag \Seen from some mails.
 */
public function markMailsAsUnread(array $mailId)
{
    $this->clearFlag($mailId, '\\Seen');
}

PhpImap\Mailbox::markMailsAsImportant()

/**
 * Add the flag \Flagged to some mails.
 */
public function markMailsAsImportant(array $mailId)
{
    $this->setFlag($mailId, '\\Flagged');
}

PhpImap\Mailbox::setFlag()

/**
 * Causes a store to add the specified flag to the flags set for the mails in the specified sequence.
 *
 * @param array  $mailsIds Array of mail IDs
 * @param string $flag     Which you can set are \Seen, \Answered, \Flagged, \Deleted, and \Draft as defined by RFC2060
 */
public function setFlag(array $mailsIds, $flag)
{
    $this->imap('setflag_full', [implode(',', $mailsIds), $flag, ST_UID]);
}

PhpImap\Mailbox::clearFlag()

/**
 * Causes a store to delete the specified flag to the flags set for the mails in the specified sequence.
 *
 * @param array  $mailsIds Array of mail IDs
 * @param string $flag     Which you can delete are \Seen, \Answered, \Flagged, \Deleted, and \Draft as defined by RFC2060
 */
public function clearFlag(array $mailsIds, $flag)
{
    $this->imap('clearflag_full', [implode(',', $mailsIds), $flag, ST_UID]);
}

PhpImap\Mailbox::getMailsInfo()

/**
 * Fetch mail headers for listed mails ids.
 *
 * Returns an array of objects describing one mail header each. The object will only define a property if it exists. The possible properties are:
 *  subject - the mails subject
 *  from - who sent it
 *  sender - who sent it
 *  to - recipient
 *  date - when was it sent
 *  message_id - Mail-ID
 *  references - is a reference to this mail id
 *  in_reply_to - is a reply to this mail id
 *  size - size in bytes
 *  uid - UID the mail has in the mailbox
 *  msgno - mail sequence number in the mailbox
 *  recent - this mail is flagged as recent
 *  flagged - this mail is flagged
 *  answered - this mail is flagged as answered
 *  deleted - this mail is flagged for deletion
 *  seen - this mail is flagged as already read
 *  draft - this mail is flagged as being a draft
 *
 * @return array $mailsIds Array of mail IDs
 */
public function getMailsInfo(array $mailsIds)
{
    $mails = $this->imap('fetch_overview', [implode(',', $mailsIds), (SE_UID == $this->imapSearchOption) ? FT_UID : 0]);
    if (\is_array($mails) && \count($mails)) {
        foreach ($mails as &$mail) {
            if (isset($mail->subject) and !empty(trim($mail->subject))) {
                $mail->subject = $this->decodeMimeStr($mail->subject, $this->getServerEncoding());
            }
            if (isset($mail->from) and !empty(trim($mail->from))) {
                $mail->from = $this->decodeMimeStr($mail->from, $this->getServerEncoding());
            }
            if (isset($mail->sender) and !empty(trim($mail->sender))) {
                $mail->sender = $this->decodeMimeStr($mail->sender, $this->getServerEncoding());
            }
            if (isset($mail->to) and !empty(trim($mail->to))) {
                $mail->to = $this->decodeMimeStr($mail->to, $this->getServerEncoding());
            }
        }
    }
    return $mails;
}

PhpImap\Mailbox::getMailboxHeaders()

/**
 * Get headers for all messages in the defined mailbox,
 * returns an array of string formatted with header info,
 * one element per mail message.
 *
 * @return array
 *
 * @see    imap_headers()
 */
public function getMailboxHeaders()
{
    return $this->imap('headers');
}

PhpImap\Mailbox::getMailboxInfo()

/**
 * Get information about the current mailbox.
 *
 * Returns an object with following properties:
 *  Date - last change (current datetime)
 *  Driver - driver
 *  Mailbox - name of the mailbox
 *  Nmsgs - number of messages
 *  Recent - number of recent messages
 *  Unread - number of unread messages
 *  Deleted - number of deleted messages
 *  Size - mailbox size
 *
 * @return object Object with info
 *
 * @see    mailboxmsginfo
 */
public function getMailboxInfo()
{
    return $this->imap('mailboxmsginfo');
}

PhpImap\Mailbox::sortMails()

/**
 * Gets mails ids sorted by some criteria.
 *
 * Criteria can be one (and only one) of the following constants:
 *  SORTDATE - mail Date
 *  SORTARRIVAL - arrival date (default)
 *  SORTFROM - mailbox in first From address
 *  SORTSUBJECT - mail subject
 *  SORTTO - mailbox in first To address
 *  SORTCC - mailbox in first cc address
 *  SORTSIZE - size of mail in octets
 *
 * @param int    $criteria       Sorting criteria (eg. SORTARRIVAL)
 * @param bool   $reverse        Sort reverse or not
 * @param string $searchCriteria See http://php.net/imap_search for a complete list of available criteria
 *
 * @return array Mails ids
 */
public function sortMails($criteria = SORTARRIVAL, $reverse = true, $searchCriteria = 'ALL')
{
    return $this->imap('sort', [$criteria, $reverse, $this->imapSearchOption, $searchCriteria]);
}

PhpImap\Mailbox::countMails()

/**
 * Get mails count in mail box.
 *
 * @return int
 *
 * @see    imap_num_msg()
 */
public function countMails()
{
    return $this->imap('num_msg');
}

PhpImap\Mailbox::getQuotaLimit()

/**
 * Return quota limit in KB.
 *
 * @param string $quota_root Should normally be in the form of which mailbox (i.e. INBOX)
 *
 * @return int
 */
public function getQuotaLimit($quota_root = 'INBOX')
{
    $quota = $this->getQuota($quota_root);
    return isset($quota['STORAGE']['limit']) ? $quota['STORAGE']['limit'] : 0;
}

PhpImap\Mailbox::getQuotaUsage()

/**
 * Return quota usage in KB.
 *
 * @param string $quota_root Should normally be in the form of which mailbox (i.e. INBOX)
 *
 * @return int FALSE in the case of call failure
 */
public function getQuotaUsage($quota_root = 'INBOX')
{
    $quota = $this->getQuota($quota_root);
    return isset($quota['STORAGE']['usage']) ? $quota['STORAGE']['usage'] : 0;
}

PhpImap\Mailbox::getRawMail()

/**
 * Get raw mail data.
 *
 * @param int  $msgId      ID of the message
 * @param bool $markAsSeen Mark the email as seen, when set to true
 *
 * @return string Message of the fetched body
 */
public function getRawMail($msgId, $markAsSeen = true)
{
    $options = (SE_UID == $this->imapSearchOption) ? FT_UID : 0;
    if (!$markAsSeen) {
        $options |= FT_PEEK;
    }
    return $this->imap('fetchbody', [$msgId, '', $options]);
}

PhpImap\Mailbox::getMailHeader()

/**
 * Get mail header.
 *
 * @param int $mailId ID of the message
 *
 * @return IncomingMailHeader
 *
 * @throws Exception
 */
public function getMailHeader($mailId)
{
    $headersRaw = $this->imap('fetchheader', [$mailId, (SE_UID == $this->imapSearchOption) ? FT_UID : 0]);
    if (false === $headersRaw) {
        throw new Exception('Empty mail header - fetchheader failed. Invalid mail ID?');
    }
    $head = imap_rfc822_parse_headers($headersRaw);
    $header = new IncomingMailHeader();
    $header->headersRaw = $headersRaw;
    $header->headers = $head;
    $header->id = $mailId;
    $header->isDraft = (!isset($head->date)) ? true : false;
    $header->priority = (preg_match("/Priority\:(.*)/i", $headersRaw, $matches)) ? trim($matches[1]) : '';
    $header->importance = (preg_match("/Importance\:(.*)/i", $headersRaw, $matches)) ? trim($matches[1]) : '';
    $header->sensitivity = (preg_match("/Sensitivity\:(.*)/i", $headersRaw, $matches)) ? trim($matches[1]) : '';
    $header->autoSubmitted = (preg_match("/Auto-Submitted\:(.*)/i", $headersRaw, $matches)) ? trim($matches[1]) : '';
    $header->precedence = (preg_match("/Precedence\:(.*)/i", $headersRaw, $matches)) ? trim($matches[1]) : '';
    $header->failedRecipients = (preg_match("/Failed-Recipients\:(.*)/i", $headersRaw, $matches)) ? trim($matches[1]) : '';
    if (isset($head->date) and !empty(trim($head->date))) {
        $header->date = self::parseDateTime($head->date);
    } elseif (isset($head->Date) and !empty(trim($head->Date))) {
        $header->date = self::parseDateTime($head->Date);
    } else {
        $now = new DateTime();
        $header->date = self::parseDateTime($now->format('Y-m-d H:i:s'));
    }
    $header->subject = (isset($head->subject) and !empty(trim($head->subject))) ? $this->decodeMimeStr($head->subject, $this->getServerEncoding()) : null;
    if (isset($head->from) and !empty($head->from)) {
        $header->fromHost = isset($head->from[0]->host) ? $head->from[0]->host : (isset($head->from[1]->host) ? $head->from[1]->host : null);
        $header->fromName = (isset($head->from[0]->personal) and !empty(trim($head->from[0]->personal))) ? $this->decodeMimeStr($head->from[0]->personal, $this->getServerEncoding()) : ((isset($head->from[1]->personal) and (!empty(trim($head->from[1]->personal)))) ? $this->decodeMimeStr($head->from[1]->personal, $this->getServerEncoding()) : null);
        $header->fromAddress = strtolower($head->from[0]->mailbox.'@'.$header->fromHost);
    } elseif (preg_match('/smtp.mailfrom=[-0-9a-zA-Z.+_]+@[-0-9a-zA-Z.+_]+.[a-zA-Z]{2,4}/', $headersRaw, $matches)) {
        $header->fromAddress = substr($matches[0], 14);
    }
    if (isset($head->sender) and !empty($head->sender)) {
        $header->senderHost = isset($head->sender[0]->host) ? $head->sender[0]->host : (isset($head->sender[1]->host) ? $head->sender[1]->host : null);
        $header->senderName = (isset($head->sender[0]->personal) and !empty(trim($head->sender[0]->personal))) ? $this->decodeMimeStr($head->sender[0]->personal, $this->getServerEncoding()) : ((isset($head->sender[1]->personal) and (!empty(trim($head->sender[1]->personal)))) ? $this->decodeMimeStr($head->sender[1]->personal, $this->getServerEncoding()) : null);
        $header->senderAddress = strtolower($head->sender[0]->mailbox.'@'.$header->senderHost);
    }
    if (isset($head->to)) {
        $toStrings = [];
        foreach ($head->to as $to) {
            if (isset($to->mailbox) && !empty(trim($to->mailbox)) && isset($to->host) && !empty(trim($to->host))) {
                $toEmail = strtolower($to->mailbox.'@'.$to->host);
                $toName = (isset($to->personal) and !empty(trim($to->personal))) ? $this->decodeMimeStr($to->personal, $this->getServerEncoding()) : null;
                $toStrings[] = $toName ? "$toName <$toEmail>" : $toEmail;
                $header->to[$toEmail] = $toName;
            }
        }
        $header->toString = implode(', ', $toStrings);
    }
    if (isset($head->cc)) {
        foreach ($head->cc as $cc) {
            if (isset($cc->mailbox) && !empty(trim($cc->mailbox)) && isset($cc->host) && !empty(trim($cc->host))) {
                $ccEmail = strtolower($cc->mailbox.'@'.$cc->host);
                $ccName = (isset($cc->personal) and !empty(trim($cc->personal))) ? $this->decodeMimeStr($cc->personal, $this->getServerEncoding()) : null;
                $ccStrings[] = $ccName ? "$ccName <$ccEmail>" : $ccEmail;
                $header->cc[$ccEmail] = $ccName;
            }
        }
    }
    if (isset($head->bcc)) {
        foreach ($head->bcc as $bcc) {
            if (isset($bcc->mailbox) && !empty(trim($bcc->mailbox)) && isset($bcc->host) && !empty(trim($bcc->host))) {
                $bccEmail = strtolower($bcc->mailbox.'@'.$bcc->host);
                $bccName = (isset($bcc->personal) and !empty(trim($bcc->personal))) ? $this->decodeMimeStr($bcc->personal, $this->getServerEncoding()) : null;
                $bccStrings[] = $bccName ? "$bccName <$bccEmail>" : $bccEmail;
                $header->bcc[$bccEmail] = $bccName;
            }
        }
    }
    if (isset($head->reply_to)) {
        foreach ($head->reply_to as $replyTo) {
            if (isset($replyTo->mailbox) && !empty(trim($replyTo->mailbox)) && isset($replyTo->host) && !empty(trim($replyTo->host))) {
                $replyToEmail = strtolower($replyTo->mailbox.'@'.$replyTo->host);
                $replyToName = (isset($replyTo->personal) and !empty(trim($replyTo->personal))) ? $this->decodeMimeStr($replyTo->personal, $this->getServerEncoding()) : null;
                $replyToStrings[] = $replyToName ? "$replyToName <$replyToEmail>" : $replyToEmail;
                $header->replyTo[$replyToEmail] = $replyToName;
            }
        }
    }
    if (isset($head->message_id)) {
        $header->messageId = $head->message_id;
    }
    return $header;
}

PhpImap\Mailbox::flattenParts()

/**
 * taken from https://www.electrictoolbox.com/php-imap-message-parts/.
 */
public function flattenParts($messageParts, $flattenedParts = [], $prefix = '', $index = 1, $fullPrefix = true)
{
    foreach ($messageParts as $part) {
        $flattenedParts[$prefix.$index] = $part;
        if (isset($part->parts)) {
            if (2 == $part->type) {
                $flattenedParts = $this->flattenParts($part->parts, $flattenedParts, $prefix.$index.'.', 0, false);
            } elseif ($fullPrefix) {
                $flattenedParts = $this->flattenParts($part->parts, $flattenedParts, $prefix.$index.'.');
            } else {
                $flattenedParts = $this->flattenParts($part->parts, $flattenedParts, $prefix);
            }
            unset($flattenedParts[$prefix.$index]->parts);
        }
        ++$index;
    }
    return $flattenedParts;
}

PhpImap\Mailbox::getMail()

/**
 * Get mail data.
 *
 * @param int  $mailId     ID of the mail
 * @param bool $markAsSeen Mark the email as seen, when set to true
 *
 * @return IncomingMail
 */
public function getMail($mailId, $markAsSeen = true)
{
    $mail = new IncomingMail();
    $mail->setHeader($this->getMailHeader($mailId));
    $mailStructure = $this->imap('fetchstructure', [$mailId, (SE_UID == $this->imapSearchOption) ? FT_UID : 0]);
    if (empty($mailStructure->parts)) {
        $this->initMailPart($mail, $mailStructure, 0, $markAsSeen);
    } else {
        foreach ($this->flattenParts($mailStructure->parts) as $partNum => $partStructure) {
            $this->initMailPart($mail, $partStructure, $partNum, $markAsSeen);
        }
    }
    return $mail;
}
protected function initMailPart(IncomingMail $mail, $partStructure, $partNum, $markAsSeen = true, $emlParse = false)
{
    $options = (SE_UID == $this->imapSearchOption) ? FT_UID : 0;
    if (!$markAsSeen) {
        $options |= FT_PEEK;
    }
    $dataInfo = new DataPartInfo($this, $mail->id, $partNum, $partStructure->encoding, $options);
    $params = [];
    if (!empty($partStructure->parameters)) {
        foreach ($partStructure->parameters as $param) {
            $params[strtolower($param->attribute)] = (!isset($param->value) || empty(trim($param->value))) ? '' : $this->decodeMimeStr($param->value);
        }
    }
    if (!empty($partStructure->dparameters)) {
        foreach ($partStructure->dparameters as $param) {
            $paramName = strtolower(preg_match('~^(.*?)\*~', $param->attribute, $matches) ? $matches[1] : $param->attribute);
            if (isset($params[$paramName])) {
                $params[$paramName] .= $param->value;
            } else {
                $params[$paramName] = $param->value;
            }
        }
    }
    $isAttachment = isset($params['filename']) || isset($params['name']);
    // ignore contentId on body when mail isn't multipart (https://github.com/barbushin/php-imap/issues/71)
    if (!$partNum && TYPETEXT === $partStructure->type) {
        $isAttachment = false;
    }
    if ($isAttachment) {
        $mail->setHasAttachments(true);
    }
    // check if the part is a subpart of another attachment part (RFC822)
    if ('RFC822' == $partStructure->subtype && isset($partStructure->disposition) && 'attachment' == $partStructure->disposition) {
        // Although we are downloading each part separately, we are going to download the EML to a single file
        //incase someone wants to process or parse in another process
        $attachment = self::downloadAttachment($dataInfo, $params, $partStructure, $mail->id, false);
        $mail->addAttachment($attachment);
    }
    // If it comes from an EML file it is an attachment
    if ($emlParse) {
        $isAttachment = true;
    }
    // Do NOT parse attachments, when getAttachmentsIgnore() is true
    if ($this->getAttachmentsIgnore()
        && (TYPEMULTIPART !== $partStructure->type
        && (TYPETEXT !== $partStructure->type || !\in_array(strtolower($partStructure->subtype), ['plain', 'html'])))
    ) {
        return false;
    }
    if ($isAttachment) {
        $attachment = self::downloadAttachment($dataInfo, $params, $partStructure, $mail->id, $emlParse);
        $mail->addAttachment($attachment);
    } else {
        if (isset($params['charset']) and !empty(trim($params['charset']))) {
            $dataInfo->charset = $params['charset'];
        }
    }
    if (!empty($partStructure->parts)) {
        foreach ($partStructure->parts as $subPartNum => $subPartStructure) {
            if (TYPEMESSAGE === $partStructure->type && 'RFC822' == $partStructure->subtype && (!isset($partStructure->disposition) || 'attachment' !== $partStructure->disposition)) {
                $this->initMailPart($mail, $subPartStructure, $partNum, $markAsSeen);
            } elseif (TYPEMULTIPART === $partStructure->type && 'ALTERNATIVE' == $partStructure->subtype && (!isset($partStructure->disposition) || 'attachment' !== $partStructure->disposition)) {
                // https://github.com/barbushin/php-imap/issues/198
                $this->initMailPart($mail, $subPartStructure, $partNum, $markAsSeen);
            } elseif ('RFC822' == $partStructure->subtype && isset($partStructure->disposition) && 'attachment' == $partStructure->disposition) {
                //If it comes from am EML attachment, download each part separately as a file
                $this->initMailPart($mail, $subPartStructure, $partNum.'.'.($subPartNum + 1), $markAsSeen, true);
            } else {
                $this->initMailPart($mail, $subPartStructure, $partNum.'.'.($subPartNum + 1), $markAsSeen);
            }
        }
    } else {
        if (TYPETEXT === $partStructure->type) {
            if ('plain' == strtolower($partStructure->subtype)) {
                $mail->addDataPartInfo($dataInfo, DataPartInfo::TEXT_PLAIN);
            } elseif (!$partStructure->ifdisposition) {
                $mail->addDataPartInfo($dataInfo, DataPartInfo::TEXT_HTML);
            } elseif ('attachment' != strtolower($partStructure->disposition)) {
                $mail->addDataPartInfo($dataInfo, DataPartInfo::TEXT_HTML);
            }
        } elseif (TYPEMESSAGE === $partStructure->type) {
            $mail->addDataPartInfo($dataInfo, DataPartInfo::TEXT_PLAIN);
        }
    }
}

PhpImap\Mailbox::downloadAttachment()

/**
 * Download attachment.
 *
 * @param string $dataInfo
 * @param array  $params        Array of params of mail
 * @param object $partStructure Part of mail
 * @param int    $mailId        ID of mail
 * @param bool   $emlOrigin     True, if it indicates, that the attachment comes from an EML (mail) file
 *
 * @return IncomingMailAttachment[] $attachment
 */
public function downloadAttachment(DataPartInfo $dataInfo, $params, $partStructure, $mailId, $emlOrigin = false)
{
    if ('RFC822' == $partStructure->subtype && isset($partStructure->disposition) && 'attachment' == $partStructure->disposition) {
        $fileExt = strtolower($partStructure->subtype).'.eml';
    } elseif ('ALTERNATIVE' == $partStructure->subtype) {
        $fileExt = strtolower($partStructure->subtype).'.eml';
    } elseif (!isset($params['filename']) or empty(trim($params['filename'])) && (!isset($params['name']) or empty(trim($params['name'])))) {
        $fileExt = strtolower($partStructure->subtype);
    } else {
        $fileName = (isset($params['filename']) and !empty(trim($params['filename']))) ? $params['filename'] : $params['name'];
        $fileName = $this->decodeMimeStr($fileName, $this->getServerEncoding());
        $fileName = $this->decodeRFC2231($fileName, $this->getServerEncoding());
    }
    if (isset($fileExt) && isset($fileName)) {
        $fileName = $fileName.'.'.$fileExt;
    } elseif (isset($fileExt) && !isset($fileName)) {
        $fileName = $fileExt;
    } elseif (!isset($fileExt) && isset($fileName)) {
        $fileName = $fileName;
    }
    $attachmentId = sha1($fileName.($partStructure->ifid ? $partStructure->id : ''));
    $attachment = new IncomingMailAttachment();
    $attachment->id = $attachmentId;
    $attachment->contentId = $partStructure->ifid ? trim($partStructure->id, ' <>') : null;
    $attachment->name = $fileName;
    $attachment->disposition = (isset($partStructure->disposition) ? $partStructure->disposition : null);
    $attachment->charset = (isset($params['charset']) and !empty(trim($params['charset']))) ? $params['charset'] : null;
    $attachment->emlOrigin = $emlOrigin;
    $attachment->addDataPartInfo($dataInfo);
    if (null != $this->getAttachmentsDir()) {
        $replace = [
            '/\s/' => '_',
            '/[^\w\.]/iu' => '',
            '/_+/' => '_',
            '/(^_)|(_$)/' => '',
        ];
        $fileSysName = preg_replace('~[\\\\/]~', '', $mailId.'_'.$attachmentId.'_'.preg_replace(array_keys($replace), $replace, $fileName));
        $filePath = $this->getAttachmentsDir().\DIRECTORY_SEPARATOR.$fileSysName;
        if (\strlen($filePath) > 255) {
            $ext = pathinfo($filePath, PATHINFO_EXTENSION);
            $filePath = substr($filePath, 0, 255 - 1 - \strlen($ext)).'.'.$ext;
        }
        $attachment->setFilePath($filePath);
        $attachment->saveToDisk();
    }
    return $attachment;
}

PhpImap\Mailbox::decodeMimeStr()

/**
 * Decodes a mime string.
 *
 * @param string $string MIME string to decode
 *
 * @return string Converted string if conversion was successful, or the original string if not
 *
 * @throws Exception
 */
public function decodeMimeStr($string, $toCharset = 'utf-8')
{
    if (empty(trim($string))) {
        throw new Exception('decodeMimeStr() Can not decode an empty string!');
    }
    $newString = '';
    foreach (imap_mime_header_decode($string) as $element) {
        if (isset($element->text)) {
            $fromCharset = !isset($element->charset) ? 'iso-8859-1' : $element->charset;
            // Convert to UTF-8, if string has UTF-8 characters to avoid broken strings. See https://github.com/barbushin/php-imap/issues/232
            $toCharset = isset($element->charset) && preg_match('/(UTF\-8)|(default)/i', $element->charset) ? 'UTF-8' : $toCharset;
            $newString .= $this->convertStringEncoding($element->text, $fromCharset, $toCharset);
        }
    }
    return $newString;
}

PhpImap\Mailbox::isUrlEncoded()

/**
 * -
 */
public function isUrlEncoded($string)
{
    $hasInvalidChars = preg_match('#[^%a-zA-Z0-9\-_\.\+]#', $string);
    $hasEscapedChars = preg_match('#%[a-zA-Z0-9]{2}#', $string);
    return !$hasInvalidChars && $hasEscapedChars;
}

PhpImap\Mailbox::parseDateTime()

/**
 * Converts the datetime to a RFC 3339 compliant format.
 *
 * @param string $dateHeader Header datetime
 *
 * @return string RFC 3339 compliant format or original (unchanged) format,
 *                if conversation is not possible
 */
public function parseDateTime($dateHeader)
{
    if (empty(trim($dateHeader))) {
        throw new InvalidParameterException('parseDateTime() expects parameter 1 to be a parsable string datetime');
    }
    $dateHeaderUnixtimestamp = strtotime($dateHeader);
    if (!$dateHeaderUnixtimestamp) {
        return $dateHeader;
    }
    $dateHeaderRfc3339 = date(DATE_RFC3339, $dateHeaderUnixtimestamp);
    if (!$dateHeaderRfc3339) {
        return $dateHeader;
    }
    return $dateHeaderRfc3339;
}

PhpImap\Mailbox::convertStringEncoding()

/**
 * Converts a string from one encoding to another.
 *
 * @param string $string       the string, which you want to convert
 * @param string $fromEncoding the current charset (encoding)
 * @param string $toEncoding   the new charset (encoding)
 *
 * @return string Converted string if conversion was successful, or the original string if not
 */
public function convertStringEncoding($string, $fromEncoding, $toEncoding)
{
    if (preg_match('/default|ascii/i', $fromEncoding) || !$string || $fromEncoding == $toEncoding) {
        return $string;
    }
    $convertedString = '';
    $mbLoaded = \extension_loaded('mbstring');
    $supportedEncodings = [];
    if ($mbLoaded) {
        $supportedEncodings = array_map('strtolower', mb_list_encodings());
    }
    if ($mbLoaded && \in_array(strtolower($fromEncoding), $supportedEncodings) && \in_array(strtolower($toEncoding), $supportedEncodings)) {
        $convertedString = mb_convert_encoding($string, $toEncoding, $fromEncoding);
    } elseif (\function_exists('iconv')) {
        $convertedString = @iconv($fromEncoding, $toEncoding.'//TRANSLIT//IGNORE', $string);
    }
    if (('' == $convertedString) or (false === $convertedString)) {
        return $string;
    }
    return $convertedString;
}

PhpImap\Mailbox::__destruct()

/**
 * Disconnects from the IMAP server / mailbox.
 */
public function __destruct()
{
    $this->disconnect();
}

PhpImap\Mailbox::getImapPath()

/**
 * Gets IMAP path.
 *
 * @return string
 */
public function getImapPath()
{
    return $this->imapPath;
}

PhpImap\Mailbox::getMailMboxFormat()

/**
 * Get message in MBOX format.
 *
 * @param int $mailId message number
 *
 * @return string
 */
public function getMailMboxFormat($mailId)
{
    $option = (SE_UID == $this->imapSearchOption) ? FT_UID : 0;
    return imap_fetchheader($this->getImapStream(), $mailId, $option && FT_PREFETCHTEXT).imap_body($this->getImapStream(), $mailId, $option);
}

PhpImap\Mailbox::getMailboxes()

/**
 * Get folders list.
 *
 * @param string $search
 *
 * @return array
 */
public function getMailboxes($search = '*')
{
    $arr = [];
    if ($t = imap_getmailboxes($this->getImapStream(), $this->imapPath, $search)) {
        foreach ($t as $item) {
            // https://github.com/barbushin/php-imap/issues/339
            $name = $this->decodeStringFromUtf7ImapToUtf8($item->name);
            $arr[] = [
                'fullpath' => $name,
                'attributes' => $item->attributes,
                'delimiter' => $item->delimiter,
                'shortpath' => substr($name, strpos($name, '}') + 1),
            ];
        }
    }
    return $arr;
}

PhpImap\Mailbox::getSubscribedMailboxes()

/**
 * Get folders list.
 *
 * @param string $search
 *
 * @return array
 */
public function getSubscribedMailboxes($search = '*')
{
    $arr = [];
    if ($t = imap_getsubscribed($this->getImapStream(), $this->imapPath, $search)) {
        foreach ($t as $item) {
            // https://github.com/barbushin/php-imap/issues/339
            $name = $this->decodeStringFromUtf7ImapToUtf8($item->name);
            $arr[] = [
                'fullpath' => $name,
                'attributes' => $item->attributes,
                'delimiter' => $item->delimiter,
                'shortpath' => substr($name, strpos($name, '}') + 1),
            ];
        }
    }
    return $arr;
}

PhpImap\Mailbox::subscribeMailbox()

/**
 * Subscribe to a mailbox.
 *
 * @param string $mailbox
 *
 * @throws Exception
 */
public function subscribeMailbox($mailbox)
{
    $this->imap('subscribe', $this->getCombinedPath($mailbox));
}

PhpImap\Mailbox::unsubscribeMailbox()

/**
 * Unsubscribe from a mailbox.
 *
 * @param string $mailbox
 *
 * @throws Exception
 */
public function unsubscribeMailbox($mailbox)
{
    $this->imap('unsubscribe', $this->getCombinedPath($mailbox));
}

PhpImap\Mailbox::imap()


/**
 * Call IMAP extension function call wrapped with utf7 args conversion & errors handling.
 *
 * @param string       $methodShortName             Name of PHP imap_ method, but without the 'imap_' prefix. (eg. imap_fetch_overview => fetch_overview)
 * @param array|string $args                        All arguments of the original method, except the 'resource $imap_stream' (eg. imap_fetch_overview => string $sequence [, int $options = 0 ])
 * @param bool         $prependConnectionAsFirstArg Add 'resource $imap_stream' as first argument, if set to true
 * @param string|null  $throwExceptionClass         Name of exception class, which will be thrown in case of errors
 *
 * @throws Exception
 */
public function imap($methodShortName, $args = [], $prependConnectionAsFirstArg = true, $throwExceptionClass = Exception::class)
{
    if (!\is_array($args)) {
        $args = [$args];
    }
    // https://github.com/barbushin/php-imap/issues/242
    if (\in_array($methodShortName, ['open'])) {
        // Mailbox names that contain international characters besides those in the printable ASCII space have to be encoded with imap_utf7_encode().
        // https://www.php.net/manual/en/function.imap-open.php
        if (\is_string($args[0])) {
            if (preg_match("/^\{.*\}(.*)$/", $args[0], $matches)) {
                $mailbox_name = $matches[1];
                if (!mb_detect_encoding($mailbox_name, 'ASCII', true)) {
                    $args[0] = $this->encodeStringToUtf7Imap($mailbox_name);
                }
            }
        }
    } else {
        foreach ($args as &$arg) {
            if (\is_string($arg)) {
                $arg = $this->encodeStringToUtf7Imap($arg);
            }
        }
    }
    if ($prependConnectionAsFirstArg) {
        array_unshift($args, $this->getImapStream());
    }
    imap_errors(); // flush errors
    $result = @\call_user_func_array("imap_$methodShortName", $args);
    if (!$result) {
        $errors = imap_errors();
        if ($errors) {
            if ($throwExceptionClass) {
                throw new $throwExceptionClass("IMAP method imap_$methodShortName() failed with error: ".implode('. ', $errors));
            } else {
                return false;
            }
        }
    }
    return $result;
}
``

本文章首发在 LearnKu.com 网站上。

上一篇 下一篇
讨论数量: 0
发起讨论 只看当前版本


暂无话题~