HEX
Server: LiteSpeed
System: Linux d8 4.18.0-553.121.1.lve.el8.x86_64 #1 SMP Thu Apr 30 16:40:41 UTC 2026 x86_64
User: wbwebdes (3015)
PHP: 8.1.31
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/wbwebdes/domains/support.wb-webdesign.com/private_html/inc/mail/imap/HeskIMAP.php
<?php
/**
 *
 * This file is part of HESK - PHP Help Desk Software.
 *
 * (c) Copyright Klemen Stirn. All rights reserved.
 * https://www.hesk.com
 *
 * For the full copyright and license agreement information visit
 * https://www.hesk.com/eula.php
 *
 */

class HeskIMAP {

    /**
     * @var string $host
     */
    public $host;

    /**
     * @var integer $port
     */
    public $port;

    /**
     * @var string $username
     */
    public $username;

    /**
     * @var string $password
     */
    public $password;

    /**
     * @var string $accessToken
     */
    public $accessToken;

    /**
     * @var string $folder
     */
    public $folder = 'INBOX';

    /**
     * @var boolean
     */
    public $ssl = false;

    /**
     * @var boolean
     */
    public $tls = false;

    /**
     * @var boolean
     */
    public $ignoreCertificateErrors = false;

    /**
     * @var integer $connectTimeout
     */
    public $connectTimeout = 20;

    /**
     * @var integer $responseTimeout
     */
    public $responseTimeout = 20;

    /**
     * Will we be connecting using OAuth?
     * @var boolean
     */
    public $useOAuth = false;

    /**
     * Connect to IMAP in read only mode
     * @var boolean
     */
    public $readOnly = false;

    /**
     * Disable GSSAPI - a workaround for Kerberos error
     * @var boolean
     */
    public $disableGSSAPI = false;

    // Resource storage
    private $imap;

    // Mailbox path for imap_open
    private $mailbox;

    // Storage for imap_search results
    private $emails;

    // Storage for error messages
    private $errors;


    /**
     * @var string $imap_mailbox // Declare the property
     */
    public $imap_mailbox;

    /**
     * Connects to Host if successful returns true else false
     * @return boolean
     */
    public function login() {
        if ($this->useOAuth) {
            //echo "using OAuth class<br>\n";
            require 'OAuthIMAP.php';
            $this->imap = new OAuthIMAP();

            if ($this->ssl) {
                $this->imap->host = 'ssl://' . $this->host;
            } elseif ($this->tls) {
                $this->imap->host = 'tls://' . $this->host;
            } else {
                $this->imap->host = $this->host;
            }

            $this->imap->port = $this->port;
            $this->imap->username = $this->username;
            if ($this->password)
                $this->imap->password = $this->password;
            if ($this->accessToken)
                $this->imap->accessToken = $this->accessToken;
            $this->imap->ignoreCertificateErrors = $this->ignoreCertificateErrors;
            $this->imap->tls = $this->tls;
            $this->imap->connectTimeout = $this->connectTimeout;
            $this->imap->responseTimeout = $this->responseTimeout;

            return $this->imap->login();
        } else {
            //echo "using PHP IMAP extension<br>\n";
            // We need the PHP IMAP extension for this to work
            if ( ! function_exists('imap_open')) {
                global $hesklang;
                die($hesklang['iei']);
            }

            // IMAP mailbox based on required encryption
            if ($this->ssl) {
                $this->mailbox = '{'.$this->host.':'.$this->port.'/imap/ssl'.($this->ignoreCertificateErrors ? '/novalidate-cert' : '').'}';
            } elseif ($this->tls) {
                $this->mailbox = '{'.$this->host.':'.$this->port.'/imap/tls'.($this->ignoreCertificateErrors ? '/novalidate-cert' : '').'}';
            } else {
                $this->mailbox = '{'.$this->host.':'.$this->port.'}';
            }

            $this->mailbox .= $this->imap_mailbox; // Added for IMAP Mailbox
            imap_timeout(IMAP_OPENTIMEOUT, $this->connectTimeout);
            imap_timeout(IMAP_READTIMEOUT, $this->responseTimeout);
            imap_timeout(IMAP_WRITETIMEOUT, $this->responseTimeout);
            imap_timeout(IMAP_CLOSETIMEOUT, $this->responseTimeout);

            if ($this->disableGSSAPI) {
                $options = array('DISABLE_AUTHENTICATOR' => 'GSSAPI');
            } else {
                $options = array();
            }

            // Connect to IMAP
            if ($this->readOnly) {
                $this->imap = @imap_open($this->mailbox, $this->username, $this->password, OP_READONLY, 0, $options);
            } else {
                $this->imap = @imap_open($this->mailbox, $this->username, $this->password, 0, 0, $options);
            }

            return $this->imap;
        }
    }

    /**
     * Disconnects from Host
     */
    public function logout() {
        if ($this->useOAuth) {
            $this->imap->logout();
        } else {
            imap_close($this->imap);
        }
    }

    /**
     * Returns number of unseen emails in a folder
     * @retun integer
     */
    public function hasUnseenMessages() {
        if ($this->useOAuth) {
            return $this->imap->totalUnseenMails($this->folder);
        } else {
            $emails = imap_search($this->imap, 'UNSEEN');

            if (is_array($emails)) {
                $this->emails = $emails;
                return count($emails);
            } else {
                return 0;
            }
        }
    }

    /**
     * Gets a list of message IDs of unseen messages
     * @return Array
     */
	public function getUnseenMessageIDs() {
        if ($this->useOAuth) {
            $this->imap->selectFolder($this->folder, $this->readOnly);
            return $this->imap->getUnseenMessageIDs();
        }

        if (is_array($this->emails)) {
            return $this->emails;
        }

        return array();
	}

    /**
     * Fetch a single mail and return
     * @param integer $id
     * @return mixed
     */
    public function getMessage($id) {
        if ($this->useOAuth) {
            return $this->imap->getMessage($id);
        } else {
            return imap_fetchbody($this->imap, $id, "");
        }
    }

    /**
     * Fetch a single mail and save it to a file
     * @param integer $id
     * @param string $file
     * @return boolean
     */
    public function saveMessageToFile($id, $file) {
        if ($this->useOAuth) {
            return $this->imap->saveMessageToFile($id, $file);
        } else {
            return imap_savebody($this->imap, $file, $id, "");
        }
    }

    /**
     * Marks a message for deletion
     * @param integer $id
     */
    public function delete($id) {
        if ($this->useOAuth) {
            $this->imap->delete($id);
        } else {
            imap_delete($this->imap, $id);
        }
    }

    /**
     * Expunges mailbox (deletes messages makred with \Deleted flag)
     */
    public function expunge() {
        if ($this->useOAuth) {
            $this->imap->expunge();
        } else {
            imap_expunge($this->imap);
        }
    }

    /**
     * Return IMAP errors
     * @return mixed
     */
    public function getErrors() {
        if ($this->useOAuth) {
            return $this->imap->getErrors();
        } else {
            return imap_errors();
        }
    }

}