php-libimap

php-libimap is a PHP imap library in pure OOP, the idea is to make the native php_imap functions easier to use with performance tunning in mind.

Installation

using composer , include this in your composer.json file :

"razzbee/php-libimap" : "dev-master"

Usage

Initialise class

$imap = new \PHPLibImap\IMAP;

connect an imap server

$imap->connectServer([
   'host' => 'localhost',
   'port' => 993,
   'imap_username' => 'username@domain.tld',
   'password' => 'secret',
   'mailbox_name' => 'INBOX',
   'enableSSL' => true,
]);

host : Your Imap mail server hostname , example : localhost , 19.10.10.2 , imap.domain.tld or domain.tld

port : your mailserver's imap's port , the default for secure connection is 993 and no secure connection is 143

imap_username : The full qualified email address of mail account , example: you@example.com

password : your mail account password.

mailbox_name : (optional) , the mailbox to open on an initial connection, if non is specified, INBOX will be used.

enableSSL : (optional) , This is for those using a custom port, so that the library will know if the port needs a secure connection

Switching Mailbox

After Connecting to the server, the optional mailbox_name supplied in the connection parameters is opened automatically , you can change or switch mailbox using

$imap-> switchMailBox('mailbox_name');

the mailbox_name must be one of the names of the mailfolders or boxes in your mailserver , example: INBOX , Drafts , Spam or Trash

Fetch MailBoxes (Mail Folders)

You can also list available mail boxes in mailserver

$mailBoxes = $imap->getMailBoxes($pattern);

$pattern: (optional) This is either * or % where :

* Means the library should fetch all the mailboxes including top level mail boxes and sub folders

% Means the library should fetch all sub folders in the current mailbox

read more here : http://php.net/manual/en/function.imap-getmailboxes.php

Get Info About a mailbox

$mailBoxInfo = $imap->getMailBoxInfo($mailboxName=null,$forceNew=false);

$mailBoxName: (optional) the name of the mailbox you want the info about, it defaults to the current opened mailbox if not set

$forceNew : (optional) The mailbox info is always prefetched and kept, but if you want a fresh copy of the info to be refetched , set this to true ..

Count Total Recent Messages

$totalRecent = $imap->getMailBoxInfo()->recent;

Count Total Unread Messages In the MailBox

$totalMsgNo = $imap->getTotalMessages();

//or

$totalMsgNo = $imap->getMailBoxInfo()->messages;

Fetch Mails From a MailBox

This library has many ways to fetch mails from a mailbox , we have also optimized this particular feature for speed and performance ..

Fetch MailBox Items overview By UID

$mails = $imap->fetchMailBoxItems("mailbox_name")
              ->select(uid1,uid2,uid3,uid4...uidN)
              ->getResults();

mailbox_name : optional mailbox name , if none is supplied, the current opened mailboxed will be used

select(uid1,uid2, ... ): Select mail headers by the uid or the integer id(s) of the mail(s) , you must provide a valid uid else an exception will be generated

getResults : Generate and get the results

Fetch Mail Overview using range

$mails = $imap->fetchMailBoxItems("mailbox_name")
              ->range(1,10)
              ->orderById('desc')
              ->getResults();

range(arg1,arg2) : The range of mail uid , the above example will pull mailbox item overview info of uid 1 to 10 , This method assumes you already know your range already..

orderById : Order the results by the uid , the default is DESC (Descending Order), this means the latest mails overview info will be shown first

Fetch Mail Overview using limit and Offset

Like mysql limit and offset , this library supports the limit and offset using the limit($limit,$offset) method..

$mails = $imap->fetchMailBoxItems("mailbox_name")
              ->limit(1,10)
              ->orderById('desc')
              ->getResults();

limit($limit,$offset=0) : The limit method accepts two arguments the limit and offset ,internally , the limits and offsets are been calculated automatically to ranges , this method is safer to use if you have no idea about the range values or number of data in the mailbox. The offset is optional and defaults to 0

Move Mail Between Mailboxes

This method moves email message between mailboxes or folder, on success true is returned else false,an exception will also occur on error ..

$move = $imap->moveMail($mails_uids_array,$source_mailbox,$destination_mailbox,$expunge=false);

$mails_uids_array : The mail(s) numeric uid in an array , it can contain 1 or more valid ids

$source_mailbox : The name of the mailbox where the mail is currently located at , example : INBOX , Drafts ...

$destination_mailbox : The Name of the new mail box you want to move the mail into , Example : Spam, drafts ....

$expunge : Optional boolean which tells the library to perform immediate clean up or deletion of the email at the source mailbox after moving

Mark as Mail as seen , answered , deleted , draft or flagged

$setFlag = $imap->setFlag($mails_uids_array,$flag,$mailBoxName);

$mails_uids_array : The mail(s) numeric uid in an array , it can contain 1 or more valid ids

$flag: The flag to set to ,valid flags : seen , answered, deleted , draft or flagged

$mailBoxName : Mailbox name of the mails you want to set the flags to if not provided , current opened mailbox will be used

Search Mail

Search into mailbox using a given criteria , use the getResults() method to retrive the results

        $keyword = "hello";

        //body must contain at least one occurrance of the keyword
        $searchCritiria['BODY'] = $keyword;

        //subject too must contain at least one occurrance of the keyword 
        $searchCritiria['SUBJECT'] = $keyword;

        $mailBoxName = "INBOX";

        $searchResults = $imap
            ->search($searchCritiria,$mailBoxName)
            ->limit(20)
            ->getResults();

$keyword The string we want to search for

$searchCritiria : The search Criteria which will be used for the search , read more about the criteria here : http://php.net/manual/en/function.imap-search.php

$mailBoxName: Optional Mailbox Name where you want to search into , if the mailbox name is omitted , the current opened mailbox will be used