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