xref: /plugin/smtp/action.php (revision e6fd30d8fc6db97c4aee5cecfd2bcbcef6aa94eb)
1<?php
2/**
3 * DokuWiki Plugin smtp (Action Component)
4 *
5 * @license GPL 2 http://www.gnu.org/licenses/gpl-2.0.html
6 * @author  Andreas Gohr <andi@splitbrain.org>
7 */
8
9// must be run within Dokuwiki
10if(!defined('DOKU_INC')) die();
11
12class action_plugin_smtp extends DokuWiki_Action_Plugin {
13
14    /**
15     * Registers a callback function for a given event
16     *
17     * @param Doku_Event_Handler $controller DokuWiki's event controller object
18     * @return void
19     */
20    public function register(Doku_Event_Handler $controller) {
21
22       $controller->register_hook('MAIL_MESSAGE_SEND', 'BEFORE', $this, 'handle_mail_message_send');
23
24    }
25
26    /**
27     * [Custom event handler which performs action]
28     *
29     * @param Doku_Event $event  event object by reference
30     * @param mixed      $param  [the parameters passed as fifth argument to register_hook() when this
31     *                           handler was registered]
32     * @return void
33     */
34
35    public function handle_mail_message_send(Doku_Event &$event, $param) {
36        require_once __DIR__ . '/loader.php';
37
38        // prepare the message
39        /** @var Mailer $mailer Our Mailer with all the data */
40        $mailer = $event->data['mail'];
41        $rcpt   = $mailer->cleanAddress($event->data['to']) . ',' .
42                  $mailer->cleanAddress($event->data['cc']) . ',' .
43                  $mailer->cleanAddress($event->data['bcc']);
44        $from   = $event->data['from'];
45        $message = new \splitbrain\dokuwiki\plugin\smtp\Message(
46            $from,
47            $rcpt,
48            $mailer->dump()
49        );
50
51        // prepare the SMTP communication lib
52        $logger = new \splitbrain\dokuwiki\plugin\smtp\Logger();
53        $smtp = new \Tx\Mailer\SMTP($logger);
54        $smtp->setServer(
55            $this->getConf('smtp_host'),
56            $this->getConf('smtp_port'),
57            $this->getConf('smtp_ssl')
58        );
59        if($this->getConf('auth_user')){
60            $smtp->setAuth(
61                $this->getConf('auth_user'),
62                $this->getConf('auth_pass')
63            );
64        }
65        $smtp->setEhlo(
66            helper_plugin_smtp::getEHLO($this->getConf('localdomain'))
67        );
68
69
70        // send the message
71        try {
72            $smtp->send($message);
73            $ok = true;
74        } catch (Exception $e) {
75            msg('There was an unexpected problem communicating with SMTP: '.$e->getMessage(), -1);
76            $ok = false;
77        }
78
79        // give debugging help on error
80        if(!$ok && $this->getConf('debug')) {
81            $log = array();
82            foreach($logger->getLog() as $line) {
83                $log[] = trim($line[1]);
84            }
85            $log = trim(join("\n", $log));
86            msg('SMTP log:<br /><pre>'.hsc($log).'</pre><b>Above may contain passwords - do not post online!</b>',-1);
87        }
88
89        // finish event handling
90        $event->preventDefault();
91        $event->stopPropagation();
92        $event->result = $ok;
93        $event->data['success'] = $ok;
94    }
95
96}
97
98// vim:ts=4:sw=4:et:
99