159 lines
4.7 KiB
PHP
159 lines
4.7 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
+--------------------------------------------------------------------+
|
||
|
| CiviCRM version 4.7 |
|
||
|
+--------------------------------------------------------------------+
|
||
|
| Copyright CiviCRM LLC (c) 2004-2017 |
|
||
|
+--------------------------------------------------------------------+
|
||
|
| This file is a part of CiviCRM. |
|
||
|
| |
|
||
|
| CiviCRM is free software; you can copy, modify, and distribute it |
|
||
|
| under the terms of the GNU Affero General Public License |
|
||
|
| Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
|
||
|
| |
|
||
|
| CiviCRM is distributed in the hope that it will be useful, but |
|
||
|
| WITHOUT ANY WARRANTY; without even the implied warranty of |
|
||
|
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
|
||
|
| See the GNU Affero General Public License for more details. |
|
||
|
| |
|
||
|
| You should have received a copy of the GNU Affero General Public |
|
||
|
| License and the CiviCRM Licensing Exception along |
|
||
|
| with this program; if not, contact CiviCRM LLC |
|
||
|
| at info[AT]civicrm[DOT]org. If you have questions about the |
|
||
|
| GNU Affero General Public License or the licensing of CiviCRM, |
|
||
|
| see the CiviCRM license FAQ at http://civicrm.org/licensing |
|
||
|
+--------------------------------------------------------------------+
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
*
|
||
|
* @package CRM
|
||
|
* @copyright CiviCRM LLC (c) 2004-2017
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Class CRM_Mailing_MailStore_Localdir
|
||
|
*/
|
||
|
class CRM_Mailing_MailStore_Localdir extends CRM_Mailing_MailStore {
|
||
|
|
||
|
/**
|
||
|
* Connect to the supplied dir and make sure the two mail dirs exist.
|
||
|
*
|
||
|
* @param string $dir
|
||
|
* Dir to operate upon.
|
||
|
*
|
||
|
* @return \CRM_Mailing_MailStore_Localdir
|
||
|
*/
|
||
|
public function __construct($dir) {
|
||
|
$this->_dir = $dir;
|
||
|
|
||
|
$this->_ignored = $this->maildir(implode(DIRECTORY_SEPARATOR, array(
|
||
|
'CiviMail.ignored',
|
||
|
date('Y'),
|
||
|
date('m'),
|
||
|
date('d'),
|
||
|
)));
|
||
|
$this->_processed = $this->maildir(implode(DIRECTORY_SEPARATOR, array(
|
||
|
'CiviMail.processed',
|
||
|
date('Y'),
|
||
|
date('m'),
|
||
|
date('d'),
|
||
|
)));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Return the next X messages from the mail store.
|
||
|
* FIXME: in CiviCRM 2.2 this always returns all the emails
|
||
|
*
|
||
|
* @param int $count
|
||
|
* Number of messages to fetch FIXME: ignored in CiviCRM 2.2 (assumed to be 0, i.e., fetch all).
|
||
|
*
|
||
|
* @return array
|
||
|
* array of ezcMail objects
|
||
|
*/
|
||
|
public function fetchNext($count = 0) {
|
||
|
$mails = array();
|
||
|
$path = rtrim($this->_dir, DIRECTORY_SEPARATOR);
|
||
|
|
||
|
if ($this->_debug) {
|
||
|
|
||
|
print "fetching $count messages\n";
|
||
|
|
||
|
}
|
||
|
|
||
|
$directory = new DirectoryIterator($path);
|
||
|
foreach ($directory as $entry) {
|
||
|
if ($entry->isDot()) {
|
||
|
continue;
|
||
|
}
|
||
|
if (count($mails) >= $count) {
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
$file = $path . DIRECTORY_SEPARATOR . $entry->getFilename();
|
||
|
if ($this->_debug) {
|
||
|
print "retrieving message $file\n";
|
||
|
}
|
||
|
|
||
|
$set = new ezcMailFileSet(array($file));
|
||
|
$parser = new ezcMailParser();
|
||
|
// set property text attachment as file CRM-5408
|
||
|
$parser->options->parseTextAttachmentsAsFiles = TRUE;
|
||
|
|
||
|
$mail = $parser->parseMail($set);
|
||
|
|
||
|
if (!$mail) {
|
||
|
return CRM_Core_Error::createAPIError(ts('%1 could not be parsed',
|
||
|
array(1 => $file)
|
||
|
));
|
||
|
}
|
||
|
$mails[$file] = $mail[0];
|
||
|
}
|
||
|
|
||
|
if ($this->_debug && (count($mails) <= 0)) {
|
||
|
|
||
|
print "No messages found\n";
|
||
|
|
||
|
}
|
||
|
|
||
|
return $mails;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fetch the specified message to the local ignore folder.
|
||
|
*
|
||
|
* @param int $file
|
||
|
* File location of the message to fetch.
|
||
|
*
|
||
|
* @throws Exception
|
||
|
*/
|
||
|
public function markIgnored($file) {
|
||
|
if ($this->_debug) {
|
||
|
print "moving $file to ignored folder\n";
|
||
|
}
|
||
|
$target = $this->_ignored . DIRECTORY_SEPARATOR . basename($file);
|
||
|
if (!rename($file, $target)) {
|
||
|
throw new Exception("Could not rename $file to $target");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Fetch the specified message to the local processed folder.
|
||
|
*
|
||
|
* @param int $file
|
||
|
* File location of the message to fetch.
|
||
|
*
|
||
|
* @throws Exception
|
||
|
*/
|
||
|
public function markProcessed($file) {
|
||
|
if ($this->_debug) {
|
||
|
print "moving $file to processed folder\n";
|
||
|
}
|
||
|
$target = $this->_processed . DIRECTORY_SEPARATOR . basename($file);
|
||
|
if (!rename($file, $target)) {
|
||
|
throw new Exception("Could not rename $file to $target");
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|