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