Git Product home page Git Product logo

email-reply's Introduction

Email Reply

The library passes reply messages from email to predefined objects. It uses IMAP to connect email servers.

Latest Stable Version Build Status

Limitation

The library uses ddeboer/imap and it requires:

  • PHP >= 7.1
  • extensions iconv, IMAP, mbstring

Installation

The preferred way to install this extension is through composer.

Either run

php composer.phar require --prefer-dist tigrov/email-reply

or add

"tigrov/email-reply": "~1.0"

to the require section of your composer.json file.

Usage

First of all you need to configure your email server. Create special mailbox and redirect all the mails sent to non-existent mailboxes. The server must accepts IMAP connections.

Then you can take steps:

  1. Create a model class with ModelInterface interface and implement the necessary methods (see examples/Model.php).
    class Model implements ModelInterface
    {
        public static function paramNames() {}
    
        public function paramValues() {}
    
        public static function buildFromParams($paramValues) {}
    
        public function emailReply($message) {}
    }
  2. Create and configure EmailReply object.
    $config = [
        'classesMap' => [
            // key will be used as prefix for email address
            'model' => \Model::class,
            // email for reply will be like [email protected]
            // or
            // 'm' => \Model::class,
            // email for reply will be like [email protected]
            // where 5 is id of a model
        ],
    ];
    
    $emailReply = new EmailReply($config);
  3. Send a email message with a special reply email address.
    $email = $emailReply->getReplyEmail($model, 'domain.com');
    
    // Send an email to somebody with the reply email $email
    // ...
  4. Read your mailboxes using IMAP. For example as cron job.
    $server = new Server($host, $port);
    
    $connection = $server->authenticate($username, $password);
    
    $mailboxModels = Reader::getMailboxModels($connection);
    
    $messages = Reader::getIterator($mailboxModels);
    
    $emailReply->read($messages);
    
    $connection->expunge();
  5. Each message will be passed to ModelInterface::emailReply($message) where you can precess them.
    class Model implements ModelInterface
    {
        // ...
    
        public function emailReply($message)
        {
            /** @var string $fromEmail email address of the sender */
            $fromEmail = $message->getFrom()->getAddress();
            
            /** @var string $fromName name of the sender */
            $fromName = $message->getFrom()->getName();
            
            /** @var string $content content from the replied message */
            $content = $message->getBodyHtml() ?: $message->getBodyText() ?: $message->getDecodedContent();
            
            // Parse the content to get only answer
            $content = EmailReplyParser::parseReply($content);
            
            // To do something with $content
            // e.g. add comment from $fromEmail to the object 
        }

See examples directory for examples.

Also see EmailReply for Yii2.

Suggests

You can use willdurand/email-reply-parser to parse only reply text from email messages.

$reply = EmailReplyParser::parseReply($content);

License

MIT

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.