anod / gmail-imap
API to work with Gmail using IMAP built on top of Zend Imap Library
Installs: 8 570
Dependents: 0
Suggesters: 0
Security: 0
Stars: 66
Watchers: 9
Forks: 11
Open Issues: 0
Requires
- php: ^7.2
- psr/log: ^1.1
- zendframework/zend-mail: 2.10.*
Requires (Dev)
- google/apiclient: ^2.0
- phpunit/phpunit: ^8
- squizlabs/php_codesniffer: ^3.5
This package is auto-updated.
Last update: 2024-11-27 20:50:19 UTC
README
Wrapper library above Gmail IMAP API.
Features
The library extends Zend Imap Library, this way it provides all basic IMAP functionality. In addition it provides simple Gmail specific API for:
- OAUTH2 Authentication
- get UID of the message
- work with GMail labels: retrive, apply, remove
- Getting Gmail thread id
- Utility to convert Gmail message id representation: from big int to hex and opposite
- Archive message
TODO
- move to inbox
- mark as read/unread
Requirements
Composer
- Zend Imap Library
Usage example
<?php // \Anod\Gmail\Math::bchexdec("FMfcgxwGCkZzGTlZHvpgXBHPvqzkLKtC") == "1430824723191418813" $msgId = "1430824723191418813"; $email = "alex.gavrishev@gmail.com"; $protocol = new \Anod\Gmail\Imap(true /* debug */); $gmail = new \Anod\Gmail\Gmail($protocol); $gmail->setId("Example App", "0.1", "Alex Gavrishev", "alex.gavrishev@gmail.com"); $gmail->connect(); $gmail->authenticate($email, $token); $gmail->sendId(); $gmail->selectInbox(); $uid = $gmail->getUID($msgId); $gmail->applyLabel($uid, "Very Important"); // Apply label to a message with specific UID $gmail->removeLabel($uid, "Not Important"); // Remove label to a message with specific UID $message = $gmail->getMessageData($uid); // Retrieve message content $details = array( 'subject' => $message->getHeader('subject', 'string'), 'body' => $message->getContent(), 'from' => $message->getHeader('from', 'string'), 'to' => $message->getHeader('to', 'string'), 'thrid' => \Anod\Gmail\Math::bcdechex($message->getThreadId()), 'labels' => $message->getLabels() ); $gmail->archive($uid); // Archive the message
Example of fetching token with local server php -S localhost:8000
<?php session_start(); require_once __DIR__ . '/vendor/autoload.php'; // Based on https://developers.google.com/identity/protocols/OAuth2 $clientId = Clien Id from google console; $clientSecret = Client secret from google console; $redirectUri = 'http://' . $_SERVER['HTTP_HOST'] . $_SERVER['PHP_SELF']; $client = new Google_Client([ 'client_id' => $clientId, 'client_secret' => $clientSecret, 'redirect_uri' => $redirectUri ]); // Scope for IMAP access $client->addScope("https://mail.google.com/"); if (isset($_GET['code'])) { $token = $client->fetchAccessTokenWithAuthCode($_GET['code']); $_SESSION['gmail_token'] = $token; // redirect back to the example header('Location: ' . filter_var($redirectUri, FILTER_SANITIZE_URL)); exit; } if (!empty($_SESSION['gmail_token'])) { $client->setAccessToken($_SESSION['gmail_token']); if ($client->isAccessTokenExpired()) { unset($_SESSION['gmail_token']); } } else { $authUrl = $client->createAuthUrl(); } if ($authUrl) { $authUrl = $client->createAuthUrl(); header("Location: $authUrl"); exit; } $token = $client->getAccessToken()['access_token']; echo "Token: $token\n\n";
Author
Alex Gavrishev, 2013
License
Library is licensed under the MIT license.