mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-10-22 13:25:54 +02:00 
			
		
		
		
	 f3745a2752
			
		
	
	f3745a2752
	
	
	
		
			
			* Remove unneeded escape * Fix guild back buttons (change logo & motd) * small adjustment in news.php * Fix create character when admin (any case is allowed now) * Fix forum table style (boards & thread view) * Small improvement to plugins.enabled check * [WIP] nikic/fast-route implementation I will describe it more in Pull Request * Optimisations & fixes. * Fix path - should not be absolute * Add PLUGINS to Twig path * Don't hide "Install Plugin" Box by default * Update package-lock.json * nothing important, just early exit & fixes Fix creature display * fix premium_ends_at for tfs 1.3+ * Move pages * Move pages tbc * $db->select: make $where parameter optional, allows to get all records * Add some error box to error * fix parse error * Rewriting the router v2 To be more flexible * small fixes * fix & add admin icons * Move mass_* pages to correct folder * fix logout hook 2 * Delete accountmanagement.php * This code wasn't used * Add missing var * Add redirect_from && redirect_to to router options + Also add * for all methods shortcut * Remove comments Not allowed in normal json * Allow admin pages included into plugins dir * block access to some files * Fix admin logout * Fix #178 * feature: mail confirmed reward Suggested by @EPuncker # Conflicts: # system/hooks.php * remove misleading comment * adjust required version according to composer.json * fix duplicated word * Adjustments & fixed to mass actions * Add password confirm, and change text type to password * Add list of Open Source Software MyAAC is using * Fix signature * Show First, Second instead of numbers * fix base dir detection * fix double ACTION define + undefined URI in template * new function> escapeHtml + fix css in admin menus * fix changelog add * fix news adding, rename const to NEWS_* * Add verify to pages, add messages, limits, fix add * fix "Please fill all input" * add required input to admin pages * shorten some expressions with ?? * shorten code + fix conversion (int) * Move account_types to config, account.web_flags to common.php * Update example.json * feature: router aliases * shorten some code + const convert * remove wrong char * fix signature on custom basedir * fix: mass teleport position validation (#214) * fix: mass teleport position validation * fix: max position * Fix execute in CLI * fix warning in reload cache in dev mode * Configurable admin panel folder * feature: plugin require more options with comma * $config_account_salt -> USE_ACCOUNT_SALT * fix forum show_thread * Update show_thread.php --------- Co-authored-by: Gabriel Pedro <gpedro@users.noreply.github.com>
		
			
				
	
	
		
			142 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| class News
 | |
| {
 | |
| 	static public function verify($title, $body, $article_text, $article_image, &$errors)
 | |
| 	{
 | |
| 		if(!isset($title[0]) || !isset($body[0])) {
 | |
| 			$errors[] = 'Please fill all inputs.';
 | |
| 			return false;
 | |
| 		}
 | |
| 		if(strlen($title) > NEWS_TITLE_LIMIT) {
 | |
| 			$errors[] = 'News title cannot be longer than ' . NEWS_TITLE_LIMIT . ' characters.';
 | |
| 			return false;
 | |
| 		}
 | |
| 		if(strlen($body) > NEWS_BODY_LIMIT) {
 | |
| 			$errors[] = 'News content cannot be longer than ' . NEWS_BODY_LIMIT . ' characters.';
 | |
| 			return false;
 | |
| 		}
 | |
| 		if(strlen($article_text) > ARTICLE_TEXT_LIMIT) {
 | |
| 			$errors[] = 'Article text cannot be longer than ' . ARTICLE_TEXT_LIMIT . ' characters.';
 | |
| 			return false;
 | |
| 		}
 | |
| 		if(strlen($article_image) > ARTICLE_IMAGE_LIMIT) {
 | |
| 			$errors[] = 'Article image cannot be longer than ' . ARTICLE_IMAGE_LIMIT . ' characters.';
 | |
| 			return false;
 | |
| 		}
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	static public function add($title, $body, $type, $category, $player_id, $comments, $article_text, $article_image, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(!self::verify($title, $body, $article_text, $article_image, $errors))
 | |
| 			return false;
 | |
| 
 | |
| 		$db->insert(TABLE_PREFIX . 'news', array('title' => $title, 'body' => $body, 'type' => $type, 'date' => time(), 'category' => $category, 'player_id' => isset($player_id) ? $player_id : 0, 'comments' => $comments, 'article_text' => ($type == 3 ? $article_text : ''), 'article_image' => ($type == 3 ? $article_image : '')));
 | |
| 		self::clearCache();
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	static public function get($id) {
 | |
| 		global $db;
 | |
| 		return $db->select(TABLE_PREFIX . 'news', array('id' => $id));
 | |
| 	}
 | |
| 
 | |
| 	static public function update($id, $title, $body, $type, $category, $player_id, $comments, $article_text, $article_image, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(!self::verify($title, $body, $article_text, $article_image, $errors))
 | |
| 			return false;
 | |
| 
 | |
| 		$db->update(TABLE_PREFIX . 'news', array('title' => $title, 'body' => $body, 'type' => $type, 'category' => $category, 'last_modified_by' => isset($player_id) ? $player_id : 0, 'last_modified_date' => time(), 'comments' => $comments, 'article_text' => $article_text, 'article_image' => $article_image), array('id' => $id));
 | |
| 		self::clearCache();
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	static public function delete($id, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(isset($id))
 | |
| 		{
 | |
| 			if($db->select(TABLE_PREFIX . 'news', array('id' => $id)) !== false)
 | |
| 				$db->delete(TABLE_PREFIX . 'news', array('id' => $id));
 | |
| 			else
 | |
| 				$errors[] = 'News with id ' . $id . ' does not exists.';
 | |
| 		}
 | |
| 		else
 | |
| 			$errors[] = 'News id not set.';
 | |
| 
 | |
| 		if(count($errors)) {
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 		self::clearCache();
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	static public function toggleHidden($id, &$errors, &$status)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(isset($id))
 | |
| 		{
 | |
| 			$query = $db->select(TABLE_PREFIX . 'news', array('id' => $id));
 | |
| 			if($query !== false)
 | |
| 			{
 | |
| 				$db->update(TABLE_PREFIX . 'news', array('hidden' => ($query['hidden'] == 1 ? 0 : 1)), array('id' => $id));
 | |
| 				$status = $query['hidden'];
 | |
| 			}
 | |
| 			else
 | |
| 				$errors[] = 'News with id ' . $id . ' does not exists.';
 | |
| 		}
 | |
| 		else
 | |
| 			$errors[] = 'News id not set.';
 | |
| 
 | |
| 		if(count($errors)) {
 | |
| 			return false;
 | |
| 		}
 | |
| 
 | |
| 		self::clearCache();
 | |
| 		return true;
 | |
| 	}
 | |
| 
 | |
| 	static public function getCached($type)
 | |
| 	{
 | |
| 		global $template_name;
 | |
| 
 | |
| 		$cache = Cache::getInstance();
 | |
| 		if ($cache->enabled())
 | |
| 		{
 | |
| 			$tmp = '';
 | |
| 			if ($cache->fetch('news_' . $template_name . '_' . $type, $tmp) && isset($tmp[0])) {
 | |
| 				return $tmp;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	static public function clearCache()
 | |
| 	{
 | |
| 		$cache = Cache::getInstance();
 | |
| 		if (!$cache->enabled()) {
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		$tmp = '';
 | |
| 		foreach (get_templates() as $template) {
 | |
| 			if ($cache->fetch('news_' . $template . '_' . NEWS, $tmp)) {
 | |
| 				$cache->delete('news_' . $template . '_' . NEWS);
 | |
| 			}
 | |
| 
 | |
| 			if ($cache->fetch('news_' . $template . '_' . TICKER, $tmp)) {
 | |
| 				$cache->delete('news_' . $template . '_' . TICKER);
 | |
| 			}
 | |
| 
 | |
| 			if ($cache->fetch('news_' . $template . '_' . ARTICLE, $tmp)) {
 | |
| 				$cache->delete('news_' . $template . '_' . ARTICLE);
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 |