|
|
|
@ -1,33 +1,73 @@
|
|
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
class Mail_Handler{
|
|
|
|
|
|
|
|
|
|
private $db;
|
|
|
|
|
|
|
|
|
|
function oms_mail_send($recipient, $subject, $body, $from = NULL) {
|
|
|
|
|
function mail_fork() {
|
|
|
|
|
/*global $db;
|
|
|
|
|
$db = NULL;
|
|
|
|
|
$pid = pcntl_fork();
|
|
|
|
|
oms_db_connect();
|
|
|
|
|
return $pid;*/
|
|
|
|
|
$this->db = new DBLayer("lib");
|
|
|
|
|
//Start a new thread and return the thread id!
|
|
|
|
|
$pid = pcntl_fork();
|
|
|
|
|
return $pid;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
function oms_db_connect() {
|
|
|
|
|
global $db;
|
|
|
|
|
global $db_host, $db_name, $db_user, $db_pass;
|
|
|
|
|
if(!isset($db)) {
|
|
|
|
|
try {
|
|
|
|
|
$db = new PDO(
|
|
|
|
|
"mysql:host=$db_host;dbname=$db_name",
|
|
|
|
|
$db_user,
|
|
|
|
|
$db_pass,
|
|
|
|
|
array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8")
|
|
|
|
|
);
|
|
|
|
|
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
|
|
|
|
|
//$db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
|
|
|
|
|
oms_error_log("oms_db_connect: database connection established", 3);
|
|
|
|
|
} catch(PDOException $e) {
|
|
|
|
|
print "Database error: " . $e->getMessage() . "<br/>";
|
|
|
|
|
die();
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
oms_error_log("oms_db_connect: already connected");
|
|
|
|
|
}
|
|
|
|
|
}*/
|
|
|
|
|
|
|
|
|
|
function oms_mail_send($recipient, $subject, $body, $from = NULL) {
|
|
|
|
|
|
|
|
|
|
if(is_numeric($recipient)) {
|
|
|
|
|
$id_user = $recipient;
|
|
|
|
|
$recipient = NULL;
|
|
|
|
|
}
|
|
|
|
|
db_insert('email', array('recipient' => $recipient, 'subject' => $subject, 'body' => $body, 'status' => 'NEW', 'id_user' => $id_user, 'sender' => $from));
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function oms_mail_cron() {
|
|
|
|
|
|
|
|
|
|
$oms_inbox_username = '123';
|
|
|
|
|
$oms_inbox_password = '456';
|
|
|
|
|
$oms_host = 'test.com';
|
|
|
|
|
$oms_reply_to = "OMS <oms@".$oms_host.">";
|
|
|
|
|
function mail_cron() {
|
|
|
|
|
global $cfg;
|
|
|
|
|
$inbox_username = $cfg['mail']['username'];
|
|
|
|
|
$inbox_password = $cfg['mail']['password'];
|
|
|
|
|
$inbox_host = $cfg['mail']['host'];
|
|
|
|
|
$oms_reply_to = "OMS <oms@".$inbox_host.">";
|
|
|
|
|
global $basedir;
|
|
|
|
|
|
|
|
|
|
// Deliver new mail
|
|
|
|
|
echo("mail cron\n");
|
|
|
|
|
|
|
|
|
|
//TO ASK:
|
|
|
|
|
$pid = oms_fork();
|
|
|
|
|
$pid = mail_fork();
|
|
|
|
|
$pidfile = '/tmp/oms_cron_email_pid';
|
|
|
|
|
|
|
|
|
|
//if process is running, then we are already cronning
|
|
|
|
|
if($pid) {
|
|
|
|
|
|
|
|
|
|
// We're the main process.
|
|
|
|
@ -40,6 +80,8 @@ function oms_mail_cron() {
|
|
|
|
|
$file = fopen($pidfile, 'w');
|
|
|
|
|
fwrite($file, $pid);
|
|
|
|
|
fclose($file);
|
|
|
|
|
|
|
|
|
|
//select all new & failed emails & try to send them
|
|
|
|
|
$emails = db_query("select * from email where status = 'NEW' or status = 'FAILED'");
|
|
|
|
|
|
|
|
|
|
foreach($emails as $email) {
|
|
|
|
@ -51,7 +93,7 @@ function oms_mail_cron() {
|
|
|
|
|
|
|
|
|
|
if($email['sender']) {
|
|
|
|
|
$username = oms_get_username_from_id($email['sender']);
|
|
|
|
|
$from = "$username <$username@$oms_host>";
|
|
|
|
|
$from = "$username <$username@$inbox_host>";
|
|
|
|
|
} else {
|
|
|
|
|
$from = $oms_reply_to;
|
|
|
|
|
}
|
|
|
|
@ -64,14 +106,15 @@ function oms_mail_cron() {
|
|
|
|
|
$status = "FAILED";
|
|
|
|
|
echo("Email to {$email['recipient']} failed\n");
|
|
|
|
|
}
|
|
|
|
|
//change the status of the emails.
|
|
|
|
|
db_exec('update email set status = ?, message_id = ?, attempts = attempts + 1 where id_email = ?', array($status, $message_id, $email['id_email']));
|
|
|
|
|
}
|
|
|
|
|
unlink($pidfile);
|
|
|
|
|
}
|
|
|
|
|
// Check mail
|
|
|
|
|
|
|
|
|
|
//$mailbox = imap_open("{localhost:110/pop3/novalidate-cert}INBOX", $oms_inbox_username, $oms_inbox_password);
|
|
|
|
|
$mbox = imap_open("{localhost:110/pop3/novalidate-cert}INBOX", $oms_inbox_username, $oms_inbox_password);
|
|
|
|
|
//$mailbox = imap_open("{localhost:110/pop3/novalidate-cert}INBOX", $inbox_username, $inbox_password);
|
|
|
|
|
$mbox = imap_open($cfg['mail']['server'], $inbox_username, $inbox_password);
|
|
|
|
|
$message_count = imap_num_msg($mbox);
|
|
|
|
|
|
|
|
|
|
for ($i = 1; $i <= $message_count; ++$i) {
|
|
|
|
@ -96,11 +139,11 @@ function oms_mail_cron() {
|
|
|
|
|
imap_close($mbox);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function oms_new_message_id() {
|
|
|
|
|
function oms_new_message_id() {
|
|
|
|
|
|
|
|
|
|
$time = time();
|
|
|
|
|
$pid = getmypid();
|
|
|
|
@ -108,11 +151,11 @@ function oms_new_message_id() {
|
|
|
|
|
$oms_mail_count = ($oms_mail_count == '') ? 1 : $oms_mail_count + 1;
|
|
|
|
|
return "<oms.message.$pid.$oms_mail_count.$time@dev1.dev.subrigo.net>";
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function oms_create_email($from, $subject, $body, $html, $recipient = 0, $sender = NULL) {
|
|
|
|
|
function oms_create_email($from, $subject, $body, $html, $recipient = 0, $sender = NULL) {
|
|
|
|
|
|
|
|
|
|
if($recipient == 0 && !is_string($recipient)) {
|
|
|
|
|
global $user;
|
|
|
|
@ -146,11 +189,11 @@ function oms_create_email($from, $subject, $body, $html, $recipient = 0, $sender
|
|
|
|
|
oms_task_index($message, array('subject', 'body', 'sender', 'recipient'));
|
|
|
|
|
//---------------------------
|
|
|
|
|
return $message['id_task'];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function oms_get_email($id) {
|
|
|
|
|
function oms_get_email($id) {
|
|
|
|
|
|
|
|
|
|
$message = oms_task_load($id);
|
|
|
|
|
if($message) {
|
|
|
|
@ -160,30 +203,30 @@ function oms_get_email($id) {
|
|
|
|
|
return FALSE;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function oms_prepare_email(&$message) {
|
|
|
|
|
function oms_prepare_email(&$message) {
|
|
|
|
|
|
|
|
|
|
$data = $message['data'];
|
|
|
|
|
$data['id_message'] = $message['id_task'];
|
|
|
|
|
$data['read'] = ($message['status'] != 'NEW' && $message['status'] != 'UNREAD');
|
|
|
|
|
$message = $data;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function oms_email_mark_read($mid) {
|
|
|
|
|
function oms_email_mark_read($mid) {
|
|
|
|
|
|
|
|
|
|
db_exec("update task set status = 'READ' where id_task = ? and type = 'email' and module = 'email'", array($mid));
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function decode_utf8($str) {
|
|
|
|
|
function decode_utf8($str) {
|
|
|
|
|
|
|
|
|
|
preg_match_all("/=\?UTF-8\?B\?([^\?]+)\?=/i",$str, $arr);
|
|
|
|
|
for ($i=0;$i<count($arr[1]);$i++){
|
|
|
|
@ -192,13 +235,13 @@ function decode_utf8($str) {
|
|
|
|
|
}
|
|
|
|
|
return $str;
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function get_mime_type(&$structure) {
|
|
|
|
|
function get_mime_type(&$structure) {
|
|
|
|
|
|
|
|
|
|
$primary_mime_type = array("TEXT", "MULTIPART","MESSAGE", "APPLICATION", "AUDIO","IMAGE", "VIDEO", "OTHER");
|
|
|
|
|
if($structure->subtype) {
|
|
|
|
@ -206,11 +249,11 @@ function get_mime_type(&$structure) {
|
|
|
|
|
}
|
|
|
|
|
return "TEXT/PLAIN";
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function get_part($stream, $msg_number, $mime_type, $structure = false, $part_number = false) {
|
|
|
|
|
function get_part($stream, $msg_number, $mime_type, $structure = false, $part_number = false) {
|
|
|
|
|
|
|
|
|
|
if(!$structure) {
|
|
|
|
|
$structure = imap_fetchstructure($stream, $msg_number);
|
|
|
|
@ -247,6 +290,6 @@ function get_part($stream, $msg_number, $mime_type, $structure = false, $part_nu
|
|
|
|
|
} // END OF STRUTURE
|
|
|
|
|
return false;
|
|
|
|
|
|
|
|
|
|
} // END OF FUNCTION
|
|
|
|
|
|
|
|
|
|
} // END OF FUNCTION
|
|
|
|
|
|
|
|
|
|
}
|