сценарий отчета очереди почты груша? - PullRequest
1 голос
/ 14 апреля 2010

Есть ли в вашей базе данных MQ скрипт создания отчетов о очереди почты, который создает симпатичные диаграммы и графики? Я настроил MQ на работу cron и хочу привязать некоторые отчеты к моей консоли администратора.

1 Ответ

2 голосов
/ 16 апреля 2010

Не «изначально», но вы можете использовать новую поддержку обратного вызова в версии 1.2.3, чтобы заполнить таблицу журналов в вашей базе данных и генерировать ваши отчеты. Функция обратного вызова вызывается перед удалением соответствующей записи из таблицы mail_queue в базе данных, поэтому при необходимости вы можете добавить в нее дополнительные поля для вставки в таблицу журнала / отчета.

Вам нужно будет использовать последние выпуски пакетов PEAR Mail и Net_SMTP, чтобы иметь возможность получить идентификатор esmtp и данные приветствия, если они понадобятся для ваших отчетов. Кроме того, если вы хотите декодировать тело письма и сохранить его для своего отчета, вам необходимо установить пакет PEAR Mail_mimeDecode.

Укажите имя функции обратного вызова следующим образом:

$dn = $mail_queue->sendMailsInQueue(
    MAX_AMOUNT_MAILS,
    MAILQUEUE_START,  
    MAILQUEUE_MAX_RETRY,
    "callback_fn");

function callback_fn($args) {
    $row = get_mail_queue_row($args['id']);
    $headers = unserialize($row['headers']);
    $subject = $headers['Subject'];
    $body = unserialize($row['body']);

    $mh = '';
    foreach($headers as $key=>$value) {
        $mh .= "$key:$value\n";
    }
    $mail = $mh . "\n" . $body;
    $decoder = new Mail_mimeDecode($mail);
    $decoded = $decoder->decode(array(
        'include_bodies' => TRUE,
        'decode_bodies'  => TRUE,
        'decode_headers'  => TRUE,
    ));
    $body = $decoded->body;

    if (isset($args['greeting'])) {
        $greeting = $args['greeting'];
        $greets = explode(" ", $greeting);
        $detail =  "esmtp id: {$args['queued_as']}; server: {$greets[0]}";
    } else {
        $detail =  "esmtp id: {$args['queued_as']}; server: localhost";
    }

    insert_to_log($detail, $subject,...);
}
...