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', 24*830f19a9Swikidesign 'date' => '2007-01-05', 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 ); 49479dd10fSwikidesign $contr->register_hook( 50479dd10fSwikidesign 'RENDERER_CONTENT_POSTPROCESS', 51479dd10fSwikidesign 'AFTER', 52479dd10fSwikidesign $this, 53479dd10fSwikidesign 'add_toc_item', 54479dd10fSwikidesign array() 55479dd10fSwikidesign ); 56f0fda08aSwikidesign } 57f0fda08aSwikidesign 58f0fda08aSwikidesign /** 59f0fda08aSwikidesign * Main function; dispatches the comment actions 60f0fda08aSwikidesign */ 61f0fda08aSwikidesign function comments(&$event, $param){ 62f0fda08aSwikidesign if ($event->data != 'show') return; // nothing to do for us 63f0fda08aSwikidesign 64f0fda08aSwikidesign $cid = $_REQUEST['cid']; 65f0fda08aSwikidesign 66f0fda08aSwikidesign switch ($_REQUEST['comment']){ 67f0fda08aSwikidesign 68f0fda08aSwikidesign case 'add': 69f0fda08aSwikidesign $comment = array( 70f0fda08aSwikidesign 'user' => $_REQUEST['user'], 71f0fda08aSwikidesign 'name' => $_REQUEST['name'], 72f0fda08aSwikidesign 'mail' => $_REQUEST['mail'], 73f0fda08aSwikidesign 'url' => $_REQUEST['url'], 74f0fda08aSwikidesign 'address' => $_REQUEST['address'], 75f0fda08aSwikidesign 'date' => $_REQUEST['date'], 76f0fda08aSwikidesign 'raw' => cleanText($_REQUEST['text']) 77f0fda08aSwikidesign ); 78f0fda08aSwikidesign $repl = $_REQUEST['reply']; 79f0fda08aSwikidesign $this->_add($comment, $repl); 80f0fda08aSwikidesign break; 81f0fda08aSwikidesign 82f0fda08aSwikidesign case 'edit': 83f0fda08aSwikidesign $this->_show(NULL, $cid); 84f0fda08aSwikidesign break; 85f0fda08aSwikidesign 86f0fda08aSwikidesign case 'save': 87f0fda08aSwikidesign $raw = cleanText($_REQUEST['text']); 88f0fda08aSwikidesign $this->_save($cid, $raw); 89f0fda08aSwikidesign break; 90f0fda08aSwikidesign 911e46d176Swikidesign case 'delete': 921e46d176Swikidesign $this->_save($cid, ''); 932ee3dca3Swikidesign break; 941e46d176Swikidesign 95f0fda08aSwikidesign case 'toogle': 96f0fda08aSwikidesign $this->_save($cid, '', true); 97f0fda08aSwikidesign break; 98f0fda08aSwikidesign 99f0fda08aSwikidesign default: // 'show' => $this->_show(), 'reply' => $this->_show($cid) 100f0fda08aSwikidesign $this->_show($cid); 101f0fda08aSwikidesign } 102f0fda08aSwikidesign } 103f0fda08aSwikidesign 104f0fda08aSwikidesign /** 105f0fda08aSwikidesign * Shows all comments of the current page 106f0fda08aSwikidesign */ 107f0fda08aSwikidesign function _show($reply = NULL, $edit = NULL){ 1087fec4787Swikidesign global $ID, $INFO; 109f0fda08aSwikidesign 110479dd10fSwikidesign // get .comments meta file name 111f0fda08aSwikidesign $file = metaFN($ID, '.comments'); 112f0fda08aSwikidesign 113479dd10fSwikidesign if (!@file_exists($file)){ 114479dd10fSwikidesign // create .comments meta file if automatic setting is switched on 1157fec4787Swikidesign if ($this->getConf('automatic') && $INFO['exists']){ 116479dd10fSwikidesign $data = array('status' => 1, 'number' => 0); 117479dd10fSwikidesign io_saveFile($file, serialize($data)); 118479dd10fSwikidesign } 119479dd10fSwikidesign } else { // load data 120f0fda08aSwikidesign $data = unserialize(io_readFile($file, false)); 121479dd10fSwikidesign } 122f0fda08aSwikidesign 123479dd10fSwikidesign if (!$data['status']) return false; // comments are turned off 124f0fda08aSwikidesign 125f0fda08aSwikidesign // section title 126f0fda08aSwikidesign $title = $this->getLang('discussion'); 127decf3d57Swikidesign echo '<div class="comment_wrapper">'; 128479dd10fSwikidesign echo '<h2><a name="discussion__section" id="discussion__section">'.$title.'</a></h2>'; 129*830f19a9Swikidesign echo '<div class="level2 hfeed">'; 130f0fda08aSwikidesign 131f0fda08aSwikidesign // now display the comments 132f0fda08aSwikidesign if (isset($data['comments'])){ 133f0fda08aSwikidesign foreach ($data['comments'] as $key => $value){ 134f0fda08aSwikidesign if ($key == $edit) $this->_form($value['raw'], 'save', $edit); // edit form 135f0fda08aSwikidesign else $this->_print($key, $data, '', $reply); 136f0fda08aSwikidesign } 137f0fda08aSwikidesign } 138f0fda08aSwikidesign 139f0fda08aSwikidesign // comment form 140f0fda08aSwikidesign if (($data['status'] == 1) && !$reply && !$edit) $this->_form(''); 141f0fda08aSwikidesign 142decf3d57Swikidesign echo '</div>'; // level2 143decf3d57Swikidesign echo '</div>'; // comment_wrapper 144f0fda08aSwikidesign 145f0fda08aSwikidesign return true; 146f0fda08aSwikidesign } 147f0fda08aSwikidesign 148f0fda08aSwikidesign /** 149f0fda08aSwikidesign * Adds a new comment and then displays all comments 150f0fda08aSwikidesign */ 151f0fda08aSwikidesign function _add($comment, $parent){ 152f0fda08aSwikidesign global $ID; 153f0fda08aSwikidesign global $TEXT; 154f0fda08aSwikidesign 155f0fda08aSwikidesign $otxt = $TEXT; // set $TEXT to comment text for wordblock check 156f0fda08aSwikidesign $TEXT = $comment['raw']; 157f0fda08aSwikidesign 158f0fda08aSwikidesign // spamcheck against the DokuWiki blacklist 159f0fda08aSwikidesign if (checkwordblock()){ 160f0fda08aSwikidesign msg($this->getLang('wordblock'), -1); 161f0fda08aSwikidesign $this->_show(); 162f0fda08aSwikidesign return false; 163f0fda08aSwikidesign } 164f0fda08aSwikidesign 165f0fda08aSwikidesign $TEXT = $otxt; // restore global $TEXT 166f0fda08aSwikidesign 167f0fda08aSwikidesign // get discussion meta file name 168f0fda08aSwikidesign $file = metaFN($ID, '.comments'); 169f0fda08aSwikidesign 170f0fda08aSwikidesign $data = array(); 171f0fda08aSwikidesign $data = unserialize(io_readFile($file, false)); 172f0fda08aSwikidesign 173f0fda08aSwikidesign if ($data['status'] != 1) return false; // comments off or closed 174f0fda08aSwikidesign if ((!$this->getConf('allowguests')) 175f0fda08aSwikidesign && ($comment['user'] != $_SERVER['REMOTE_USER'])) 176f0fda08aSwikidesign return false; // guest comments not allowed 177f0fda08aSwikidesign 178f0fda08aSwikidesign if ($comment['date']) $date = strtotime($comment['date']); 179f0fda08aSwikidesign else $date = time(); 180f0fda08aSwikidesign if ($date == -1) $date = time(); 181f0fda08aSwikidesign $cid = md5($comment['user'].$date); // create a unique id 182f0fda08aSwikidesign 183f0fda08aSwikidesign if (!is_array($data['comments'][$parent])) $parent = NULL; // invalid parent comment 184f0fda08aSwikidesign 185f0fda08aSwikidesign // render the comment 186f0fda08aSwikidesign $xhtml = $this->_render($comment['raw']); 187f0fda08aSwikidesign 188f0fda08aSwikidesign // fill in the new comment 189f0fda08aSwikidesign $data['comments'][$cid] = array( 190*830f19a9Swikidesign 'user' => hsc($comment['user']), 191*830f19a9Swikidesign 'name' => hsc($comment['name']), 192*830f19a9Swikidesign 'mail' => hsc($comment['mail']), 193f0fda08aSwikidesign 'date' => $date, 194f0fda08aSwikidesign 'show' => true, 195f0fda08aSwikidesign 'raw' => trim($comment['raw']), 196f0fda08aSwikidesign 'xhtml' => $xhtml, 197f0fda08aSwikidesign 'parent' => $parent, 198f0fda08aSwikidesign 'replies' => array() 199f0fda08aSwikidesign ); 200f0fda08aSwikidesign if ($comment['url']) 201*830f19a9Swikidesign $data['comments'][$cid]['url'] = hsc($comment['url']); 202f0fda08aSwikidesign if ($comment['address']) 203*830f19a9Swikidesign $data['comments'][$cid]['address'] = hsc($comment['address']); 204f0fda08aSwikidesign 205f0fda08aSwikidesign // update parent comment 206f0fda08aSwikidesign if ($parent) $data['comments'][$parent]['replies'][] = $cid; 207f0fda08aSwikidesign 208f0fda08aSwikidesign // update the number of comments 209f0fda08aSwikidesign $data['number']++; 210f0fda08aSwikidesign 211f0fda08aSwikidesign // save the comment metadata file 212f0fda08aSwikidesign io_saveFile($file, serialize($data)); 213f0fda08aSwikidesign $this->_addLogEntry($date, $ID, 'cc', '', $cid); 214f0fda08aSwikidesign 215f0fda08aSwikidesign // notify subscribers of the page 216f0fda08aSwikidesign $this->_notify($data['comments'][$cid]); 217f0fda08aSwikidesign 218f0fda08aSwikidesign $this->_show(); 219f0fda08aSwikidesign return true; 220f0fda08aSwikidesign } 221f0fda08aSwikidesign 222f0fda08aSwikidesign /** 223f0fda08aSwikidesign * Saves the comment with the given ID and then displays all comments 224f0fda08aSwikidesign */ 225f0fda08aSwikidesign function _save($cid, $raw, $toogle = false){ 226f0fda08aSwikidesign global $ID; 227f0fda08aSwikidesign global $INFO; 228f0fda08aSwikidesign 2292ee3dca3Swikidesign if ($raw){ 2302ee3dca3Swikidesign global $TEXT; 2312ee3dca3Swikidesign 232f0fda08aSwikidesign $otxt = $TEXT; // set $TEXT to comment text for wordblock check 233f0fda08aSwikidesign $TEXT = $raw; 234f0fda08aSwikidesign 235f0fda08aSwikidesign // spamcheck against the DokuWiki blacklist 236f0fda08aSwikidesign if (checkwordblock()){ 237f0fda08aSwikidesign msg($this->getLang('wordblock'), -1); 238f0fda08aSwikidesign $this->_show(); 239f0fda08aSwikidesign return false; 240f0fda08aSwikidesign } 241f0fda08aSwikidesign 242f0fda08aSwikidesign $TEXT = $otxt; // restore global $TEXT 2432ee3dca3Swikidesign } 244f0fda08aSwikidesign 245f0fda08aSwikidesign // get discussion meta file name 246f0fda08aSwikidesign $file = metaFN($ID, '.comments'); 247f0fda08aSwikidesign 248f0fda08aSwikidesign $data = array(); 249f0fda08aSwikidesign $data = unserialize(io_readFile($file, false)); 250f0fda08aSwikidesign 251f0fda08aSwikidesign // someone else was trying to edit our comment -> abort 252f0fda08aSwikidesign if (($data['comments'][$cid]['user'] != $_SERVER['REMOTE_USER']) 253f0fda08aSwikidesign && ($INFO['perm'] != AUTH_ADMIN)) return false; 254f0fda08aSwikidesign 255f0fda08aSwikidesign $date = time(); 256f0fda08aSwikidesign 257f0fda08aSwikidesign if ($toogle){ // toogle visibility 258f0fda08aSwikidesign $now = $data['comments'][$cid]['show']; 259f0fda08aSwikidesign $data['comments'][$cid]['show'] = !$now; 260f0fda08aSwikidesign $data['number'] = $this->_count($data); 261f0fda08aSwikidesign 262f0fda08aSwikidesign $type = ($data['comments'][$cid]['show'] ? 'sc' : 'hc'); 263f0fda08aSwikidesign 264f0fda08aSwikidesign } elseif (!$raw){ // remove the comment 265f0fda08aSwikidesign unset($data['comments'][$cid]); 266f0fda08aSwikidesign $data['number'] = $this->_count($data); 267f0fda08aSwikidesign 268f0fda08aSwikidesign $type = 'dc'; 269f0fda08aSwikidesign 270f0fda08aSwikidesign } else { // save changed comment 271f0fda08aSwikidesign $xhtml = $this->_render($raw); 272f0fda08aSwikidesign 273f0fda08aSwikidesign // now change the comment's content 274f0fda08aSwikidesign $data['comments'][$cid]['edited'] = $date; 275f0fda08aSwikidesign $data['comments'][$cid]['raw'] = trim($raw); 276f0fda08aSwikidesign $data['comments'][$cid]['xhtml'] = $xhtml; 277f0fda08aSwikidesign 278f0fda08aSwikidesign $type = 'ec'; 279f0fda08aSwikidesign } 280f0fda08aSwikidesign 281f0fda08aSwikidesign // save the comment metadata file 282f0fda08aSwikidesign io_saveFile($file, serialize($data)); 283f0fda08aSwikidesign $this->_addLogEntry($date, $ID, $type, '', $cid); 284f0fda08aSwikidesign 285f0fda08aSwikidesign $this->_show(); 286f0fda08aSwikidesign return true; 287f0fda08aSwikidesign } 288f0fda08aSwikidesign 289f0fda08aSwikidesign /** 290f0fda08aSwikidesign * Prints an individual comment 291f0fda08aSwikidesign */ 292f0fda08aSwikidesign function _print($cid, &$data, $parent = '', $reply = '', $visible = true){ 293f0fda08aSwikidesign global $conf; 294f0fda08aSwikidesign global $lang; 295f0fda08aSwikidesign global $ID; 296f0fda08aSwikidesign global $INFO; 297f0fda08aSwikidesign 2982ee3dca3Swikidesign if (!isset($data['comments'][$cid])) return false; // comment was removed 299f0fda08aSwikidesign $comment = $data['comments'][$cid]; 300f0fda08aSwikidesign 301f0fda08aSwikidesign if (!is_array($comment)) return false; // corrupt datatype 302f0fda08aSwikidesign 303f0fda08aSwikidesign if ($comment['parent'] != $parent) return true; // reply to an other comment 304f0fda08aSwikidesign 305f0fda08aSwikidesign if (!$comment['show']){ // comment hidden 306f0fda08aSwikidesign if ($INFO['perm'] == AUTH_ADMIN) echo '<div class="comment_hidden">'.NL; 307f0fda08aSwikidesign else return true; 308f0fda08aSwikidesign } 309f0fda08aSwikidesign 310f0fda08aSwikidesign // comment head with date and user data 311*830f19a9Swikidesign echo '<div class="hentry"><div class="comment_head">'.NL. 312*830f19a9Swikidesign '<a name="comment__'.$cid.'" id="comment__'.$cid.'"></a>'.NL. 313*830f19a9Swikidesign '<span class="vcard author">'; 314f0fda08aSwikidesign 315f0fda08aSwikidesign // show gravatar image 316f0fda08aSwikidesign if ($this->getConf('usegravatar')){ 317f0fda08aSwikidesign $default = DOKU_URL.'lib/plugins/discussion/images/default.gif'; 318f0fda08aSwikidesign $size = $this->getConf('gravatar_size'); 319f0fda08aSwikidesign if ($comment['mail']) $src = ml('http://www.gravatar.com/avatar.php?'. 320f0fda08aSwikidesign 'gravatar_id='.md5($comment['mail']). 321f0fda08aSwikidesign '&default='.urlencode($default). 322f0fda08aSwikidesign '&size='.$size. 3230c7c2bf6Swikidesign '&rating='.$this->getConf('gravatar_rating'). 3240c7c2bf6Swikidesign '&.jpg', 'cache=recache'); 325f0fda08aSwikidesign else $src = $default; 326f0fda08aSwikidesign $title = ($comment['name'] ? $comment['name'] : obfuscate($comment['mail'])); 327*830f19a9Swikidesign echo '<img src="'.$src.'" class="medialeft photo" title="'.$title.'"'. 328f0fda08aSwikidesign ' alt="'.$title.'" width="'.$size.'" height="'.$size.'" />'.NL; 3295f87b5b6Swikidesign $style = ' style="margin-left: '.($size + 14).'px;"'; 3305f87b5b6Swikidesign } else { 3315f87b5b6Swikidesign $style = ' style="margin-left: 20px;"'; 332f0fda08aSwikidesign } 333f0fda08aSwikidesign 334f0fda08aSwikidesign if ($this->getConf('linkemail') && $comment['mail']){ 335*830f19a9Swikidesign echo $this->email($comment['email'], $comment['name'], 'email fn'); 336f0fda08aSwikidesign } elseif ($comment['url']){ 337*830f19a9Swikidesign echo $this->external_link($comment['url'], $comment['name'], 'urlextern url fn'); 338f0fda08aSwikidesign } else { 339*830f19a9Swikidesign echo '<span class="fn">'.$comment['name'].'</span>'; 340f0fda08aSwikidesign } 341*830f19a9Swikidesign if ($comment['address']) 342*830f19a9Swikidesign echo ', <span class="adr">'.$comment['address'].'</span>'; 343*830f19a9Swikidesign echo '</span>, <abbr class="published" title="'.gmdate('Y-m-d\TH:i:s\Z', 344*830f19a9Swikidesign $comment['date']).'">'.date($conf['dformat'], $comment['date']).'</abbr>'; 345*830f19a9Swikidesign if ($comment['edited']) echo ' (<abbr class="updated" title="'. 346*830f19a9Swikidesign gmdate('Y-m-d\TH:i:s\Z', $comment['edited']).'">'.date($conf['dformat'], 347*830f19a9Swikidesign $comment['edited']).'</abbr>)'; 348*830f19a9Swikidesign echo ':'.NL. 349*830f19a9Swikidesign '</div>'.NL; // class="comment_head" 350f0fda08aSwikidesign 351f0fda08aSwikidesign // main comment content 352*830f19a9Swikidesign echo '<div class="comment_body entry-content"'. 353*830f19a9Swikidesign ($this->getConf('usegravatar') ? $style : '').'>'.NL. 354*830f19a9Swikidesign $comment['xhtml'].NL. 355*830f19a9Swikidesign '</div>'.NL. 356*830f19a9Swikidesign '</div>'.NL; // class="comment_body" and class="hentry" 357f0fda08aSwikidesign 358f0fda08aSwikidesign 359f0fda08aSwikidesign if ($visible){ 360f0fda08aSwikidesign // show hide/show toogle button? 361f0fda08aSwikidesign echo '<div class="comment_buttons">'.NL; 362f0fda08aSwikidesign if ($INFO['perm'] == AUTH_ADMIN){ 363f0fda08aSwikidesign if (!$comment['show']) $label = $this->getLang('btn_show'); 364f0fda08aSwikidesign else $label = $this->getLang('btn_hide'); 365f0fda08aSwikidesign 366f0fda08aSwikidesign $this->_button($cid, $label, 'toogle'); 367f0fda08aSwikidesign } 368f0fda08aSwikidesign 369f0fda08aSwikidesign // show reply button? 370f1c4aa1aSwikidesign if (($data['status'] == 1) && !$reply && $comment['show'] 371f1c4aa1aSwikidesign && ($this->getConf('allowguests') || $_SERVER['REMOTE_USER'])) 3721e46d176Swikidesign $this->_button($cid, $this->getLang('btn_reply'), 'reply', true); 373f0fda08aSwikidesign 3741e46d176Swikidesign // show edit and delete button? 375f0fda08aSwikidesign if ((($comment['user'] == $_SERVER['REMOTE_USER']) && ($comment['user'] != '')) 376f0fda08aSwikidesign || ($INFO['perm'] == AUTH_ADMIN)) 3771e46d176Swikidesign $this->_button($cid, $lang['btn_secedit'], 'edit', true); 3781e46d176Swikidesign if ($INFO['perm'] == AUTH_ADMIN) 3791e46d176Swikidesign $this->_button($cid, $lang['btn_delete'], 'delete'); 380f0fda08aSwikidesign echo '</div>'.NL; // class="comment_buttons" 381decf3d57Swikidesign echo '<div class="comment_line" '.($this->getConf('usegravatar') ? $style : '').'> </div>'.NL; 382f0fda08aSwikidesign } 383f0fda08aSwikidesign 384f0fda08aSwikidesign // replies to this comment entry? 385f0fda08aSwikidesign if (count($comment['replies'])){ 3865f87b5b6Swikidesign echo '<div class="comment_replies"'.$style.'>'.NL; 387f0fda08aSwikidesign $visible = ($comment['show'] && $visible); 388f0fda08aSwikidesign foreach ($comment['replies'] as $rid){ 389f0fda08aSwikidesign $this->_print($rid, $data, $cid, $reply, $visible); 390f0fda08aSwikidesign } 391f0fda08aSwikidesign echo '</div>'.NL; // class="comment_replies" 392f0fda08aSwikidesign } 393f0fda08aSwikidesign 394f0fda08aSwikidesign if (!$comment['show']) echo '</div>'.NL; // class="comment_hidden" 395f0fda08aSwikidesign 396f0fda08aSwikidesign // reply form 397f0fda08aSwikidesign if ($reply == $cid){ 398f0fda08aSwikidesign echo '<div class="comment_replies">'.NL; 399f0fda08aSwikidesign $this->_form('', 'add', $cid); 400f0fda08aSwikidesign echo '</div>'.NL; // class="comment_replies" 401f0fda08aSwikidesign } 402f0fda08aSwikidesign } 403f0fda08aSwikidesign 404f0fda08aSwikidesign /** 405f0fda08aSwikidesign * Outputs the comment form 406f0fda08aSwikidesign */ 407f0fda08aSwikidesign function _form($raw = '', $act = 'add', $cid = NULL){ 408f0fda08aSwikidesign global $lang; 409f0fda08aSwikidesign global $conf; 410f0fda08aSwikidesign global $ID; 411f0fda08aSwikidesign global $INFO; 412f0fda08aSwikidesign 413f0fda08aSwikidesign // not for unregistered users when guest comments aren't allowed 414f0fda08aSwikidesign if (!$_SERVER['REMOTE_USER'] && !$this->getConf('allowguests')) return false; 415f0fda08aSwikidesign 4161ba72c23Swikidesign // fill $raw with $_REQUEST['text'] if it's empty (for failed CAPTCHA check) 4171ba72c23Swikidesign if (!$raw && ($_REQUEST['comment'] == 'show')) $raw = $_REQUEST['text']; 418e7c760b3Swikidesign 419f0fda08aSwikidesign ?> 420f0fda08aSwikidesign <div class="comment_form"> 421f0fda08aSwikidesign <form id="discussion__comment_form" method="post" action="<?php echo script() ?>" accept-charset="<?php echo $lang['encoding'] ?>" onsubmit="return validate(this);"> 422f0fda08aSwikidesign <div class="no"> 423f0fda08aSwikidesign <input type="hidden" name="id" value="<?php echo $ID ?>" /> 424f0fda08aSwikidesign <input type="hidden" name="do" value="show" /> 425f0fda08aSwikidesign <input type="hidden" name="comment" value="<?php echo $act ?>" /> 426f0fda08aSwikidesign <?php 427f0fda08aSwikidesign 428f0fda08aSwikidesign // for adding a comment 429f0fda08aSwikidesign if ($act == 'add'){ 430f0fda08aSwikidesign ?> 431f0fda08aSwikidesign <input type="hidden" name="reply" value="<?php echo $cid ?>" /> 432f0fda08aSwikidesign <?php 4331ba72c23Swikidesign // for registered user (and we're not in admin import mode) 4341ba72c23Swikidesign if ($conf['useacl'] && $_SERVER['REMOTE_USER'] 4351ba72c23Swikidesign && (!($this->getConf('adminimport') && ($INFO['perm'] == AUTH_ADMIN)))){ 436f0fda08aSwikidesign ?> 43765cdad39Swikidesign <input type="hidden" name="user" value="<?php echo hsc($_SERVER['REMOTE_USER']) ?>" /> 43865cdad39Swikidesign <input type="hidden" name="name" value="<?php echo hsc($INFO['userinfo']['name']) ?>" /> 43965cdad39Swikidesign <input type="hidden" name="mail" value="<?php echo hsc($INFO['userinfo']['mail']) ?>" /> 440f0fda08aSwikidesign <?php 441f0fda08aSwikidesign // for guest: show name and e-mail entry fields 442f0fda08aSwikidesign } else { 443f0fda08aSwikidesign ?> 444f0fda08aSwikidesign <input type="hidden" name="user" value="<?php echo clientIP() ?>" /> 445f0fda08aSwikidesign <div class="comment_name"> 446f0fda08aSwikidesign <label class="block" for="discussion__comment_name"> 447f0fda08aSwikidesign <span><?php echo $lang['fullname'] ?>:</span> 448e7c760b3Swikidesign <input type="text" class="edit" name="name" id="discussion__comment_name" size="50" tabindex="1" value="<?php echo hsc($_REQUEST['name'])?>" /> 449f0fda08aSwikidesign </label> 450f0fda08aSwikidesign </div> 451f0fda08aSwikidesign <div class="comment_mail"> 452f0fda08aSwikidesign <label class="block" for="discussion__comment_mail"> 453f0fda08aSwikidesign <span><?php echo $lang['email'] ?>:</span> 4541ba72c23Swikidesign <input type="text" class="edit" name="mail" id="discussion__comment_mail" size="50" tabindex="2" value="<?php echo hsc($_REQUEST['mail'])?>" /> 455f0fda08aSwikidesign </label> 456f0fda08aSwikidesign </div> 457f0fda08aSwikidesign <?php 458f0fda08aSwikidesign } 459f0fda08aSwikidesign 460f0fda08aSwikidesign // allow entering an URL 461f0fda08aSwikidesign if ($this->getConf('urlfield')){ 462f0fda08aSwikidesign ?> 463f0fda08aSwikidesign <div class="comment_url"> 464f0fda08aSwikidesign <label class="block" for="discussion__comment_url"> 465f0fda08aSwikidesign <span><?php echo $this->getLang('url') ?>:</span> 466e7c760b3Swikidesign <input type="text" class="edit" name="url" id="discussion__comment_url" size="50" tabindex="3" value="<?php echo hsc($_REQUEST['url'])?>" /> 467f0fda08aSwikidesign </label> 468f0fda08aSwikidesign </div> 469f0fda08aSwikidesign <?php 470f0fda08aSwikidesign } 471f0fda08aSwikidesign 472f0fda08aSwikidesign // allow entering an address 473f0fda08aSwikidesign if ($this->getConf('addressfield')){ 474f0fda08aSwikidesign ?> 475f0fda08aSwikidesign <div class="comment_address"> 476f0fda08aSwikidesign <label class="block" for="discussion__comment_address"> 477f0fda08aSwikidesign <span><?php echo $this->getLang('address') ?>:</span> 478e7c760b3Swikidesign <input type="text" class="edit" name="address" id="discussion__comment_address" size="50" tabindex="4" value="<?php echo hsc($_REQUEST['address'])?>" /> 479f0fda08aSwikidesign </label> 480f0fda08aSwikidesign </div> 481f0fda08aSwikidesign <?php 482f0fda08aSwikidesign } 483f0fda08aSwikidesign 484f0fda08aSwikidesign // allow setting the comment date 4851ba72c23Swikidesign if ($this->getConf('adminimport') && ($INFO['perm'] == AUTH_ADMIN)){ 486f0fda08aSwikidesign ?> 487f0fda08aSwikidesign <div class="comment_date"> 488f0fda08aSwikidesign <label class="block" for="discussion__comment_date"> 489f0fda08aSwikidesign <span><?php echo $this->getLang('date') ?>:</span> 490f0fda08aSwikidesign <input type="text" class="edit" name="date" id="discussion__comment_date" size="50" /> 491f0fda08aSwikidesign </label> 492f0fda08aSwikidesign </div> 493f0fda08aSwikidesign <?php 494f0fda08aSwikidesign } 495f0fda08aSwikidesign 496f0fda08aSwikidesign // for saving a comment 497f0fda08aSwikidesign } else { 498f0fda08aSwikidesign ?> 499f0fda08aSwikidesign <input type="hidden" name="cid" value="<?php echo $cid ?>" /> 500f0fda08aSwikidesign <?php 501f0fda08aSwikidesign } 502f0fda08aSwikidesign ?> 503f0fda08aSwikidesign <div class="comment_text"> 50465cdad39Swikidesign <textarea class="edit" name="text" cols="80" rows="10" id="discussion__comment_text" tabindex="5"><?php echo formText($raw) ?></textarea> 505f0fda08aSwikidesign </div> 506e7c760b3Swikidesign <?php //bad and dirty event insert hook 507e7c760b3Swikidesign $evdata = array('writable' => true); 508e7c760b3Swikidesign trigger_event('HTML_EDITFORM_INJECTION', $evdata); 509e7c760b3Swikidesign ?> 510f0fda08aSwikidesign <input class="button" type="submit" name="submit" value="<?php echo $lang['btn_save'] ?>" tabindex="6" /> 511f0fda08aSwikidesign </div> 512f0fda08aSwikidesign </form> 513f0fda08aSwikidesign </div> 514f0fda08aSwikidesign <?php 515f0fda08aSwikidesign if ($this->getConf('usecocomment')) echo $this->_coComment(); 516f0fda08aSwikidesign } 517f0fda08aSwikidesign 518f0fda08aSwikidesign /** 519f0fda08aSwikidesign * Adds a javascript to interact with coComments 520f0fda08aSwikidesign */ 521f0fda08aSwikidesign function _coComment(){ 522f0fda08aSwikidesign global $ID; 523f0fda08aSwikidesign global $conf; 524f0fda08aSwikidesign global $INFO; 525f0fda08aSwikidesign 526f0fda08aSwikidesign $user = $_SERVER['REMOTE_USER']; 527f0fda08aSwikidesign 528f0fda08aSwikidesign ?> 529f0fda08aSwikidesign <script type="text/javascript"><!--//--><![CDATA[//><!-- 530f0fda08aSwikidesign var blogTool = "DokuWiki"; 531f0fda08aSwikidesign var blogURL = "<?php echo DOKU_URL ?>"; 532f0fda08aSwikidesign var blogTitle = "<?php echo $conf['title'] ?>"; 533f0fda08aSwikidesign var postURL = "<?php echo wl($ID, '', true) ?>"; 534f0fda08aSwikidesign var postTitle = "<?php echo tpl_pagetitle($ID, true) ?>"; 535f0fda08aSwikidesign <?php 536f0fda08aSwikidesign if ($user){ 537f0fda08aSwikidesign ?> 538f0fda08aSwikidesign var commentAuthor = "<?php echo $INFO['userinfo']['name'] ?>"; 539f0fda08aSwikidesign <?php 540f0fda08aSwikidesign } else { 541f0fda08aSwikidesign ?> 542f0fda08aSwikidesign var commentAuthorFieldName = "name"; 543f0fda08aSwikidesign <?php 544f0fda08aSwikidesign } 545f0fda08aSwikidesign ?> 546f0fda08aSwikidesign var commentAuthorLoggedIn = <?php echo ($user ? 'true' : 'false') ?>; 547f0fda08aSwikidesign var commentFormID = "discussion__comment_form"; 548f0fda08aSwikidesign var commentTextFieldName = "text"; 549f0fda08aSwikidesign var commentButtonName = "submit"; 550f0fda08aSwikidesign var cocomment_force = false; 551f0fda08aSwikidesign //--><!]]></script> 552f0fda08aSwikidesign <script type="text/javascript" src="http://www.cocomment.com/js/cocomment.js"> 553f0fda08aSwikidesign </script> 554f0fda08aSwikidesign <?php 555f0fda08aSwikidesign } 556f0fda08aSwikidesign 557f0fda08aSwikidesign /** 558f0fda08aSwikidesign * General button function 559f0fda08aSwikidesign */ 5601e46d176Swikidesign function _button($cid, $label, $act, $jump = false){ 561f0fda08aSwikidesign global $ID; 5621e46d176Swikidesign $anchor = ($jump ? '#discussion__comment_form' : '' ); 563f0fda08aSwikidesign 564f0fda08aSwikidesign ?> 5651e46d176Swikidesign <form class="button" method="post" action="<?php echo script().$anchor ?>"> 566f0fda08aSwikidesign <div class="no"> 567f0fda08aSwikidesign <input type="hidden" name="id" value="<?php echo $ID ?>" /> 568f0fda08aSwikidesign <input type="hidden" name="do" value="show" /> 569f0fda08aSwikidesign <input type="hidden" name="comment" value="<?php echo $act ?>" /> 570f0fda08aSwikidesign <input type="hidden" name="cid" value="<?php echo $cid ?>" /> 571f0fda08aSwikidesign <input type="submit" value="<?php echo $label ?>" class="button" title="<?php echo $label ?>" /> 572f0fda08aSwikidesign </div> 573f0fda08aSwikidesign </form> 574f0fda08aSwikidesign <?php 575f0fda08aSwikidesign return true; 576f0fda08aSwikidesign } 577f0fda08aSwikidesign 578f0fda08aSwikidesign /** 579f0fda08aSwikidesign * Adds an entry to the comments changelog 580f0fda08aSwikidesign * 581f0fda08aSwikidesign * @author Esther Brunner <wikidesign@gmail.com> 582f0fda08aSwikidesign * @author Ben Coburn <btcoburn@silicodon.net> 583f0fda08aSwikidesign */ 584f0fda08aSwikidesign function _addLogEntry($date, $id, $type = 'cc', $summary = '', $extra = ''){ 585f0fda08aSwikidesign global $conf; 586f0fda08aSwikidesign 587f0fda08aSwikidesign $changelog = $conf['metadir'].'/_comments.changes'; 588f0fda08aSwikidesign 589f0fda08aSwikidesign if(!$date) $date = time(); //use current time if none supplied 590f0fda08aSwikidesign $remote = $_SERVER['REMOTE_ADDR']; 591f0fda08aSwikidesign $user = $_SERVER['REMOTE_USER']; 592f0fda08aSwikidesign 593f0fda08aSwikidesign $strip = array("\t", "\n"); 594f0fda08aSwikidesign $logline = array( 595f0fda08aSwikidesign 'date' => $date, 596f0fda08aSwikidesign 'ip' => $remote, 597f0fda08aSwikidesign 'type' => str_replace($strip, '', $type), 598f0fda08aSwikidesign 'id' => $id, 599f0fda08aSwikidesign 'user' => $user, 600f0fda08aSwikidesign 'sum' => str_replace($strip, '', $summary), 601f0fda08aSwikidesign 'extra' => str_replace($strip, '', $extra) 602f0fda08aSwikidesign ); 603f0fda08aSwikidesign 604f0fda08aSwikidesign // add changelog line 605f0fda08aSwikidesign $logline = implode("\t", $logline)."\n"; 606f0fda08aSwikidesign io_saveFile($changelog, $logline, true); //global changelog cache 607f0fda08aSwikidesign $this->_trimRecentCommentsLog($changelog); 608f0fda08aSwikidesign } 609f0fda08aSwikidesign 610f0fda08aSwikidesign /** 611f0fda08aSwikidesign * Trims the recent comments cache to the last $conf['changes_days'] recent 612f0fda08aSwikidesign * changes or $conf['recent'] items, which ever is larger. 613f0fda08aSwikidesign * The trimming is only done once a day. 614f0fda08aSwikidesign * 615f0fda08aSwikidesign * @author Ben Coburn <btcoburn@silicodon.net> 616f0fda08aSwikidesign */ 617f0fda08aSwikidesign function _trimRecentCommentsLog($changelog){ 618f0fda08aSwikidesign global $conf; 619f0fda08aSwikidesign 620f0fda08aSwikidesign if (@file_exists($changelog) && 621f0fda08aSwikidesign (filectime($changelog) + 86400) < time() && 622f0fda08aSwikidesign !@file_exists($changelog.'_tmp')){ 623f0fda08aSwikidesign 624f0fda08aSwikidesign io_lock($changelog); 625f0fda08aSwikidesign $lines = file($changelog); 626f0fda08aSwikidesign if (count($lines)<$conf['recent']) { 627f0fda08aSwikidesign // nothing to trim 628f0fda08aSwikidesign io_unlock($changelog); 629f0fda08aSwikidesign return true; 630f0fda08aSwikidesign } 631f0fda08aSwikidesign 632f0fda08aSwikidesign io_saveFile($changelog.'_tmp', ''); // presave tmp as 2nd lock 633f0fda08aSwikidesign $trim_time = time() - $conf['recent_days']*86400; 634f0fda08aSwikidesign $out_lines = array(); 635f0fda08aSwikidesign 636f0fda08aSwikidesign for ($i=0; $i<count($lines); $i++) { 637f0fda08aSwikidesign $log = parseChangelogLine($lines[$i]); 638f0fda08aSwikidesign if ($log === false) continue; // discard junk 639f0fda08aSwikidesign if ($log['date'] < $trim_time) { 640f0fda08aSwikidesign $old_lines[$log['date'].".$i"] = $lines[$i]; // keep old lines for now (append .$i to prevent key collisions) 641f0fda08aSwikidesign } else { 642f0fda08aSwikidesign $out_lines[$log['date'].".$i"] = $lines[$i]; // definitely keep these lines 643f0fda08aSwikidesign } 644f0fda08aSwikidesign } 645f0fda08aSwikidesign 646f0fda08aSwikidesign // sort the final result, it shouldn't be necessary, 647f0fda08aSwikidesign // however the extra robustness in making the changelog cache self-correcting is worth it 648f0fda08aSwikidesign ksort($out_lines); 649f0fda08aSwikidesign $extra = $conf['recent'] - count($out_lines); // do we need extra lines do bring us up to minimum 650f0fda08aSwikidesign if ($extra > 0) { 651f0fda08aSwikidesign ksort($old_lines); 652f0fda08aSwikidesign $out_lines = array_merge(array_slice($old_lines,-$extra),$out_lines); 653f0fda08aSwikidesign } 654f0fda08aSwikidesign 655f0fda08aSwikidesign // save trimmed changelog 656f0fda08aSwikidesign io_saveFile($changelog.'_tmp', implode('', $out_lines)); 657f0fda08aSwikidesign @unlink($changelog); 658f0fda08aSwikidesign if (!rename($changelog.'_tmp', $changelog)) { 659f0fda08aSwikidesign // rename failed so try another way... 660f0fda08aSwikidesign io_unlock($changelog); 661f0fda08aSwikidesign io_saveFile($changelog, implode('', $out_lines)); 662f0fda08aSwikidesign @unlink($changelog.'_tmp'); 663f0fda08aSwikidesign } else { 664f0fda08aSwikidesign io_unlock($changelog); 665f0fda08aSwikidesign } 666f0fda08aSwikidesign return true; 667f0fda08aSwikidesign } 668f0fda08aSwikidesign } 669f0fda08aSwikidesign 670f0fda08aSwikidesign /** 671f0fda08aSwikidesign * Sends a notify mail on new comment 672f0fda08aSwikidesign * 673f0fda08aSwikidesign * @param array $comment data array of the new comment 674f0fda08aSwikidesign * 675f0fda08aSwikidesign * @author Andreas Gohr <andi@splitbrain.org> 676f0fda08aSwikidesign * @author Esther Brunner <wikidesign@gmail.com> 677f0fda08aSwikidesign */ 678f0fda08aSwikidesign function _notify($comment){ 679f0fda08aSwikidesign global $conf; 680f0fda08aSwikidesign global $ID; 681f0fda08aSwikidesign 682cc0c9acdSwikidesign if ((!$conf['subscribers']) && (!$conf['notify'])) return; //subscribers enabled? 683f0fda08aSwikidesign $bcc = subscriber_addresslist($ID); 684cc0c9acdSwikidesign if ((empty($bcc)) && (!$conf['notify'])) return; 685cc0c9acdSwikidesign $to = $conf['notify']; 686f0fda08aSwikidesign $text = io_readFile($this->localFN('subscribermail')); 687f0fda08aSwikidesign 688f0fda08aSwikidesign $text = str_replace('@PAGE@', $ID, $text); 689f0fda08aSwikidesign $text = str_replace('@TITLE@', $conf['title'], $text); 690f0fda08aSwikidesign $text = str_replace('@DATE@', date($conf['dformat'], $comment['date']), $text); 691f0fda08aSwikidesign $text = str_replace('@NAME@', $comment['name'], $text); 692f0fda08aSwikidesign $text = str_replace('@TEXT@', $comment['raw'], $text); 693f0fda08aSwikidesign $text = str_replace('@UNSUBSCRIBE@', wl($ID, 'do=unsubscribe', true, '&'), $text); 694f0fda08aSwikidesign $text = str_replace('@DOKUWIKIURL@', DOKU_URL, $text); 695f0fda08aSwikidesign 696f0fda08aSwikidesign $subject = '['.$conf['title'].'] '.$this->getLang('mail_newcomment'); 697f0fda08aSwikidesign 698f0fda08aSwikidesign mail_send($to, $subject, $text, $conf['mailfrom'], '', $bcc); 699f0fda08aSwikidesign } 700f0fda08aSwikidesign 701f0fda08aSwikidesign /** 702f0fda08aSwikidesign * Counts the number of visible comments 703f0fda08aSwikidesign */ 704f0fda08aSwikidesign function _count($data){ 705f0fda08aSwikidesign $number = 0; 706f0fda08aSwikidesign foreach ($data['comments'] as $cid => $comment){ 707f0fda08aSwikidesign if ($comment['parent']) continue; 708f0fda08aSwikidesign if (!$comment['show']) continue; 709f0fda08aSwikidesign $number++; 710f0fda08aSwikidesign $rids = $comment['replies']; 711f0fda08aSwikidesign if (count($rids)) $number = $number + $this->_countReplies($data, $rids); 712f0fda08aSwikidesign } 713f0fda08aSwikidesign return $number; 714f0fda08aSwikidesign } 715f0fda08aSwikidesign 716f0fda08aSwikidesign function _countReplies(&$data, $rids){ 717f0fda08aSwikidesign $number = 0; 718f0fda08aSwikidesign foreach ($rids as $rid){ 7192ee3dca3Swikidesign if (!isset($data['comments'][$rid])) continue; // reply was removed 720f0fda08aSwikidesign if (!$data['comments'][$rid]['show']) continue; 721f0fda08aSwikidesign $number++; 722f0fda08aSwikidesign $rids = $data['comments'][$rid]['replies']; 723f0fda08aSwikidesign if (count($rids)) $number = $number + $this->_countReplies($data, $rids); 724f0fda08aSwikidesign } 725f0fda08aSwikidesign return $number; 726f0fda08aSwikidesign } 727f0fda08aSwikidesign 728f0fda08aSwikidesign /** 729f0fda08aSwikidesign * Renders the comment text 730f0fda08aSwikidesign */ 731f0fda08aSwikidesign function _render($raw){ 732f0fda08aSwikidesign if ($this->getConf('wikisyntaxok')){ 733f0fda08aSwikidesign $xhtml = $this->render($raw); 734f0fda08aSwikidesign } else { // wiki syntax not allowed -> just encode special chars 735f0fda08aSwikidesign $xhtml = htmlspecialchars(trim($raw)); 736f0fda08aSwikidesign } 737f0fda08aSwikidesign return $xhtml; 738f0fda08aSwikidesign } 739f0fda08aSwikidesign 740f0fda08aSwikidesign /** 741479dd10fSwikidesign * Adds a TOC item for the discussion section 742479dd10fSwikidesign */ 743479dd10fSwikidesign function add_toc_item(&$event, $param){ 744479dd10fSwikidesign if ($event->data[0] != 'xhtml') return; // nothing to do for us 745479dd10fSwikidesign if (!$this->_hasDiscussion()) return; // no discussion section 746479dd10fSwikidesign 747479dd10fSwikidesign $pattern = '/<div id="toc__inside">(.*?)<\/div>\s<\/div>/s'; 748479dd10fSwikidesign if (!preg_match($pattern, $event->data[1], $match)) return; // no TOC on this page 749479dd10fSwikidesign 750479dd10fSwikidesign // ok, then let's do it! 751479dd10fSwikidesign global $conf; 752479dd10fSwikidesign 753479dd10fSwikidesign $title = $this->getLang('discussion'); 754479dd10fSwikidesign $section = '#discussion__section'; 755479dd10fSwikidesign $level = 3 - $conf['toptoclevel']; 756479dd10fSwikidesign 757479dd10fSwikidesign $item = '<li class="level'.$level.'"><div class="li"><span class="li"><a href="'. 758479dd10fSwikidesign $section.'" class="toc">'.$title.'</a></span></div></li>'; 759479dd10fSwikidesign 760479dd10fSwikidesign if ($level == 1) $search = "</ul>\n</div>"; 761479dd10fSwikidesign else $search = "</ul>\n</li></ul>\n</div>"; 762479dd10fSwikidesign 763479dd10fSwikidesign $new = str_replace($search, $item.$search, $match[0]); 764479dd10fSwikidesign $event->data[1] = preg_replace($pattern, $new, $event->data[1]); 765479dd10fSwikidesign } 766479dd10fSwikidesign 767479dd10fSwikidesign /** 768479dd10fSwikidesign * Finds out whether there is a discussion section for the current page 769479dd10fSwikidesign */ 770479dd10fSwikidesign function _hasDiscussion(){ 771479dd10fSwikidesign global $ID; 772479dd10fSwikidesign 773479dd10fSwikidesign $cfile = metaFN($ID, '.comments'); 774479dd10fSwikidesign 775479dd10fSwikidesign if (!@file_exists($cfile)){ 776479dd10fSwikidesign if ($this->getConf('automatic')) return true; 777479dd10fSwikidesign else return false; 778479dd10fSwikidesign } 779479dd10fSwikidesign 780479dd10fSwikidesign $comments = unserialize(io_readFile($cfile, false)); 781479dd10fSwikidesign 782479dd10fSwikidesign $num = $comments['number']; 783479dd10fSwikidesign if ((!$comments['status']) || (($comments['status'] == 2) && (!$num))) return false; 784479dd10fSwikidesign else return true; 785479dd10fSwikidesign } 786479dd10fSwikidesign 787479dd10fSwikidesign /** 788e7c760b3Swikidesign * Checks if 'newthread' was given as action or the comment form was submitted 789f0fda08aSwikidesign */ 790f0fda08aSwikidesign function handle_act_preprocess(&$event, $param){ 791e7c760b3Swikidesign if ($event->data == 'newthread'){ 7922e80cd5fSwikidesign // we can handle it -> prevent others 7932e80cd5fSwikidesign // $event->stopPropagation(); 7942e80cd5fSwikidesign $event->preventDefault(); 7952e80cd5fSwikidesign 7962e80cd5fSwikidesign $event->data = $this->_handle_newThread(); 797e7c760b3Swikidesign } 798e7c760b3Swikidesign if ((in_array($_REQUEST['comment'], array('add', 'save'))) 799e7c760b3Swikidesign && (@file_exists(DOKU_PLUGIN.'captcha/action.php'))){ 800e7c760b3Swikidesign $this->_handle_captchaCheck(); 801e7c760b3Swikidesign } 802e7c760b3Swikidesign } 803f0fda08aSwikidesign 804e7c760b3Swikidesign /** 805e7c760b3Swikidesign * Creates a new thread page 806e7c760b3Swikidesign */ 8072e80cd5fSwikidesign function _handle_newThread(){ 808f0fda08aSwikidesign global $ID; 8092e80cd5fSwikidesign global $INFO; 810f0fda08aSwikidesign 8111ea794e5Swikidesign $ns = cleanID($_REQUEST['ns']); 812f0fda08aSwikidesign $title = str_replace(':', '', $_REQUEST['title']); 8132e80cd5fSwikidesign $back = $ID; 8142e80cd5fSwikidesign $ID = ($ns ? $ns.':' : '').cleanID($title); 8152e80cd5fSwikidesign $INFO = pageinfo(); 816f0fda08aSwikidesign 817f0fda08aSwikidesign // check if we are allowed to create this file 8182e80cd5fSwikidesign if ($INFO['perm'] >= AUTH_CREATE){ 819f0fda08aSwikidesign 820f0fda08aSwikidesign //check if locked by anyone - if not lock for my self 8212e80cd5fSwikidesign if ($INFO['locked']) return 'locked'; 8222e80cd5fSwikidesign else lock($ID); 823f0fda08aSwikidesign 824f0fda08aSwikidesign // prepare the new thread file with default stuff 8252e80cd5fSwikidesign if (!@file_exists($INFO['filepath'])){ 826f0fda08aSwikidesign global $TEXT; 827f0fda08aSwikidesign global $conf; 828f0fda08aSwikidesign 8292e80cd5fSwikidesign $TEXT = pageTemplate(array(($ns ? $ns.':' : '').$title)); 8301433886fSwikidesign if (!$TEXT){ 8311433886fSwikidesign $TEXT = "<- [[:$back]]\n\n====== $title ======\n\n"; 8321433886fSwikidesign if ($this->getConf('usegravatar')) 8331433886fSwikidesign $TEXT .= '{{gravatar>'.$INFO['userinfo']['mail'].' }} '; 8348820dcabSwikidesign $TEXT .= "//".$INFO['userinfo']['name'].", ".date($conf['dformat']).": //\n\n"; 835f844c865Swikidesign if ((@file_exists(DOKU_PLUGIN.'tag/syntax/tag.php')) 836f844c865Swikidesign && (!plugin_isdisabled('tag'))) 8378820dcabSwikidesign $TEXT .= "\n\n{{tag>}}"; 8388820dcabSwikidesign $TEXT .= "\n\n~~DISCUSSION~~"; 8392e80cd5fSwikidesign } 8402e80cd5fSwikidesign return 'preview'; 841f0fda08aSwikidesign } else { 8422e80cd5fSwikidesign return 'edit'; 843f0fda08aSwikidesign } 844f0fda08aSwikidesign } else { 8452e80cd5fSwikidesign return 'show'; 846f0fda08aSwikidesign } 847f0fda08aSwikidesign } 848f0fda08aSwikidesign 849e7c760b3Swikidesign /** 850e7c760b3Swikidesign * Checks if the CAPTCHA string submitted is valid 851e7c760b3Swikidesign * 852e7c760b3Swikidesign * @author Andreas Gohr <gohr@cosmocode.de> 853e7c760b3Swikidesign * @adaption Esther Brunner <wikidesign@gmail.com> 854e7c760b3Swikidesign */ 855e7c760b3Swikidesign function _handle_captchaCheck(){ 856e7c760b3Swikidesign if (@file_exists(DOKU_PLUGIN.'captcha/disabled')) return; // CAPTCHA is disabled 857e7c760b3Swikidesign 858e7c760b3Swikidesign require_once(DOKU_PLUGIN.'captcha/action.php'); 859e7c760b3Swikidesign $captcha = new action_plugin_captcha; 860e7c760b3Swikidesign 861d1c29589Swikidesign // do nothing if logged in user and no CAPTCHA required 862d1c29589Swikidesign if (!$captcha->getConf('forusers') && $_SERVER['REMOTE_USER']) return; 863d1c29589Swikidesign 864e7c760b3Swikidesign // compare provided string with decrypted captcha 865e7c760b3Swikidesign $rand = PMA_blowfish_decrypt($_REQUEST['plugin__captcha_secret'], auth_cookiesalt()); 866e7c760b3Swikidesign $code = $captcha->_generateCAPTCHA($captcha->_fixedIdent(), $rand); 867e7c760b3Swikidesign 868e7c760b3Swikidesign if (!$_REQUEST['plugin__captcha_secret'] || 869e7c760b3Swikidesign !$_REQUEST['plugin__captcha'] || 870e7c760b3Swikidesign strtoupper($_REQUEST['plugin__captcha']) != $code){ 871e7c760b3Swikidesign 872e7c760b3Swikidesign // CAPTCHA test failed! Continue to edit instead of saving 873e7c760b3Swikidesign msg($captcha->getLang('testfailed'), -1); 874e7c760b3Swikidesign if ($_REQUEST['comment'] == 'save') $_REQUEST['comment'] = 'edit'; 875e7c760b3Swikidesign elseif ($_REQUEST['comment'] == 'add') $_REQUEST['comment'] = 'show'; 876e7c760b3Swikidesign } 877e7c760b3Swikidesign // if we arrive here it was a valid save 878e7c760b3Swikidesign } 879e7c760b3Swikidesign 880f0fda08aSwikidesign} 881f0fda08aSwikidesign 882f0fda08aSwikidesign//Setup VIM: ex: et ts=4 enc=utf-8 : 883