2017 © Pedro Peláez
 

library gmail-imap

API to work with Gmail using IMAP built on top of Zend Imap Library

image

anod/gmail-imap

API to work with Gmail using IMAP built on top of Zend Imap Library

  • Thursday, August 25, 2016
  • by anod
  • Repository
  • 7 Watchers
  • 59 Stars
  • 3,699 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 14 Forks
  • 0 Open issues
  • 2 Versions
  • 7 % Grown

The README.md

GMAIL IMAP API in PHP

Wrapper library above Gmail IMAP API., (*1)

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, (*2)

TODO

  • move to inbox
  • mark as read/unread

Requirements

Composer * Zend Imap Library, (*3)

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, (*4)

<?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, (*5)

License

Library is licensed under the MIT license., (*6)

The Versions

25/08 2016

dev-master

9999999-dev http://github.com/anod/gmail-imap-php

API to work with Gmail using IMAP built on top of Zend Imap Library

  Sources   Download

MIT

The Requires

 

The Development Requires

by Alex Gavrishev

imap gmail

12/05 2015

v1.1

1.1.0.0 http://github.com/anod/gmail-imap-php

API to work with Gmail using IMAP built on top of Zend Imap Library

  Sources   Download

MIT

The Requires

 

The Development Requires

by Alex Gavrishev

imap gmail