xref: /plugin/discussion/action.php (revision 2e80cd5ff467c94585d3a9cb81c88f187a1ccce5)
1f0fda08aSwikidesign<?php
2f0fda08aSwikidesign/**
3f0fda08aSwikidesign * @license    GPL 2 (http://www.gnu.org/licenses/gpl.html)
4f0fda08aSwikidesign * @author     Esther Brunner <wikidesign@gmail.com>
5f0fda08aSwikidesign */
6f0fda08aSwikidesign
7f0fda08aSwikidesign// must be run within Dokuwiki
8f0fda08aSwikidesignif (!defined('DOKU_INC')) die();
9f0fda08aSwikidesign
10f0fda08aSwikidesignif (!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/');
11f0fda08aSwikidesignrequire_once(DOKU_PLUGIN.'action.php');
12f0fda08aSwikidesign
13f0fda08aSwikidesignif (!defined('NL')) define('NL',"\n");
14f0fda08aSwikidesign
15f0fda08aSwikidesignclass action_plugin_discussion extends DokuWiki_Action_Plugin{
16f0fda08aSwikidesign
17f0fda08aSwikidesign  /**
18f0fda08aSwikidesign   * Return some info
19f0fda08aSwikidesign   */
20f0fda08aSwikidesign  function getInfo(){
21f0fda08aSwikidesign    return array(
22f0fda08aSwikidesign      'author' => 'Esther Brunner',
23f0fda08aSwikidesign      'email'  => 'wikidesign@gmail.com',
240c7c2bf6Swikidesign      'date'   => '2006-11-27',
25f0fda08aSwikidesign      'name'   => 'Discussion Plugin',
26f0fda08aSwikidesign      'desc'   => 'Enables discussion features',
27decf3d57Swikidesign      'url'    => 'http://www.wikidesign.ch/en/plugin/discussion/start',
28f0fda08aSwikidesign    );
29f0fda08aSwikidesign  }
30f0fda08aSwikidesign
31f0fda08aSwikidesign  /**
32f0fda08aSwikidesign   * Register the eventhandlers
33f0fda08aSwikidesign   */
34f0fda08aSwikidesign  function register(&$contr){
35f0fda08aSwikidesign    $contr->register_hook(
36f0fda08aSwikidesign      'ACTION_ACT_PREPROCESS',
37f0fda08aSwikidesign      'BEFORE',
38f0fda08aSwikidesign      $this,
39f0fda08aSwikidesign      'handle_act_preprocess',
40f0fda08aSwikidesign      array()
41f0fda08aSwikidesign    );
42f0fda08aSwikidesign    $contr->register_hook(
43f0fda08aSwikidesign      'TPL_ACT_RENDER',
44f0fda08aSwikidesign      'AFTER',
45f0fda08aSwikidesign      $this,
46f0fda08aSwikidesign      'comments',
47f0fda08aSwikidesign      array()
48f0fda08aSwikidesign    );
49f0fda08aSwikidesign  }
50f0fda08aSwikidesign
51f0fda08aSwikidesign  /**
52f0fda08aSwikidesign   * Main function; dispatches the comment actions
53f0fda08aSwikidesign   */
54f0fda08aSwikidesign  function comments(&$event, $param){
55f0fda08aSwikidesign    if ($event->data != 'show') return; // nothing to do for us
56f0fda08aSwikidesign
57f0fda08aSwikidesign    $cid  = $_REQUEST['cid'];
58f0fda08aSwikidesign
59f0fda08aSwikidesign    switch ($_REQUEST['comment']){
60f0fda08aSwikidesign
61f0fda08aSwikidesign      case 'add':
62f0fda08aSwikidesign        $comment = array(
63f0fda08aSwikidesign          'user'    => $_REQUEST['user'],
64f0fda08aSwikidesign          'name'    => $_REQUEST['name'],
65f0fda08aSwikidesign          'mail'    => $_REQUEST['mail'],
66f0fda08aSwikidesign          'url'     => $_REQUEST['url'],
67f0fda08aSwikidesign          'address' => $_REQUEST['address'],
68f0fda08aSwikidesign          'date'    => $_REQUEST['date'],
69f0fda08aSwikidesign          'raw'     => cleanText($_REQUEST['text'])
70f0fda08aSwikidesign        );
71f0fda08aSwikidesign        $repl = $_REQUEST['reply'];
72f0fda08aSwikidesign        $this->_add($comment, $repl);
73f0fda08aSwikidesign        break;
74f0fda08aSwikidesign
75f0fda08aSwikidesign      case 'edit':
76f0fda08aSwikidesign        $this->_show(NULL, $cid);
77f0fda08aSwikidesign        break;
78f0fda08aSwikidesign
79f0fda08aSwikidesign      case 'save':
80f0fda08aSwikidesign        $raw  = cleanText($_REQUEST['text']);
81f0fda08aSwikidesign        $this->_save($cid, $raw);
82f0fda08aSwikidesign        break;
83f0fda08aSwikidesign
841e46d176Swikidesign      case 'delete':
851e46d176Swikidesign        $this->_save($cid, '');
862ee3dca3Swikidesign        break;
871e46d176Swikidesign
88f0fda08aSwikidesign      case 'toogle':
89f0fda08aSwikidesign        $this->_save($cid, '', true);
90f0fda08aSwikidesign        break;
91f0fda08aSwikidesign
92f0fda08aSwikidesign      default: // 'show' => $this->_show(), 'reply' => $this->_show($cid)
93f0fda08aSwikidesign        $this->_show($cid);
94f0fda08aSwikidesign    }
95f0fda08aSwikidesign  }
96f0fda08aSwikidesign
97f0fda08aSwikidesign  /**
98f0fda08aSwikidesign   * Shows all comments of the current page
99f0fda08aSwikidesign   */
100f0fda08aSwikidesign  function _show($reply = NULL, $edit = NULL){
101f0fda08aSwikidesign    global $ID;
102f0fda08aSwikidesign
103f0fda08aSwikidesign    // get discussion meta file name
104f0fda08aSwikidesign    $file = metaFN($ID, '.comments');
105f0fda08aSwikidesign
106f0fda08aSwikidesign    if (!file_exists($file)) return true;  // no comments at all
107f0fda08aSwikidesign
108f0fda08aSwikidesign    $data = unserialize(io_readFile($file, false));
109f0fda08aSwikidesign
110f0fda08aSwikidesign    if ($data['status'] == 0) return true; // comments are off
111f0fda08aSwikidesign
112f0fda08aSwikidesign    // section title
113f0fda08aSwikidesign    $title = $this->getLang('discussion');
114f0fda08aSwikidesign    $secid = cleanID($title);
115decf3d57Swikidesign    echo '<div class="comment_wrapper">';
116f0fda08aSwikidesign    echo '<h2><a name="'.$secid.'" id="'.$secid.'">'.$title.'</a></h2>';
117f0fda08aSwikidesign    echo '<div class="level2">';
118f0fda08aSwikidesign
119f0fda08aSwikidesign    // now display the comments
120f0fda08aSwikidesign    if (isset($data['comments'])){
121f0fda08aSwikidesign      foreach ($data['comments'] as $key => $value){
122f0fda08aSwikidesign        if ($key == $edit) $this->_form($value['raw'], 'save', $edit); // edit form
123f0fda08aSwikidesign        else $this->_print($key, $data, '', $reply);
124f0fda08aSwikidesign      }
125f0fda08aSwikidesign    }
126f0fda08aSwikidesign
127f0fda08aSwikidesign    // comment form
128f0fda08aSwikidesign    if (($data['status'] == 1) && !$reply && !$edit) $this->_form('');
129f0fda08aSwikidesign
130decf3d57Swikidesign    echo '</div>'; // level2
131decf3d57Swikidesign    echo '</div>'; // comment_wrapper
132f0fda08aSwikidesign
133f0fda08aSwikidesign    return true;
134f0fda08aSwikidesign  }
135f0fda08aSwikidesign
136f0fda08aSwikidesign  /**
137f0fda08aSwikidesign   * Adds a new comment and then displays all comments
138f0fda08aSwikidesign   */
139f0fda08aSwikidesign  function _add($comment, $parent){
140f0fda08aSwikidesign    global $ID;
141f0fda08aSwikidesign    global $TEXT;
142f0fda08aSwikidesign
143f0fda08aSwikidesign    $otxt = $TEXT; // set $TEXT to comment text for wordblock check
144f0fda08aSwikidesign    $TEXT = $comment['raw'];
145f0fda08aSwikidesign
146f0fda08aSwikidesign    // spamcheck against the DokuWiki blacklist
147f0fda08aSwikidesign    if (checkwordblock()){
148f0fda08aSwikidesign      msg($this->getLang('wordblock'), -1);
149f0fda08aSwikidesign      $this->_show();
150f0fda08aSwikidesign      return false;
151f0fda08aSwikidesign    }
152f0fda08aSwikidesign
153f0fda08aSwikidesign    $TEXT = $otxt; // restore global $TEXT
154f0fda08aSwikidesign
155f0fda08aSwikidesign    // get discussion meta file name
156f0fda08aSwikidesign    $file = metaFN($ID, '.comments');
157f0fda08aSwikidesign
158f0fda08aSwikidesign    $data = array();
159f0fda08aSwikidesign    $data = unserialize(io_readFile($file, false));
160f0fda08aSwikidesign
161f0fda08aSwikidesign    if ($data['status'] != 1) return false;                // comments off or closed
162f0fda08aSwikidesign    if ((!$this->getConf('allowguests'))
163f0fda08aSwikidesign      && ($comment['user'] != $_SERVER['REMOTE_USER']))
164f0fda08aSwikidesign      return false;                                        // guest comments not allowed
165f0fda08aSwikidesign
166f0fda08aSwikidesign    if ($comment['date']) $date = strtotime($comment['date']);
167f0fda08aSwikidesign    else $date = time();
168f0fda08aSwikidesign    if ($date == -1) $date = time();
169f0fda08aSwikidesign    $cid  = md5($comment['user'].$date);                   // create a unique id
170f0fda08aSwikidesign
171f0fda08aSwikidesign    if (!is_array($data['comments'][$parent])) $parent = NULL; // invalid parent comment
172f0fda08aSwikidesign
173f0fda08aSwikidesign    // render the comment
174f0fda08aSwikidesign    $xhtml = $this->_render($comment['raw']);
175f0fda08aSwikidesign
176f0fda08aSwikidesign    // fill in the new comment
177f0fda08aSwikidesign    $data['comments'][$cid] = array(
178f0fda08aSwikidesign      'user'    => htmlspecialchars($comment['user']),
179f0fda08aSwikidesign      'name'    => htmlspecialchars($comment['name']),
180f0fda08aSwikidesign      'mail'    => htmlspecialchars($comment['mail']),
181f0fda08aSwikidesign      'date'    => $date,
182f0fda08aSwikidesign      'show'    => true,
183f0fda08aSwikidesign      'raw'     => trim($comment['raw']),
184f0fda08aSwikidesign      'xhtml'   => $xhtml,
185f0fda08aSwikidesign      'parent'  => $parent,
186f0fda08aSwikidesign      'replies' => array()
187f0fda08aSwikidesign    );
188f0fda08aSwikidesign    if ($comment['url'])
189f0fda08aSwikidesign      $data['comments'][$cid]['url'] = htmlspecialchars($comment['url']);
190f0fda08aSwikidesign    if ($comment['address'])
191f0fda08aSwikidesign      $data['comments'][$cid]['address'] = htmlspecialchars($comment['address']);
192f0fda08aSwikidesign
193f0fda08aSwikidesign    // update parent comment
194f0fda08aSwikidesign    if ($parent) $data['comments'][$parent]['replies'][] = $cid;
195f0fda08aSwikidesign
196f0fda08aSwikidesign    // update the number of comments
197f0fda08aSwikidesign    $data['number']++;
198f0fda08aSwikidesign
199f0fda08aSwikidesign    // save the comment metadata file
200f0fda08aSwikidesign    io_saveFile($file, serialize($data));
201f0fda08aSwikidesign    $this->_addLogEntry($date, $ID, 'cc', '', $cid);
202f0fda08aSwikidesign
203f0fda08aSwikidesign    // notify subscribers of the page
204f0fda08aSwikidesign    $this->_notify($data['comments'][$cid]);
205f0fda08aSwikidesign
206f0fda08aSwikidesign    $this->_show();
207f0fda08aSwikidesign    return true;
208f0fda08aSwikidesign  }
209f0fda08aSwikidesign
210f0fda08aSwikidesign  /**
211f0fda08aSwikidesign   * Saves the comment with the given ID and then displays all comments
212f0fda08aSwikidesign   */
213f0fda08aSwikidesign  function _save($cid, $raw, $toogle = false){
214f0fda08aSwikidesign    global $ID;
215f0fda08aSwikidesign    global $INFO;
216f0fda08aSwikidesign
2172ee3dca3Swikidesign    if ($raw){
2182ee3dca3Swikidesign      global $TEXT;
2192ee3dca3Swikidesign
220f0fda08aSwikidesign      $otxt = $TEXT; // set $TEXT to comment text for wordblock check
221f0fda08aSwikidesign      $TEXT = $raw;
222f0fda08aSwikidesign
223f0fda08aSwikidesign      // spamcheck against the DokuWiki blacklist
224f0fda08aSwikidesign      if (checkwordblock()){
225f0fda08aSwikidesign        msg($this->getLang('wordblock'), -1);
226f0fda08aSwikidesign        $this->_show();
227f0fda08aSwikidesign        return false;
228f0fda08aSwikidesign      }
229f0fda08aSwikidesign
230f0fda08aSwikidesign      $TEXT = $otxt; // restore global $TEXT
2312ee3dca3Swikidesign    }
232f0fda08aSwikidesign
233f0fda08aSwikidesign    // get discussion meta file name
234f0fda08aSwikidesign    $file = metaFN($ID, '.comments');
235f0fda08aSwikidesign
236f0fda08aSwikidesign    $data = array();
237f0fda08aSwikidesign    $data = unserialize(io_readFile($file, false));
238f0fda08aSwikidesign
239f0fda08aSwikidesign    // someone else was trying to edit our comment -> abort
240f0fda08aSwikidesign    if (($data['comments'][$cid]['user'] != $_SERVER['REMOTE_USER'])
241f0fda08aSwikidesign      && ($INFO['perm'] != AUTH_ADMIN)) return false;
242f0fda08aSwikidesign
243f0fda08aSwikidesign    $date = time();
244f0fda08aSwikidesign
245f0fda08aSwikidesign    if ($toogle){     // toogle visibility
246f0fda08aSwikidesign      $now = $data['comments'][$cid]['show'];
247f0fda08aSwikidesign      $data['comments'][$cid]['show'] = !$now;
248f0fda08aSwikidesign      $data['number'] = $this->_count($data);
249f0fda08aSwikidesign
250f0fda08aSwikidesign      $type = ($data['comments'][$cid]['show'] ? 'sc' : 'hc');
251f0fda08aSwikidesign
252f0fda08aSwikidesign    } elseif (!$raw){ // remove the comment
253f0fda08aSwikidesign      unset($data['comments'][$cid]);
254f0fda08aSwikidesign      $data['number'] = $this->_count($data);
255f0fda08aSwikidesign
256f0fda08aSwikidesign      $type = 'dc';
257f0fda08aSwikidesign
258f0fda08aSwikidesign    } else {          // save changed comment
259f0fda08aSwikidesign      $xhtml = $this->_render($raw);
260f0fda08aSwikidesign
261f0fda08aSwikidesign      // now change the comment's content
262f0fda08aSwikidesign      $data['comments'][$cid]['edited'] = $date;
263f0fda08aSwikidesign      $data['comments'][$cid]['raw']    = trim($raw);
264f0fda08aSwikidesign      $data['comments'][$cid]['xhtml']  = $xhtml;
265f0fda08aSwikidesign
266f0fda08aSwikidesign      $type = 'ec';
267f0fda08aSwikidesign    }
268f0fda08aSwikidesign
269f0fda08aSwikidesign    // save the comment metadata file
270f0fda08aSwikidesign    io_saveFile($file, serialize($data));
271f0fda08aSwikidesign    $this->_addLogEntry($date, $ID, $type, '', $cid);
272f0fda08aSwikidesign
273f0fda08aSwikidesign    $this->_show();
274f0fda08aSwikidesign    return true;
275f0fda08aSwikidesign  }
276f0fda08aSwikidesign
277f0fda08aSwikidesign  /**
278f0fda08aSwikidesign   * Prints an individual comment
279f0fda08aSwikidesign   */
280f0fda08aSwikidesign  function _print($cid, &$data, $parent = '', $reply = '', $visible = true){
281f0fda08aSwikidesign    global $conf;
282f0fda08aSwikidesign    global $lang;
283f0fda08aSwikidesign    global $ID;
284f0fda08aSwikidesign    global $INFO;
285f0fda08aSwikidesign
2862ee3dca3Swikidesign    if (!isset($data['comments'][$cid])) return false; // comment was removed
287f0fda08aSwikidesign    $comment = $data['comments'][$cid];
288f0fda08aSwikidesign
289f0fda08aSwikidesign    if (!is_array($comment)) return false;          // corrupt datatype
290f0fda08aSwikidesign
291f0fda08aSwikidesign    if ($comment['parent'] != $parent) return true; // reply to an other comment
292f0fda08aSwikidesign
293f0fda08aSwikidesign    if (!$comment['show']){                         // comment hidden
294f0fda08aSwikidesign      if ($INFO['perm'] == AUTH_ADMIN) echo '<div class="comment_hidden">'.NL;
295f0fda08aSwikidesign      else return true;
296f0fda08aSwikidesign    }
297f0fda08aSwikidesign
298f0fda08aSwikidesign    // comment head with date and user data
299f0fda08aSwikidesign    echo '<div class="comment_head">'.NL;
300f0fda08aSwikidesign    echo '<a name="comment__'.$cid.'" id="comment__'.$cid.'">'.NL;
301f0fda08aSwikidesign
302f0fda08aSwikidesign    // show gravatar image
303f0fda08aSwikidesign    if ($this->getConf('usegravatar')){
304f0fda08aSwikidesign      $default = DOKU_URL.'lib/plugins/discussion/images/default.gif';
305f0fda08aSwikidesign      $size    = $this->getConf('gravatar_size');
306f0fda08aSwikidesign      if ($comment['mail']) $src = ml('http://www.gravatar.com/avatar.php?'.
307f0fda08aSwikidesign        'gravatar_id='.md5($comment['mail']).
308f0fda08aSwikidesign        '&default='.urlencode($default).
309f0fda08aSwikidesign        '&size='.$size.
3100c7c2bf6Swikidesign        '&rating='.$this->getConf('gravatar_rating').
3110c7c2bf6Swikidesign        '&.jpg', 'cache=recache');
312f0fda08aSwikidesign      else $src = $default;
313f0fda08aSwikidesign      $title = ($comment['name'] ? $comment['name'] : obfuscate($comment['mail']));
314f0fda08aSwikidesign      echo '<img src="'.$src.'" class="medialeft" title="'.$title.'"'.
315f0fda08aSwikidesign        ' alt="'.$title.'" width="'.$size.'" height="'.$size.'" />'.NL;
3165f87b5b6Swikidesign      $style = ' style="margin-left: '.($size + 14).'px;"';
3175f87b5b6Swikidesign    } else {
3185f87b5b6Swikidesign      $style = ' style="margin-left: 20px;"';
319f0fda08aSwikidesign    }
320f0fda08aSwikidesign
321f0fda08aSwikidesign    echo '</a>'.NL;
322f0fda08aSwikidesign    if ($this->getConf('linkemail') && $comment['mail']){
323f0fda08aSwikidesign      echo $this->email($comment['email'], $comment['name']);
324f0fda08aSwikidesign    } elseif ($comment['url']){
325f0fda08aSwikidesign      echo $this->external_link($comment['url'], $comment['name'], 'urlextern');
326f0fda08aSwikidesign    } else {
327f0fda08aSwikidesign      echo $comment['name'];
328f0fda08aSwikidesign    }
329f0fda08aSwikidesign    if ($comment['address']) echo ', '.htmlentities($comment['address']);
330f0fda08aSwikidesign    echo ', '.date($conf['dformat'], $comment['date']);
331f0fda08aSwikidesign    if ($comment['edited']) echo ' ('.date($conf['dformat'], $comment['edited']).')';
332f0fda08aSwikidesign    echo ':'.NL;
333f0fda08aSwikidesign    echo '</div>'.NL; // class="comment_head"
334f0fda08aSwikidesign
335f0fda08aSwikidesign    // main comment content
3365f87b5b6Swikidesign    echo '<div class="comment_body"'.($this->getConf('usegravatar') ? $style : '').'>'.NL;
337f0fda08aSwikidesign    echo $comment['xhtml'].NL;
338f0fda08aSwikidesign    echo '</div>'.NL; // class="comment_body"
339f0fda08aSwikidesign
340f0fda08aSwikidesign
341f0fda08aSwikidesign    if ($visible){
342f0fda08aSwikidesign      // show hide/show toogle button?
343f0fda08aSwikidesign      echo '<div class="comment_buttons">'.NL;
344f0fda08aSwikidesign      if ($INFO['perm'] == AUTH_ADMIN){
345f0fda08aSwikidesign        if (!$comment['show']) $label = $this->getLang('btn_show');
346f0fda08aSwikidesign        else $label = $this->getLang('btn_hide');
347f0fda08aSwikidesign
348f0fda08aSwikidesign        $this->_button($cid, $label, 'toogle');
349f0fda08aSwikidesign      }
350f0fda08aSwikidesign
351f0fda08aSwikidesign      // show reply button?
352f1c4aa1aSwikidesign      if (($data['status'] == 1) && !$reply && $comment['show']
353f1c4aa1aSwikidesign        && ($this->getConf('allowguests') || $_SERVER['REMOTE_USER']))
3541e46d176Swikidesign        $this->_button($cid, $this->getLang('btn_reply'), 'reply', true);
355f0fda08aSwikidesign
3561e46d176Swikidesign      // show edit and delete button?
357f0fda08aSwikidesign      if ((($comment['user'] == $_SERVER['REMOTE_USER']) && ($comment['user'] != ''))
358f0fda08aSwikidesign        || ($INFO['perm'] == AUTH_ADMIN))
3591e46d176Swikidesign        $this->_button($cid, $lang['btn_secedit'], 'edit', true);
3601e46d176Swikidesign      if ($INFO['perm'] == AUTH_ADMIN)
3611e46d176Swikidesign        $this->_button($cid, $lang['btn_delete'], 'delete');
362f0fda08aSwikidesign      echo '</div>'.NL; // class="comment_buttons"
363decf3d57Swikidesign      echo '<div class="comment_line" '.($this->getConf('usegravatar') ? $style : '').'>&nbsp;</div>'.NL;
364f0fda08aSwikidesign    }
365f0fda08aSwikidesign
366f0fda08aSwikidesign    // replies to this comment entry?
367f0fda08aSwikidesign    if (count($comment['replies'])){
3685f87b5b6Swikidesign      echo '<div class="comment_replies"'.$style.'>'.NL;
369f0fda08aSwikidesign      $visible = ($comment['show'] && $visible);
370f0fda08aSwikidesign      foreach ($comment['replies'] as $rid){
371f0fda08aSwikidesign        $this->_print($rid, $data, $cid, $reply, $visible);
372f0fda08aSwikidesign      }
373f0fda08aSwikidesign      echo '</div>'.NL; // class="comment_replies"
374f0fda08aSwikidesign    }
375f0fda08aSwikidesign
376f0fda08aSwikidesign    if (!$comment['show']) echo '</div>'.NL; // class="comment_hidden"
377f0fda08aSwikidesign
378f0fda08aSwikidesign    // reply form
379f0fda08aSwikidesign    if ($reply == $cid){
380f0fda08aSwikidesign      echo '<div class="comment_replies">'.NL;
381f0fda08aSwikidesign      $this->_form('', 'add', $cid);
382f0fda08aSwikidesign      echo '</div>'.NL; // class="comment_replies"
383f0fda08aSwikidesign    }
384f0fda08aSwikidesign  }
385f0fda08aSwikidesign
386f0fda08aSwikidesign  /**
387f0fda08aSwikidesign   * Outputs the comment form
388f0fda08aSwikidesign   */
389f0fda08aSwikidesign  function _form($raw = '', $act = 'add', $cid = NULL){
390f0fda08aSwikidesign    global $lang;
391f0fda08aSwikidesign    global $conf;
392f0fda08aSwikidesign    global $ID;
393f0fda08aSwikidesign    global $INFO;
394f0fda08aSwikidesign
395f0fda08aSwikidesign    // not for unregistered users when guest comments aren't allowed
396f0fda08aSwikidesign    if (!$_SERVER['REMOTE_USER'] && !$this->getConf('allowguests')) return false;
397f0fda08aSwikidesign
398e7c760b3Swikidesign    // fill $raw with $_REQUEST['text'] if it's empty
399e7c760b3Swikidesign    if (!$raw) $raw = hsc($_REQUEST['text']);
400e7c760b3Swikidesign
401f0fda08aSwikidesign    ?>
402f0fda08aSwikidesign    <div class="comment_form">
403f0fda08aSwikidesign      <form id="discussion__comment_form" method="post" action="<?php echo script() ?>" accept-charset="<?php echo $lang['encoding'] ?>" onsubmit="return validate(this);">
404f0fda08aSwikidesign        <div class="no">
405f0fda08aSwikidesign          <input type="hidden" name="id" value="<?php echo $ID ?>" />
406f0fda08aSwikidesign          <input type="hidden" name="do" value="show" />
407f0fda08aSwikidesign          <input type="hidden" name="comment" value="<?php echo $act ?>" />
408f0fda08aSwikidesign    <?php
409f0fda08aSwikidesign
410f0fda08aSwikidesign    // for adding a comment
411f0fda08aSwikidesign    if ($act == 'add'){
412f0fda08aSwikidesign      ?>
413f0fda08aSwikidesign          <input type="hidden" name="reply" value="<?php echo $cid ?>" />
414f0fda08aSwikidesign      <?php
415f0fda08aSwikidesign      // for registered user
416f0fda08aSwikidesign      if ($conf['useacl'] && $_SERVER['REMOTE_USER']){
417f0fda08aSwikidesign      ?>
418f0fda08aSwikidesign          <input type="hidden" name="user" value="<?php echo $_SERVER['REMOTE_USER'] ?>" />
419f0fda08aSwikidesign          <input type="hidden" name="name" value="<?php echo $INFO['userinfo']['name'] ?>" />
420f0fda08aSwikidesign          <input type="hidden" name="mail" value="<?php echo $INFO['userinfo']['mail'] ?>" />
421f0fda08aSwikidesign      <?php
422f0fda08aSwikidesign      // for guest: show name and e-mail entry fields
423f0fda08aSwikidesign      } else {
424f0fda08aSwikidesign      ?>
425f0fda08aSwikidesign          <input type="hidden" name="user" value="<?php echo clientIP() ?>" />
426f0fda08aSwikidesign          <div class="comment_name">
427f0fda08aSwikidesign            <label class="block" for="discussion__comment_name">
428f0fda08aSwikidesign              <span><?php echo $lang['fullname'] ?>:</span>
429e7c760b3Swikidesign              <input type="text" class="edit" name="name" id="discussion__comment_name" size="50" tabindex="1" value="<?php echo hsc($_REQUEST['name'])?>" />
430f0fda08aSwikidesign            </label>
431f0fda08aSwikidesign          </div>
432f0fda08aSwikidesign          <div class="comment_mail">
433f0fda08aSwikidesign            <label class="block" for="discussion__comment_mail">
434f0fda08aSwikidesign              <span><?php echo $lang['email'] ?>:</span>
435e7c760b3Swikidesign              <input type="text" class="edit" name="mail" id="discussion__comment_mail" size="50" tabindex="2" value="<?php echo hsc($_REQUEST['email'])?>" />
436f0fda08aSwikidesign            </label>
437f0fda08aSwikidesign          </div>
438f0fda08aSwikidesign      <?php
439f0fda08aSwikidesign      }
440f0fda08aSwikidesign
441f0fda08aSwikidesign      // allow entering an URL
442f0fda08aSwikidesign      if ($this->getConf('urlfield')){
443f0fda08aSwikidesign      ?>
444f0fda08aSwikidesign          <div class="comment_url">
445f0fda08aSwikidesign            <label class="block" for="discussion__comment_url">
446f0fda08aSwikidesign              <span><?php echo $this->getLang('url') ?>:</span>
447e7c760b3Swikidesign              <input type="text" class="edit" name="url" id="discussion__comment_url" size="50" tabindex="3" value="<?php echo hsc($_REQUEST['url'])?>" />
448f0fda08aSwikidesign            </label>
449f0fda08aSwikidesign          </div>
450f0fda08aSwikidesign      <?php
451f0fda08aSwikidesign      }
452f0fda08aSwikidesign
453f0fda08aSwikidesign      // allow entering an address
454f0fda08aSwikidesign      if ($this->getConf('addressfield')){
455f0fda08aSwikidesign      ?>
456f0fda08aSwikidesign          <div class="comment_address">
457f0fda08aSwikidesign            <label class="block" for="discussion__comment_address">
458f0fda08aSwikidesign              <span><?php echo $this->getLang('address') ?>:</span>
459e7c760b3Swikidesign              <input type="text" class="edit" name="address" id="discussion__comment_address" size="50" tabindex="4" value="<?php echo hsc($_REQUEST['address'])?>" />
460f0fda08aSwikidesign            </label>
461f0fda08aSwikidesign          </div>
462f0fda08aSwikidesign      <?php
463f0fda08aSwikidesign      }
464f0fda08aSwikidesign
465f0fda08aSwikidesign      // allow setting the comment date
466f0fda08aSwikidesign      if ($this->getConf('datefield') && ($INFO['perm'] == AUTH_ADMIN)){
467f0fda08aSwikidesign      ?>
468f0fda08aSwikidesign          <div class="comment_date">
469f0fda08aSwikidesign            <label class="block" for="discussion__comment_date">
470f0fda08aSwikidesign              <span><?php echo $this->getLang('date') ?>:</span>
471f0fda08aSwikidesign              <input type="text" class="edit" name="date" id="discussion__comment_date" size="50" />
472f0fda08aSwikidesign            </label>
473f0fda08aSwikidesign          </div>
474f0fda08aSwikidesign      <?php
475f0fda08aSwikidesign      }
476f0fda08aSwikidesign
477f0fda08aSwikidesign    // for saving a comment
478f0fda08aSwikidesign    } else {
479f0fda08aSwikidesign    ?>
480f0fda08aSwikidesign          <input type="hidden" name="cid" value="<?php echo $cid ?>" />
481f0fda08aSwikidesign    <?php
482f0fda08aSwikidesign    }
483f0fda08aSwikidesign    ?>
484f0fda08aSwikidesign          <div class="comment_text">
485f0fda08aSwikidesign            <textarea class="edit" name="text" cols="80" rows="10" id="discussion__comment_text" tabindex="5"><?php echo $raw ?></textarea>
486f0fda08aSwikidesign          </div>
487e7c760b3Swikidesign    <?php //bad and dirty event insert hook
488e7c760b3Swikidesign    $evdata = array('writable' => true);
489e7c760b3Swikidesign    trigger_event('HTML_EDITFORM_INJECTION', $evdata);
490e7c760b3Swikidesign    ?>
491f0fda08aSwikidesign          <input class="button" type="submit" name="submit" value="<?php echo $lang['btn_save'] ?>" tabindex="6" />
492f0fda08aSwikidesign        </div>
493f0fda08aSwikidesign      </form>
494f0fda08aSwikidesign    </div>
495f0fda08aSwikidesign    <?php
496f0fda08aSwikidesign    if ($this->getConf('usecocomment')) echo $this->_coComment();
497f0fda08aSwikidesign  }
498f0fda08aSwikidesign
499f0fda08aSwikidesign  /**
500f0fda08aSwikidesign   * Adds a javascript to interact with coComments
501f0fda08aSwikidesign   */
502f0fda08aSwikidesign  function _coComment(){
503f0fda08aSwikidesign    global $ID;
504f0fda08aSwikidesign    global $conf;
505f0fda08aSwikidesign    global $INFO;
506f0fda08aSwikidesign
507f0fda08aSwikidesign    $user = $_SERVER['REMOTE_USER'];
508f0fda08aSwikidesign
509f0fda08aSwikidesign    ?>
510f0fda08aSwikidesign    <script type="text/javascript"><!--//--><![CDATA[//><!--
511f0fda08aSwikidesign      var blogTool  = "DokuWiki";
512f0fda08aSwikidesign      var blogURL   = "<?php echo DOKU_URL ?>";
513f0fda08aSwikidesign      var blogTitle = "<?php echo $conf['title'] ?>";
514f0fda08aSwikidesign      var postURL   = "<?php echo wl($ID, '', true) ?>";
515f0fda08aSwikidesign      var postTitle = "<?php echo tpl_pagetitle($ID, true) ?>";
516f0fda08aSwikidesign    <?php
517f0fda08aSwikidesign    if ($user){
518f0fda08aSwikidesign    ?>
519f0fda08aSwikidesign      var commentAuthor = "<?php echo $INFO['userinfo']['name'] ?>";
520f0fda08aSwikidesign    <?php
521f0fda08aSwikidesign    } else {
522f0fda08aSwikidesign    ?>
523f0fda08aSwikidesign      var commentAuthorFieldName = "name";
524f0fda08aSwikidesign    <?php
525f0fda08aSwikidesign    }
526f0fda08aSwikidesign    ?>
527f0fda08aSwikidesign      var commentAuthorLoggedIn = <?php echo ($user ? 'true' : 'false') ?>;
528f0fda08aSwikidesign      var commentFormID         = "discussion__comment_form";
529f0fda08aSwikidesign      var commentTextFieldName  = "text";
530f0fda08aSwikidesign      var commentButtonName     = "submit";
531f0fda08aSwikidesign      var cocomment_force       = false;
532f0fda08aSwikidesign    //--><!]]></script>
533f0fda08aSwikidesign    <script type="text/javascript" src="http://www.cocomment.com/js/cocomment.js">
534f0fda08aSwikidesign    </script>
535f0fda08aSwikidesign    <?php
536f0fda08aSwikidesign  }
537f0fda08aSwikidesign
538f0fda08aSwikidesign  /**
539f0fda08aSwikidesign   * General button function
540f0fda08aSwikidesign   */
5411e46d176Swikidesign  function _button($cid, $label, $act, $jump = false){
542f0fda08aSwikidesign    global $ID;
5431e46d176Swikidesign    $anchor = ($jump ? '#discussion__comment_form' : '' );
544f0fda08aSwikidesign
545f0fda08aSwikidesign    ?>
5461e46d176Swikidesign    <form class="button" method="post" action="<?php echo script().$anchor ?>">
547f0fda08aSwikidesign      <div class="no">
548f0fda08aSwikidesign        <input type="hidden" name="id" value="<?php echo $ID ?>" />
549f0fda08aSwikidesign        <input type="hidden" name="do" value="show" />
550f0fda08aSwikidesign        <input type="hidden" name="comment" value="<?php echo $act ?>" />
551f0fda08aSwikidesign        <input type="hidden" name="cid" value="<?php echo $cid ?>" />
552f0fda08aSwikidesign        <input type="submit" value="<?php echo $label ?>" class="button" title="<?php echo $label ?>" />
553f0fda08aSwikidesign      </div>
554f0fda08aSwikidesign    </form>
555f0fda08aSwikidesign    <?php
556f0fda08aSwikidesign    return true;
557f0fda08aSwikidesign  }
558f0fda08aSwikidesign
559f0fda08aSwikidesign  /**
560f0fda08aSwikidesign   * Adds an entry to the comments changelog
561f0fda08aSwikidesign   *
562f0fda08aSwikidesign   * @author Esther Brunner <wikidesign@gmail.com>
563f0fda08aSwikidesign   * @author Ben Coburn <btcoburn@silicodon.net>
564f0fda08aSwikidesign   */
565f0fda08aSwikidesign  function _addLogEntry($date, $id, $type = 'cc', $summary = '', $extra = ''){
566f0fda08aSwikidesign    global $conf;
567f0fda08aSwikidesign
568f0fda08aSwikidesign    $changelog = $conf['metadir'].'/_comments.changes';
569f0fda08aSwikidesign
570f0fda08aSwikidesign    if(!$date) $date = time(); //use current time if none supplied
571f0fda08aSwikidesign    $remote = $_SERVER['REMOTE_ADDR'];
572f0fda08aSwikidesign    $user   = $_SERVER['REMOTE_USER'];
573f0fda08aSwikidesign
574f0fda08aSwikidesign    $strip = array("\t", "\n");
575f0fda08aSwikidesign    $logline = array(
576f0fda08aSwikidesign      'date'  => $date,
577f0fda08aSwikidesign      'ip'    => $remote,
578f0fda08aSwikidesign      'type'  => str_replace($strip, '', $type),
579f0fda08aSwikidesign      'id'    => $id,
580f0fda08aSwikidesign      'user'  => $user,
581f0fda08aSwikidesign      'sum'   => str_replace($strip, '', $summary),
582f0fda08aSwikidesign      'extra' => str_replace($strip, '', $extra)
583f0fda08aSwikidesign    );
584f0fda08aSwikidesign
585f0fda08aSwikidesign    // add changelog line
586f0fda08aSwikidesign    $logline = implode("\t", $logline)."\n";
587f0fda08aSwikidesign    io_saveFile($changelog, $logline, true); //global changelog cache
588f0fda08aSwikidesign    $this->_trimRecentCommentsLog($changelog);
589f0fda08aSwikidesign  }
590f0fda08aSwikidesign
591f0fda08aSwikidesign  /**
592f0fda08aSwikidesign   * Trims the recent comments cache to the last $conf['changes_days'] recent
593f0fda08aSwikidesign   * changes or $conf['recent'] items, which ever is larger.
594f0fda08aSwikidesign   * The trimming is only done once a day.
595f0fda08aSwikidesign   *
596f0fda08aSwikidesign   * @author Ben Coburn <btcoburn@silicodon.net>
597f0fda08aSwikidesign   */
598f0fda08aSwikidesign  function _trimRecentCommentsLog($changelog){
599f0fda08aSwikidesign    global $conf;
600f0fda08aSwikidesign
601f0fda08aSwikidesign    if (@file_exists($changelog) &&
602f0fda08aSwikidesign      (filectime($changelog) + 86400) < time() &&
603f0fda08aSwikidesign      !@file_exists($changelog.'_tmp')){
604f0fda08aSwikidesign
605f0fda08aSwikidesign      io_lock($changelog);
606f0fda08aSwikidesign      $lines = file($changelog);
607f0fda08aSwikidesign      if (count($lines)<$conf['recent']) {
608f0fda08aSwikidesign          // nothing to trim
609f0fda08aSwikidesign          io_unlock($changelog);
610f0fda08aSwikidesign          return true;
611f0fda08aSwikidesign      }
612f0fda08aSwikidesign
613f0fda08aSwikidesign      io_saveFile($changelog.'_tmp', '');                  // presave tmp as 2nd lock
614f0fda08aSwikidesign      $trim_time = time() - $conf['recent_days']*86400;
615f0fda08aSwikidesign      $out_lines = array();
616f0fda08aSwikidesign
617f0fda08aSwikidesign      for ($i=0; $i<count($lines); $i++) {
618f0fda08aSwikidesign        $log = parseChangelogLine($lines[$i]);
619f0fda08aSwikidesign        if ($log === false) continue;                      // discard junk
620f0fda08aSwikidesign        if ($log['date'] < $trim_time) {
621f0fda08aSwikidesign          $old_lines[$log['date'].".$i"] = $lines[$i];     // keep old lines for now (append .$i to prevent key collisions)
622f0fda08aSwikidesign        } else {
623f0fda08aSwikidesign          $out_lines[$log['date'].".$i"] = $lines[$i];     // definitely keep these lines
624f0fda08aSwikidesign        }
625f0fda08aSwikidesign      }
626f0fda08aSwikidesign
627f0fda08aSwikidesign      // sort the final result, it shouldn't be necessary,
628f0fda08aSwikidesign      // however the extra robustness in making the changelog cache self-correcting is worth it
629f0fda08aSwikidesign      ksort($out_lines);
630f0fda08aSwikidesign      $extra = $conf['recent'] - count($out_lines);        // do we need extra lines do bring us up to minimum
631f0fda08aSwikidesign      if ($extra > 0) {
632f0fda08aSwikidesign        ksort($old_lines);
633f0fda08aSwikidesign        $out_lines = array_merge(array_slice($old_lines,-$extra),$out_lines);
634f0fda08aSwikidesign      }
635f0fda08aSwikidesign
636f0fda08aSwikidesign      // save trimmed changelog
637f0fda08aSwikidesign      io_saveFile($changelog.'_tmp', implode('', $out_lines));
638f0fda08aSwikidesign      @unlink($changelog);
639f0fda08aSwikidesign      if (!rename($changelog.'_tmp', $changelog)) {
640f0fda08aSwikidesign        // rename failed so try another way...
641f0fda08aSwikidesign        io_unlock($changelog);
642f0fda08aSwikidesign        io_saveFile($changelog, implode('', $out_lines));
643f0fda08aSwikidesign        @unlink($changelog.'_tmp');
644f0fda08aSwikidesign      } else {
645f0fda08aSwikidesign        io_unlock($changelog);
646f0fda08aSwikidesign      }
647f0fda08aSwikidesign      return true;
648f0fda08aSwikidesign    }
649f0fda08aSwikidesign  }
650f0fda08aSwikidesign
651f0fda08aSwikidesign  /**
652f0fda08aSwikidesign   * Sends a notify mail on new comment
653f0fda08aSwikidesign   *
654f0fda08aSwikidesign   * @param  array  $comment  data array of the new comment
655f0fda08aSwikidesign   *
656f0fda08aSwikidesign   * @author Andreas Gohr <andi@splitbrain.org>
657f0fda08aSwikidesign   * @author Esther Brunner <wikidesign@gmail.com>
658f0fda08aSwikidesign   */
659f0fda08aSwikidesign  function _notify($comment){
660f0fda08aSwikidesign    global $conf;
661f0fda08aSwikidesign    global $ID;
662f0fda08aSwikidesign
663cc0c9acdSwikidesign    if ((!$conf['subscribers']) && (!$conf['notify'])) return; //subscribers enabled?
664f0fda08aSwikidesign    $bcc  = subscriber_addresslist($ID);
665cc0c9acdSwikidesign    if ((empty($bcc)) && (!$conf['notify'])) return;
666cc0c9acdSwikidesign    $to   = $conf['notify'];
667f0fda08aSwikidesign    $text = io_readFile($this->localFN('subscribermail'));
668f0fda08aSwikidesign
669f0fda08aSwikidesign    $text = str_replace('@PAGE@', $ID, $text);
670f0fda08aSwikidesign    $text = str_replace('@TITLE@', $conf['title'], $text);
671f0fda08aSwikidesign    $text = str_replace('@DATE@', date($conf['dformat'], $comment['date']), $text);
672f0fda08aSwikidesign    $text = str_replace('@NAME@', $comment['name'], $text);
673f0fda08aSwikidesign    $text = str_replace('@TEXT@', $comment['raw'], $text);
674f0fda08aSwikidesign    $text = str_replace('@UNSUBSCRIBE@', wl($ID, 'do=unsubscribe', true, '&'), $text);
675f0fda08aSwikidesign    $text = str_replace('@DOKUWIKIURL@', DOKU_URL, $text);
676f0fda08aSwikidesign
677f0fda08aSwikidesign    $subject = '['.$conf['title'].'] '.$this->getLang('mail_newcomment');
678f0fda08aSwikidesign
679f0fda08aSwikidesign    mail_send($to, $subject, $text, $conf['mailfrom'], '', $bcc);
680f0fda08aSwikidesign  }
681f0fda08aSwikidesign
682f0fda08aSwikidesign  /**
683f0fda08aSwikidesign   * Counts the number of visible comments
684f0fda08aSwikidesign   */
685f0fda08aSwikidesign  function _count($data){
686f0fda08aSwikidesign    $number = 0;
687f0fda08aSwikidesign    foreach ($data['comments'] as $cid => $comment){
688f0fda08aSwikidesign      if ($comment['parent']) continue;
689f0fda08aSwikidesign      if (!$comment['show']) continue;
690f0fda08aSwikidesign      $number++;
691f0fda08aSwikidesign      $rids = $comment['replies'];
692f0fda08aSwikidesign      if (count($rids)) $number = $number + $this->_countReplies($data, $rids);
693f0fda08aSwikidesign    }
694f0fda08aSwikidesign    return $number;
695f0fda08aSwikidesign  }
696f0fda08aSwikidesign
697f0fda08aSwikidesign  function _countReplies(&$data, $rids){
698f0fda08aSwikidesign    $number = 0;
699f0fda08aSwikidesign    foreach ($rids as $rid){
7002ee3dca3Swikidesign      if (!isset($data['comments'][$rid])) continue; // reply was removed
701f0fda08aSwikidesign      if (!$data['comments'][$rid]['show']) continue;
702f0fda08aSwikidesign      $number++;
703f0fda08aSwikidesign      $rids = $data['comments'][$rid]['replies'];
704f0fda08aSwikidesign      if (count($rids)) $number = $number + $this->_countReplies($data, $rids);
705f0fda08aSwikidesign    }
706f0fda08aSwikidesign    return $number;
707f0fda08aSwikidesign  }
708f0fda08aSwikidesign
709f0fda08aSwikidesign  /**
710f0fda08aSwikidesign   * Renders the comment text
711f0fda08aSwikidesign   */
712f0fda08aSwikidesign  function _render($raw){
713f0fda08aSwikidesign    if ($this->getConf('wikisyntaxok')){
714f0fda08aSwikidesign      $xhtml = $this->render($raw);
715f0fda08aSwikidesign    } else { // wiki syntax not allowed -> just encode special chars
716f0fda08aSwikidesign      $xhtml = htmlspecialchars(trim($raw));
717f0fda08aSwikidesign    }
718f0fda08aSwikidesign    return $xhtml;
719f0fda08aSwikidesign  }
720f0fda08aSwikidesign
721f0fda08aSwikidesign  /**
722e7c760b3Swikidesign   * Checks if 'newthread' was given as action or the comment form was submitted
723f0fda08aSwikidesign   */
724f0fda08aSwikidesign  function handle_act_preprocess(&$event, $param){
725e7c760b3Swikidesign    if ($event->data == 'newthread'){
726*2e80cd5fSwikidesign      // we can handle it -> prevent others
727*2e80cd5fSwikidesign      // $event->stopPropagation();
728*2e80cd5fSwikidesign      $event->preventDefault();
729*2e80cd5fSwikidesign
730*2e80cd5fSwikidesign      $event->data = $this->_handle_newThread();
731e7c760b3Swikidesign    }
732e7c760b3Swikidesign    if ((in_array($_REQUEST['comment'], array('add', 'save')))
733e7c760b3Swikidesign      && (@file_exists(DOKU_PLUGIN.'captcha/action.php'))){
734e7c760b3Swikidesign      $this->_handle_captchaCheck();
735e7c760b3Swikidesign    }
736e7c760b3Swikidesign  }
737f0fda08aSwikidesign
738e7c760b3Swikidesign  /**
739e7c760b3Swikidesign   * Creates a new thread page
740e7c760b3Swikidesign   */
741*2e80cd5fSwikidesign  function _handle_newThread(){
742f0fda08aSwikidesign    global $ID;
743*2e80cd5fSwikidesign    global $INFO;
744f0fda08aSwikidesign
745f0fda08aSwikidesign    $ns    = $_REQUEST['ns'];
746f0fda08aSwikidesign    $title = str_replace(':', '', $_REQUEST['title']);
747*2e80cd5fSwikidesign    $back  = $ID;
748*2e80cd5fSwikidesign    $ID    = ($ns ? $ns.':' : '').cleanID($title);
749*2e80cd5fSwikidesign    $INFO  = pageinfo();
750f0fda08aSwikidesign
751f0fda08aSwikidesign    // check if we are allowed to create this file
752*2e80cd5fSwikidesign    if ($INFO['perm'] >= AUTH_CREATE){
753f0fda08aSwikidesign
754f0fda08aSwikidesign      //check if locked by anyone - if not lock for my self
755*2e80cd5fSwikidesign      if ($INFO['locked']) return 'locked';
756*2e80cd5fSwikidesign      else lock($ID);
757f0fda08aSwikidesign
758f0fda08aSwikidesign      // prepare the new thread file with default stuff
759*2e80cd5fSwikidesign      if (!@file_exists($INFO['filepath'])){
760f0fda08aSwikidesign        global $TEXT;
761f0fda08aSwikidesign        global $conf;
762f0fda08aSwikidesign
763*2e80cd5fSwikidesign        $TEXT = pageTemplate(array(($ns ? $ns.':' : '').$title));
7641433886fSwikidesign        if (!$TEXT){
7651433886fSwikidesign          $TEXT = "<- [[:$back]]\n\n====== $title ======\n\n";
7661433886fSwikidesign          if ($this->getConf('usegravatar'))
7671433886fSwikidesign            $TEXT .= '{{gravatar>'.$INFO['userinfo']['mail'].' }} ';
7681433886fSwikidesign          $TEXT .= "//".$INFO['userinfo']['name'].", ".date($conf['dformat']).": //".
7691433886fSwikidesign                   "\n\n\n\n~~DISCUSSION~~\n";
770*2e80cd5fSwikidesign        }
771*2e80cd5fSwikidesign        return 'preview';
772f0fda08aSwikidesign      } else {
773*2e80cd5fSwikidesign        return 'edit';
774f0fda08aSwikidesign      }
775f0fda08aSwikidesign    } else {
776*2e80cd5fSwikidesign      return 'show';
777f0fda08aSwikidesign    }
778f0fda08aSwikidesign  }
779f0fda08aSwikidesign
780e7c760b3Swikidesign  /**
781e7c760b3Swikidesign   * Checks if the CAPTCHA string submitted is valid
782e7c760b3Swikidesign   *
783e7c760b3Swikidesign   * @author     Andreas Gohr <gohr@cosmocode.de>
784e7c760b3Swikidesign   * @adaption   Esther Brunner <wikidesign@gmail.com>
785e7c760b3Swikidesign   */
786e7c760b3Swikidesign  function _handle_captchaCheck(){
787e7c760b3Swikidesign    if (@file_exists(DOKU_PLUGIN.'captcha/disabled')) return; // CAPTCHA is disabled
788e7c760b3Swikidesign
789e7c760b3Swikidesign    require_once(DOKU_PLUGIN.'captcha/action.php');
790e7c760b3Swikidesign    $captcha = new action_plugin_captcha;
791e7c760b3Swikidesign
792e7c760b3Swikidesign    // compare provided string with decrypted captcha
793e7c760b3Swikidesign    $rand = PMA_blowfish_decrypt($_REQUEST['plugin__captcha_secret'], auth_cookiesalt());
794e7c760b3Swikidesign    $code = $captcha->_generateCAPTCHA($captcha->_fixedIdent(), $rand);
795e7c760b3Swikidesign
796e7c760b3Swikidesign    if (!$_REQUEST['plugin__captcha_secret'] ||
797e7c760b3Swikidesign      !$_REQUEST['plugin__captcha'] ||
798e7c760b3Swikidesign      strtoupper($_REQUEST['plugin__captcha']) != $code){
799e7c760b3Swikidesign
800e7c760b3Swikidesign      // CAPTCHA test failed! Continue to edit instead of saving
801e7c760b3Swikidesign      msg($captcha->getLang('testfailed'),-1);
802e7c760b3Swikidesign      if ($_REQUEST['comment'] == 'save') $_REQUEST['comment'] = 'edit';
803e7c760b3Swikidesign      elseif ($_REQUEST['comment'] == 'add') $_REQUEST['comment'] = 'show';
804e7c760b3Swikidesign    }
805e7c760b3Swikidesign    // if we arrive here it was a valid save
806e7c760b3Swikidesign  }
807e7c760b3Swikidesign
808f0fda08aSwikidesign}
809f0fda08aSwikidesign
810f0fda08aSwikidesign//Setup VIM: ex: et ts=4 enc=utf-8 :
811