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