xref: /plugin/publish/action/mail.php (revision eb718fbbb17a6bf8d6cbd1344b92819a1480b25a)
1698cf656SMichael Große<?php
2698cf656SMichael Große/**
3698cf656SMichael Große * @license GNU General Public License, version 2
4698cf656SMichael Große */
5698cf656SMichael Große
6698cf656SMichael Große
7698cf656SMichael Großeif (!defined('DOKU_INC')) die();
8698cf656SMichael Große
9698cf656SMichael Große
10698cf656SMichael Große/**
11698cf656SMichael Große * Class action_plugin_publish_mail
12698cf656SMichael Große *
13698cf656SMichael Große * @author Michael Große <grosse@cosmocode.de>
14698cf656SMichael Große */
15698cf656SMichael Großeclass action_plugin_publish_mail extends DokuWiki_Action_Plugin {
16698cf656SMichael Große
17a9071e04SMichael Große    /**
18a9071e04SMichael Große     * @var helper_plugin_publish
19a9071e04SMichael Große     */
20a9071e04SMichael Große    private $hlp;
21a9071e04SMichael Große
22a9071e04SMichael Große    function __construct() {
23a9071e04SMichael Große        $this->hlp = plugin_load('helper','publish');
24a9071e04SMichael Große    }
25a9071e04SMichael Große
26698cf656SMichael Große    public function register(Doku_Event_Handler $controller) {
27698cf656SMichael Große
28698cf656SMichael Große        $controller->register_hook('IO_WIKIPAGE_WRITE', 'AFTER', $this, 'send_change_mail', array());
29698cf656SMichael Große    }
30698cf656SMichael Große
314f5c41dbSMichael Große    /**
324f5c41dbSMichael Große     * send an email to inform about a changed page
334f5c41dbSMichael Große     *
344f5c41dbSMichael Große     * @param $event
354f5c41dbSMichael Große     * @param $param
36d5f6523fSMichael Große     * @return bool false if the receiver is invalid or there was an error passing the mail to the MTA
374f5c41dbSMichael Große     */
38698cf656SMichael Große    function send_change_mail(&$event, $param) {
39698cf656SMichael Große        global $ID;
40698cf656SMichael Große        global $ACT;
41698cf656SMichael Große        global $INFO;
420d6459beSMichael Große        global $conf;
43698cf656SMichael Große        $data = pageinfo();
44698cf656SMichael Große
45698cf656SMichael Große        if ($ACT != 'save') {
46698cf656SMichael Große            return true;
47698cf656SMichael Große        }
488bc37331SMichael Große
498bc37331SMichael Große        // IO_WIKIPAGE_WRITE is always called twice when saving a page. This makes sure to only send the mail once.
50698cf656SMichael Große        if (!$event->data[3]) {
51698cf656SMichael Große            return true;
52698cf656SMichael Große        }
53698cf656SMichael Große
548bc37331SMichael Große        // Does the publish plugin apply to this page?
558bc37331SMichael Große        if (!$this->hlp->isActive($ID)) {
568bc37331SMichael Große            return true;
578bc37331SMichael Große        }
588bc37331SMichael Große
598bc37331SMichael Große        //are we supposed to send change-mails at all?
60d5f6523fSMichael Große        if ($this->getConf('apr_mail_receiver') === '') {
618bc37331SMichael Große            return true;
628bc37331SMichael Große        }
638bc37331SMichael Große
64698cf656SMichael Große        // get mail receiver
65698cf656SMichael Große        $receiver = $this->getConf('apr_mail_receiver');
66d5f6523fSMichael Große        $validator                      = new EmailAddressValidator();
67d5f6523fSMichael Große        $validator->allowLocalAddresses = true;
68d5f6523fSMichael Große        if(!$validator->check_email_address($receiver)) {
69d5f6523fSMichael Große            dbglog(sprintf($this->getLang('mail_invalid'),htmlspecialchars($receiver)));
70d5f6523fSMichael Große            return false;
71d5f6523fSMichael Große        }
72698cf656SMichael Große
73698cf656SMichael Große        // get mail sender
742583d55dSMichael Große        $ReplyTo = $data['userinfo']['mail'];
75698cf656SMichael Große
762583d55dSMichael Große        if ($ReplyTo == $receiver) {
779e614880SMichael Große            return true;
78698cf656SMichael Große        }
79698cf656SMichael Große
80698cf656SMichael Große        if ($INFO['isadmin'] == '1') {
819e614880SMichael Große            return true;
82698cf656SMichael Große        }
83698cf656SMichael Große
84698cf656SMichael Große        // get mail subject
850d6459beSMichael Große        $timestamp = dformat($data['lastmod'], $conf['dformat']);
860d6459beSMichael Große        $subject = $this->getLang('apr_mail_subject') . ': ' . $ID . ' - ' . $timestamp;
87698cf656SMichael Große
88e6206222SMichael Große        $body = $this->create_mail_body('change');
89698cf656SMichael Große
902583d55dSMichael Große        $mail = new Mailer();
912583d55dSMichael Große        $mail->to($receiver);
922583d55dSMichael Große        $mail->subject($subject);
932583d55dSMichael Große        $mail->setBody($body);
942583d55dSMichael Große        $mail->setHeader("Reply-To", $ReplyTo);
952583d55dSMichael Große        $returnStatus = $mail->send();
9612699d35SMichael Große        return $returnStatus;
97698cf656SMichael Große    }
98698cf656SMichael Große
99e6206222SMichael Große    /**
100e6206222SMichael Große     * Create the body of mails to inform about a changed or an approved page
101e6206222SMichael Große     *
102e6206222SMichael Große     * @param string $action Must either be "change" or "approve"
103e6206222SMichael Große     * @return bool|string
104*eb718fbbSMichael Große     *
105e6206222SMichael Große     */
106e6206222SMichael Große    public function create_mail_body($action) {
107e6206222SMichael Große        global $ID;
1088ff23e7fSMichael Große        global $conf;
109e6206222SMichael Große        $pageinfo = pageinfo();
110bc4555caSMichael Große
1118ff23e7fSMichael Große        // get mail text
1128ff23e7fSMichael Große        $rev = $pageinfo['lastmod'];
1138ff23e7fSMichael Große
114bc4555caSMichael Große        if ($action === 'change') {
115c447490bSMichael Große            $body = io_readFile($this->localFN('mailchangetext'));
116bc4555caSMichael Große
1178ff23e7fSMichael Große            //If there is no approved revision show the diff to the revision before. Otherwise show the diff to the last approved revision.
1188ff23e7fSMichael Große            if($this->hlp->hasApprovals($pageinfo['meta'])) {
119c447490bSMichael Große                $aprpre = 'Aproved';
120c447490bSMichael Große                $oldrev = $this->hlp->getLatestApprovedRevision($ID);
121c447490bSMichael Große                $difflink = $this->hlp->getDifflink($ID, $oldrev, $rev);
1228ff23e7fSMichael Große            } else {
123c447490bSMichael Große                $aprpre = 'Previous';
124e6206222SMichael Große                $changelog = new PageChangelog($ID);
125c447490bSMichael Große                $oldrev = $changelog->getRelativeRevision($rev, -1);
126c447490bSMichael Große                $difflink = $this->hlp->getDifflink($ID, $oldrev, $rev);
1278ff23e7fSMichael Große            }
128c447490bSMichael Große
129c447490bSMichael Große            $body = str_replace('@DIFF@', $difflink, $body);
130c447490bSMichael Große            $body = str_replace('@APRPRE@', $aprpre, $body);
131c447490bSMichael Große            $summary = $pageinfo['meta']['last_change']['sum'];
132c447490bSMichael Große            $body = str_replace('@SUMMARY@', $summary, $body);
133c447490bSMichael Große            if ($oldrev === false ) {
134c447490bSMichael Große                $oldlink = '---';
135c447490bSMichael Große            } else {
136c447490bSMichael Große                $oldlink = $this->revlink($ID, $oldrev);
137c447490bSMichael Große            }
138c447490bSMichael Große            $body = str_replace('@OLDPAGE@', $oldlink, $body);
139c447490bSMichael Große            $newlink = $this->revlink($ID, $rev);
140c447490bSMichael Große            $body = str_replace('@NEWPAGE@', $newlink, $body);
141bc4555caSMichael Große        } elseif ($action === 'approve') {
142c447490bSMichael Große            $body = io_readFile($this->localFN('mailapprovetext'));
143c447490bSMichael Große            $newlink = $this->revlink($ID, $rev);
144c447490bSMichael Große            $body = str_replace('@URL@', $newlink, $body);
145*eb718fbbSMichael Große
146*eb718fbbSMichael Große            $changelog = new PageChangelog($ID);
147*eb718fbbSMichael Große            $revinfo = $changelog->getRevisionInfo($rev);
148*eb718fbbSMichael Große            /** @var DokuWiki_Auth_Plugin $auth */
149*eb718fbbSMichael Große            global $auth;
150*eb718fbbSMichael Große            $userinfo = $auth->getUserData($revinfo['user']);
151*eb718fbbSMichael Große            $body = str_replace('@FULLNAME@', $userinfo['name'], $body);
152bc4555caSMichael Große        } else {
153bc4555caSMichael Große            return false;
154bc4555caSMichael Große        }
155bc4555caSMichael Große
1568ff23e7fSMichael Große        $body = str_replace('@DOKUWIKIURL@', DOKU_URL, $body);
1578ff23e7fSMichael Große        $body = str_replace('@TITLE@', $conf['title'], $body);
1588ff23e7fSMichael Große
1598ff23e7fSMichael Große        return $body;
1608ff23e7fSMichael Große    }
1618ff23e7fSMichael Große
1628ff23e7fSMichael Große
1639e614880SMichael Große
1649e614880SMichael Große    /**
1659e614880SMichael Große     * Send approve-mail to editor of the now approved revision
1669e614880SMichael Große     *
1672583d55dSMichael Große     * @return bool false if there was an error passing the mail to the MTA
1689e614880SMichael Große     */
16919a54b91SMichael Große    public function send_approve_mail() {
17019a54b91SMichael Große        global $ID;
17119a54b91SMichael Große        global $REV;
1728cd8852aSMichael Große
1738cd8852aSMichael Große        /** @var DokuWiki_Auth_Plugin $auth */
1748cd8852aSMichael Große        global $auth;
175698cf656SMichael Große        $data = pageinfo();
17619a54b91SMichael Große
17719a54b91SMichael Große        // get mail receiver
1783c21cb49SMichael Große        if (!$REV) {
1793c21cb49SMichael Große            $rev = $data['lastmod'];
1803c21cb49SMichael Große        } else {
1813c21cb49SMichael Große            $rev=$REV;
1823c21cb49SMichael Große        }
1838cd8852aSMichael Große        $changelog = new PageChangelog($ID);
1843c21cb49SMichael Große        $revinfo = $changelog->getRevisionInfo($rev);
1858cd8852aSMichael Große        $userinfo = $auth->getUserData($revinfo['user']);
1868cd8852aSMichael Große        $receiver = $userinfo['mail'];
187bc4555caSMichael Große
18819a54b91SMichael Große        // get mail sender
1892583d55dSMichael Große        $ReplyTo = $data['userinfo']['mail'];
1902583d55dSMichael Große
1912583d55dSMichael Große        if ($ReplyTo == $receiver) {
1922583d55dSMichael Große            return true;
1932583d55dSMichael Große        }
194bc4555caSMichael Große
19519a54b91SMichael Große        // get mail subject
19619a54b91SMichael Große        $subject = $this->getLang('apr_mail_app_subject');
197698cf656SMichael Große
198bc4555caSMichael Große        // get mail text
199e6206222SMichael Große        $body = $this->create_mail_body('approve');
20019a54b91SMichael Große
2012583d55dSMichael Große        $mail = new Mailer();
2022583d55dSMichael Große        $mail->to($receiver);
2032583d55dSMichael Große        $mail->subject($subject);
2042583d55dSMichael Große        $mail->setBody($body);
2052583d55dSMichael Große        $mail->setHeader("Reply-To", $ReplyTo);
2062583d55dSMichael Große        $returnStatus = $mail->send();
2073c21cb49SMichael Große
2082583d55dSMichael Große        return $returnStatus;
209698cf656SMichael Große    }
210698cf656SMichael Große
211698cf656SMichael Große    /**
212f31c6595SMichael Große     * create link to the specified revision
213698cf656SMichael Große     *
214f31c6595SMichael Große     * @param string $id
215f31c6595SMichael Große     * @param string $rev The timestamp of the revision
216846d3071SMichael Große     * @return string
217698cf656SMichael Große     */
218f31c6595SMichael Große    function revlink($id, $rev) {
219698cf656SMichael Große
220698cf656SMichael Große        $options = array(
221698cf656SMichael Große             'rev'=> $rev,
222698cf656SMichael Große        );
223f31c6595SMichael Große        $revlink = wl($id, $options, true, '&');
224698cf656SMichael Große
225f31c6595SMichael Große        return $revlink;
226698cf656SMichael Große    }
227698cf656SMichael Große
228698cf656SMichael Große}
229