mirror of
https://github.com/slawkens/myaac.git
synced 2025-04-26 09:19:22 +02:00

* New admin panel Pages: Options + Config [WIP] * Forgot the plugin example of options * Rename to settings.php * Add Settings Class * New myaac_settings table * Add $limit parameter to $db->select method * Add $member var annotation * Remove useless title_separator from config * Move $menus to menus.php Also fix active link when menu item has subpage * Settings [WIP] New Settings class New Plugins::load() method Move config.php to settings.php MyAAC Settings will have plugin_name = 'core' Add compat_config.php * Change options.php to settings.php * Change name to settings * Add Settings menu * Add Sections + Add setting($key) function Reorganisation * Add email + password fields as type * Update 33.php * add settings migration * php 8 compatibility * add missing hook * Add categories in tabs, move more settings, revert back getPluginSettings Categories and sections are now not numbered Remove example settings plugin * fix typo * Update .gitignore * Add 36th migration for settings table * Execute migrations just after db connect * Update plugins.php * [WIP] Some work on settings Add hidden settings New method: parse, to parse settings from array Move base html to twig template Remove vocation loading from .xml, instead use predefined voc names * Rename * Fix path * [WIP] More work on settings Move more config to settings (mainly mail_* + some other) Remove mail_admin, wasnt used anywhere Add return type to some functions Add Twig settings(key) function Possibility to save setting to db * Add min, max, step to number field option * Re-enable plugin if disabled and already installed * Add Settings menu, including all plugins with settings One change included in previous commit, due to missclick * Nothing important * Better boolean detection * More detailed error message in settings * Lets call it settings.name instead * Add new function: only_if, to hide fields when they are not enabled [WIP] Not fully finished yet * guild_management: show_if * Hide section title on show_if * Fix: check on page load if radio button is checked * Add: show_if - account_mail_verify * nothing important * Rename team_* variables + add to deprecated * Change variable name * Extract Settings:save function * Add settings.callbacks.get * Move forum config to settings * Move status config to settings * Remove whitespaces * More config to settings: account_types, genders, highscores, admin * Move signature config to settings * Move news config to settings * Rename variable * Save config.php in Settings Egg and hen problem solved :) * Test database connection on save settings -> prevents from making website unusable if connection is wrong * Test server_path -> same There is no config.php anymore, just config.local.php, which can be edited manually and also from admin panel * Remove configs from previous commit * Fix create account, if account_create_character_create is enabled * Add more deprecated configs * Add more info into comment * Update 5-database.php * Fix menu highlighting & opening * Update template.php * Enable script option * Reword email settings + move two new settings * add last_kills_limit + move shop * google_analytics_id * add mail_lost_account_interval * Create character blocked words (by @gpedro), just moved to settings * Fix google_analytics * create character name config moved to settings * Fix for install warning - min/max length * New create character checks configurable: block monsters & spells names * fixes * Improve character npc name check * New setting: donate_column + move donate config to settings * Add super fancy No Refresh saving with a toast * Add new possibility: to deny saving setting if condition is not met * Move database settings to separate category * Fix default value displaying * Add database_hash setting * add last_kills_limit to compat config * Move create character blocked names down * Every setting needs to have default * Move rest of config to settings Remove config.php completely Add new settings category: Game Fix account_login_by_email Min textarea size = 2 + adjusted automatically
126 lines
5.7 KiB
PHP
126 lines
5.7 KiB
PHP
<?php
|
|
/**
|
|
* Edit forum post
|
|
*
|
|
* @package MyAAC
|
|
* @author Gesior <jerzyskalski@wp.pl>
|
|
* @author Slawkens <slawkens@gmail.com>
|
|
* @copyright 2019 MyAAC
|
|
* @link https://my-aac.org
|
|
*/
|
|
defined('MYAAC') or die('Direct access not allowed!');
|
|
|
|
$ret = require __DIR__ . '/base.php';
|
|
if ($ret === false) {
|
|
return;
|
|
}
|
|
|
|
if(Forum::canPost($account_logged))
|
|
{
|
|
$post_id = isset($_REQUEST['id']) ? (int) $_REQUEST['id'] : false;
|
|
if(!$post_id) {
|
|
$errors[] = 'Please enter post id.';
|
|
displayErrorBoxWithBackButton($errors, getLink('forum'));
|
|
return;
|
|
}
|
|
|
|
$thread = $db->query("SELECT `author_guid`, `author_aid`, `first_post`, `post_topic`, `post_date`, `post_text`, `post_smile`, `post_html`, `id`, `section` FROM `" . FORUM_TABLE_PREFIX . "forum` WHERE `id` = ".$post_id." LIMIT 1")->fetch();
|
|
if(isset($thread['id'])) {
|
|
$first_post = $db->query("SELECT `" . FORUM_TABLE_PREFIX . "forum`.`author_guid`, `" . FORUM_TABLE_PREFIX . "forum`.`author_aid`, `" . FORUM_TABLE_PREFIX . "forum`.`first_post`, `" . FORUM_TABLE_PREFIX . "forum`.`post_topic`, `" . FORUM_TABLE_PREFIX . "forum`.`post_text`, `" . FORUM_TABLE_PREFIX . "forum`.`post_smile`, `" . FORUM_TABLE_PREFIX . "forum`.`id`, `" . FORUM_TABLE_PREFIX . "forum`.`section` FROM `" . FORUM_TABLE_PREFIX . "forum` WHERE `" . FORUM_TABLE_PREFIX . "forum`.`id` = ".(int) $thread['first_post']." LIMIT 1")->fetch();
|
|
echo '<a href="' . getLink('forum') . '">Boards</a> >> <a href="' . getForumBoardLink($thread['section']) . '">'.$sections[$thread['section']]['name'].'</a> >> <a href="' . getForumThreadLink($thread['first_post']) . '">'.$first_post['post_topic'].'</a> >> <b>Edit post</b>';
|
|
|
|
if(Forum::hasAccess($thread['section'] && ($account_logged->getId() == $thread['author_aid'] || Forum::isModerator()))) {
|
|
$char_id = $post_topic = $text = $smile = $html = null;
|
|
$players_from_account = $db->query("SELECT `players`.`name`, `players`.`id` FROM `players` WHERE `players`.`account_id` = ".(int) $account_logged->getId())->fetchAll();
|
|
$saved = false;
|
|
if(isset($_REQUEST['save'])) {
|
|
$text = stripslashes(trim($_REQUEST['text']));
|
|
$char_id = (int) $_REQUEST['char_id'];
|
|
$post_topic = stripslashes(trim($_REQUEST['topic']));
|
|
$smile = isset($_REQUEST['smile']) ? (int)$_REQUEST['smile'] : 0;
|
|
$html = isset($_REQUEST['html']) ? (int)$_REQUEST['html'] : 0;
|
|
|
|
$length = strlen($post_topic);
|
|
if(($length < 1 || $length > 60) && $thread['id'] == $thread['first_post']) {
|
|
$errors[] = "Too short or too long topic (Length: $length letters). Minimum 1 letter, maximum 60 letters.";
|
|
}
|
|
|
|
$length = strlen($text);
|
|
if($length < 1 || $length > 15000) {
|
|
$errors[] = "Too short or too long post (Length: $length letters). Minimum 1 letter, maximum 15000 letters.";
|
|
}
|
|
|
|
if($char_id == 0) {
|
|
$errors[] = 'Please select a character.';
|
|
}
|
|
|
|
if(empty($post_topic) && $thread['id'] == $thread['first_post']) {
|
|
$errors[] = 'Thread topic can\'t be empty.';
|
|
}
|
|
|
|
$player_on_account = false;
|
|
|
|
if(count($errors) == 0) {
|
|
foreach($players_from_account as $player) {
|
|
if ($char_id == $player['id']) {
|
|
$player_on_account = true;
|
|
}
|
|
}
|
|
|
|
if(!$player_on_account) {
|
|
$errors[] = 'Player with selected ID ' . $char_id . ' doesn\'t exist or isn\'t on your account';
|
|
}
|
|
}
|
|
|
|
if(count($errors) == 0) {
|
|
$saved = true;
|
|
if($account_logged->getId() != $thread['author_aid'])
|
|
$char_id = $thread['author_guid'];
|
|
$db->query("UPDATE `" . FORUM_TABLE_PREFIX . "forum` SET `author_guid` = ".(int) $char_id.", `post_text` = ".$db->quote($text).", `post_topic` = ".$db->quote($post_topic).", `post_smile` = ".$smile.", `post_html` = ".$html.", `last_edit_aid` = ".(int) $account_logged->getId().",`edit_date` = ".time()." WHERE `id` = ".(int) $thread['id']);
|
|
$post_page = $db->query("SELECT COUNT(`" . FORUM_TABLE_PREFIX . "forum`.`id`) AS posts_count FROM `players`, `" . FORUM_TABLE_PREFIX . "forum` WHERE `players`.`id` = `" . FORUM_TABLE_PREFIX . "forum`.`author_guid` AND `" . FORUM_TABLE_PREFIX . "forum`.`post_date` <= ".$thread['post_date']." AND `" . FORUM_TABLE_PREFIX . "forum`.`first_post` = ".(int) $thread['first_post'])->fetch();
|
|
$_page = (int) ceil($post_page['posts_count'] / setting('core.forum_threads_per_page')) - 1;
|
|
header('Location: ' . getForumThreadLink($thread['first_post'], $_page));
|
|
echo '<br />Thank you for editing post.<br /><a href="' . getForumThreadLink($thread['first_post'], $_page) . '">GO BACK TO LAST THREAD</a>';
|
|
}
|
|
}
|
|
else {
|
|
$text = $thread['post_text'];
|
|
$char_id = (int) $thread['author_guid'];
|
|
$post_topic = $thread['post_topic'];
|
|
$smile = (int) $thread['post_smile'];
|
|
$html = (int) $thread['post_html'];
|
|
}
|
|
|
|
if(!$saved) {
|
|
if(!empty($errors)) {
|
|
$twig->display('error_box.html.twig', array('errors' => $errors));
|
|
}
|
|
|
|
$twig->display('forum.edit_post.html.twig', array(
|
|
'post_id' => $post_id,
|
|
'players' => $players_from_account,
|
|
'player_id' => $char_id,
|
|
'post_topic' => $canEdit ? $post_topic : htmlspecialchars($post_topic),
|
|
'post_text' => $canEdit ? $text : htmlspecialchars($text),
|
|
'post_smile' => $smile > 0,
|
|
'post_html' => $html > 0,
|
|
'html' => $html,
|
|
'canEdit' => $canEdit
|
|
));
|
|
}
|
|
}
|
|
else {
|
|
$errors[] = 'You are not an author of this post.';
|
|
displayErrorBoxWithBackButton($errors, getLink('forum'));
|
|
}
|
|
}
|
|
else {
|
|
$errors[] = "Post with ID $post_id doesn't exist.";
|
|
displayErrorBoxWithBackButton($errors, getLink('forum'));
|
|
}
|
|
}
|
|
else {
|
|
$errors[] = "Your account is banned, deleted or you don't have any player with level " . setting('core.forum_level_required') . " on your account. You can't post.";
|
|
displayErrorBoxWithBackButton($errors, getLink('forum'));
|
|
}
|