PageRenderTime 51ms CodeModel.GetById 26ms RepoModel.GetById 0ms app.codeStats 0ms

/delete.php

https://bitbucket.org/gencer/punbb
PHP | 244 lines | 171 code | 47 blank | 26 comment | 26 complexity | d49e48423b33570d3cfce2128fd057ca MD5 | raw file
Possible License(s): GPL-2.0
  1. <?php
  2. /**
  3. * Post deletion page.
  4. *
  5. * Deletes the specified post (and, if necessary, the topic it is in).
  6. *
  7. * @copyright (C) 2008-2012 PunBB, partially based on code (C) 2008-2009 FluxBB.org
  8. * @license http://www.gnu.org/licenses/gpl.html GPL version 2 or higher
  9. * @package PunBB
  10. */
  11. if (!defined('FORUM_ROOT'))
  12. define('FORUM_ROOT', './');
  13. require FORUM_ROOT.'include/common.php';
  14. ($hook = get_hook('dl_start')) ? eval($hook) : null;
  15. if ($forum_user['g_read_board'] == '0')
  16. message($lang_common['No view']);
  17. // Load the delete.php language file
  18. require FORUM_ROOT.'lang/'.$forum_user['language'].'/delete.php';
  19. $id = isset($_GET['id']) ? intval($_GET['id']) : 0;
  20. if ($id < 1)
  21. message($lang_common['Bad request']);
  22. // Fetch some info about the post, the topic and the forum
  23. $query = array(
  24. 'SELECT' => 'f.id AS fid, f.forum_name, f.moderators, f.redirect_url, fp.post_replies, fp.post_topics, t.id AS tid, t.subject, t.first_post_id, t.closed, p.poster, p.poster_id, p.message, p.hide_smilies, p.posted',
  25. 'FROM' => 'posts AS p',
  26. 'JOINS' => array(
  27. array(
  28. 'INNER JOIN' => 'topics AS t',
  29. 'ON' => 't.id=p.topic_id'
  30. ),
  31. array(
  32. 'INNER JOIN' => 'forums AS f',
  33. 'ON' => 'f.id=t.forum_id'
  34. ),
  35. array(
  36. 'LEFT JOIN' => 'forum_perms AS fp',
  37. 'ON' => '(fp.forum_id=f.id AND fp.group_id='.$forum_user['g_id'].')'
  38. )
  39. ),
  40. 'WHERE' => '(fp.read_forum IS NULL OR fp.read_forum=1) AND p.id='.$id
  41. );
  42. ($hook = get_hook('dl_qr_get_post_info')) ? eval($hook) : null;
  43. $result = $forum_db->query_build($query) or error(__FILE__, __LINE__);
  44. $cur_post = $forum_db->fetch_assoc($result);
  45. if (!$cur_post)
  46. message($lang_common['Bad request']);
  47. // Sort out who the moderators are and if we are currently a moderator (or an admin)
  48. $mods_array = ($cur_post['moderators'] != '') ? unserialize($cur_post['moderators']) : array();
  49. $forum_page['is_admmod'] = ($forum_user['g_id'] == FORUM_ADMIN || ($forum_user['g_moderator'] == '1' && array_key_exists($forum_user['username'], $mods_array))) ? true : false;
  50. $cur_post['is_topic'] = ($id == $cur_post['first_post_id']) ? true : false;
  51. ($hook = get_hook('dl_pre_permission_check')) ? eval($hook) : null;
  52. // Do we have permission to delete this post?
  53. if ((($forum_user['g_delete_posts'] == '0' && !$cur_post['is_topic']) ||
  54. ($forum_user['g_delete_topics'] == '0' && $cur_post['is_topic']) ||
  55. $cur_post['poster_id'] != $forum_user['id'] ||
  56. $cur_post['closed'] == '1') &&
  57. !$forum_page['is_admmod'])
  58. message($lang_common['No permission']);
  59. ($hook = get_hook('dl_post_selected')) ? eval($hook) : null;
  60. // User pressed the cancel button
  61. if (isset($_POST['cancel']))
  62. redirect(forum_link($forum_url['post'], $id), $lang_common['Cancel redirect']);
  63. // User pressed the delete button
  64. else if (isset($_POST['delete']))
  65. {
  66. ($hook = get_hook('dl_form_submitted')) ? eval($hook) : null;
  67. if (!isset($_POST['req_confirm']))
  68. redirect(forum_link($forum_url['post'], $id), $lang_common['No confirm redirect']);
  69. if ($cur_post['is_topic'])
  70. {
  71. // Delete the topic and all of it's posts
  72. delete_topic($cur_post['tid'], $cur_post['fid']);
  73. $forum_flash->add_info($lang_delete['Topic del redirect']);
  74. ($hook = get_hook('dl_topic_deleted_pre_redirect')) ? eval($hook) : null;
  75. redirect(forum_link($forum_url['forum'], array($cur_post['fid'], sef_friendly($cur_post['forum_name']))), $lang_delete['Topic del redirect']);
  76. }
  77. else
  78. {
  79. // Delete just this one post
  80. delete_post($id, $cur_post['tid'], $cur_post['fid']);
  81. // Fetch previus post #id in some topic for redirect after delete
  82. $query = array(
  83. 'SELECT' => 'p.id',
  84. 'FROM' => 'posts AS p',
  85. 'WHERE' => 'p.topic_id = '.$cur_post['tid'].' AND p.id < '.$id,
  86. 'ORDER BY' => 'p.id DESC',
  87. 'LIMIT' => '1'
  88. );
  89. ($hook = get_hook('dl_post_deleted_get_prev_post_id')) ? eval($hook) : null;
  90. $result = $forum_db->query_build($query) or error(__FILE__, __LINE__);
  91. $prev_post = $forum_db->fetch_assoc($result);
  92. $forum_flash->add_info($lang_delete['Post del redirect']);
  93. ($hook = get_hook('dl_post_deleted_pre_redirect')) ? eval($hook) : null;
  94. if (isset($prev_post['id']))
  95. {
  96. redirect(forum_link($forum_url['post'], $prev_post['id']), $lang_delete['Post del redirect']);
  97. }
  98. else
  99. {
  100. redirect(forum_link($forum_url['topic'], array($cur_post['tid'], sef_friendly($cur_post['subject']))), $lang_delete['Post del redirect']);
  101. }
  102. }
  103. }
  104. // Run the post through the parser
  105. if (!defined('FORUM_PARSER_LOADED'))
  106. require FORUM_ROOT.'include/parser.php';
  107. $cur_post['message'] = parse_message($cur_post['message'], $cur_post['hide_smilies']);
  108. // Setup form
  109. $forum_page['group_count'] = $forum_page['item_count'] = $forum_page['fld_count'] = 0;
  110. $forum_page['form_action'] = forum_link($forum_url['delete'], $id);
  111. $forum_page['hidden_fields'] = array(
  112. 'form_sent' => '<input type="hidden" name="form_sent" value="1" />',
  113. 'csrf_token' => '<input type="hidden" name="csrf_token" value="'.generate_form_token($forum_page['form_action']).'" />'
  114. );
  115. // Setup form information
  116. $forum_page['frm_info'] = array(
  117. '<li><span>'.$lang_delete['Forum'].':<strong> '.forum_htmlencode($cur_post['forum_name']).'</strong></span></li>',
  118. '<li><span>'.$lang_delete['Topic'].':<strong> '.forum_htmlencode($cur_post['subject']).'</strong></span></li>'
  119. );
  120. // Generate the post heading
  121. $forum_page['post_ident'] = array();
  122. $forum_page['post_ident']['byline'] = '<span class="post-byline">'.sprintf((($cur_post['is_topic']) ? $lang_delete['Topic byline'] : $lang_delete['Reply byline']), '<strong>'.forum_htmlencode($cur_post['poster']).'</strong>').'</span>';
  123. $forum_page['post_ident']['link'] = '<span class="post-link"><a class="permalink" href="'.forum_link($forum_url['post'], $cur_post['tid']).'">'.format_time($cur_post['posted']).'</a></span>';
  124. ($hook = get_hook('dl_pre_item_ident_merge')) ? eval($hook) : null;
  125. // Generate the post title
  126. if ($cur_post['is_topic'])
  127. $forum_page['item_subject'] = sprintf($lang_delete['Topic title'], $cur_post['subject']);
  128. else
  129. $forum_page['item_subject'] = sprintf($lang_delete['Reply title'], $cur_post['subject']);
  130. $forum_page['item_subject'] = forum_htmlencode($forum_page['item_subject']);
  131. // Setup breadcrumbs
  132. $forum_page['crumbs'] = array(
  133. array($forum_config['o_board_title'], forum_link($forum_url['index'])),
  134. array($cur_post['forum_name'], forum_link($forum_url['forum'], array($cur_post['fid'], sef_friendly($cur_post['forum_name'])))),
  135. array($cur_post['subject'], forum_link($forum_url['topic'], array($cur_post['tid'], sef_friendly($cur_post['subject'])))),
  136. (($cur_post['is_topic']) ? $lang_delete['Delete topic'] : $lang_delete['Delete post'])
  137. );
  138. ($hook = get_hook('dl_pre_header_load')) ? eval($hook) : null;
  139. define ('FORUM_PAGE', 'postdelete');
  140. require FORUM_ROOT.'header.php';
  141. // START SUBST - <!-- forum_main -->
  142. ob_start();
  143. ($hook = get_hook('dl_main_output_start')) ? eval($hook) : null;
  144. ?>
  145. <div class="main-content main-frm">
  146. <div class="ct-box info-box">
  147. <ul class="info-list">
  148. <?php echo implode("\n\t\t\t\t", $forum_page['frm_info'])."\n" ?>
  149. </ul>
  150. </div>
  151. <?php ($hook = get_hook('dl_pre_post_display')) ? eval($hook) : null; ?>
  152. <div class="post singlepost">
  153. <div class="posthead">
  154. <h3 class="hn post-ident"><?php echo implode(' ', $forum_page['post_ident']) ?></h3>
  155. <?php ($hook = get_hook('dl_new_post_head_option')) ? eval($hook) : null; ?>
  156. </div>
  157. <div class="postbody">
  158. <div class="post-entry">
  159. <h4 class="entry-title hn"><?php echo $forum_page['item_subject'] ?></h4>
  160. <div class="entry-content">
  161. <?php echo $cur_post['message']."\n" ?>
  162. </div>
  163. <?php ($hook = get_hook('dl_new_post_entry_data')) ? eval($hook) : null; ?>
  164. </div>
  165. </div>
  166. </div>
  167. <form class="frm-form" method="post" accept-charset="utf-8" action="<?php echo $forum_page['form_action'] ?>">
  168. <div class="hidden">
  169. <?php echo implode("\n\t\t\t\t", $forum_page['hidden_fields'])."\n" ?>
  170. </div>
  171. <?php ($hook = get_hook('dl_pre_confirm_delete_fieldset')) ? eval($hook) : null; ?>
  172. <fieldset class="frm-group group<?php echo ++$forum_page['group_count'] ?>">
  173. <legend class="group-legend"><strong><?php echo ($cur_post['is_topic']) ? $lang_delete['Delete topic'] : $lang_delete['Delete post'] ?></strong></legend>
  174. <?php ($hook = get_hook('dl_pre_confirm_delete_checkbox')) ? eval($hook) : null; ?>
  175. <div class="sf-set set<?php echo ++$forum_page['item_count'] ?>">
  176. <div class="sf-box checkbox">
  177. <span class="fld-input"><input type="checkbox" id="fld<?php echo ++$forum_page['fld_count'] ?>" name="req_confirm" value="1" checked="checked" /></span>
  178. <label for="fld<?php echo $forum_page['fld_count'] ?>"><span><?php echo $lang_delete['Please confirm'] ?></span> <?php printf(((($cur_post['is_topic'])) ? $lang_delete['Delete topic label'] : $lang_delete['Delete post label']), forum_htmlencode($cur_post['poster']), format_time($cur_post['posted'])) ?></label>
  179. </div>
  180. </div>
  181. <?php ($hook = get_hook('dl_pre_confirm_delete_fieldset_end')) ? eval($hook) : null; ?>
  182. </fieldset>
  183. <?php ($hook = get_hook('dl_confirm_delete_fieldset_end')) ? eval($hook) : null; ?>
  184. <div class="frm-buttons">
  185. <span class="submit primary caution"><input type="submit" name="delete" value="<?php echo ($cur_post['is_topic']) ? $lang_delete['Delete topic'] : $lang_delete['Delete post'] ?>" /></span>
  186. <span class="cancel"><input type="submit" name="cancel" value="<?php echo $lang_common['Cancel'] ?>" formnovalidate /></span>
  187. </div>
  188. </form>
  189. </div>
  190. <?php
  191. $forum_id = $cur_post['fid'];
  192. ($hook = get_hook('dl_end')) ? eval($hook) : null;
  193. $tpl_temp = forum_trim(ob_get_contents());
  194. $tpl_main = str_replace('<!-- forum_main -->', $tpl_temp, $tpl_main);
  195. ob_end_clean();
  196. // END SUBST - <!-- forum_main -->
  197. require FORUM_ROOT.'footer.php';