mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-10-20 20:43:26 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			326 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			326 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Forum class
 | |
|  *
 | |
|  * @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!');
 | |
| 
 | |
| $configForumTablePrefix = config('forum_table_prefix');
 | |
| if(null !== $configForumTablePrefix && !empty(trim($configForumTablePrefix))) {
 | |
| 	if(!in_array($configForumTablePrefix, array('myaac_', 'z_'))) {
 | |
| 		throw new RuntimeException('Invalid value for forum_table_prefix in config.php. Can be only: "myaac_" or "z_".');
 | |
| 	}
 | |
| 
 | |
| 	define('FORUM_TABLE_PREFIX', $configForumTablePrefix);
 | |
| }
 | |
| else {
 | |
| 	if($db->hasTable('z_forum')) {
 | |
| 		define('FORUM_TABLE_PREFIX', 'z_');
 | |
| 	}
 | |
| 	else {
 | |
| 		define('FORUM_TABLE_PREFIX', 'myaac_');
 | |
| 	}
 | |
| }
 | |
| 
 | |
| class Forum
 | |
| {
 | |
| 	/**
 | |
| 	 * @param OTS_Account $account
 | |
| 	 * @return bool
 | |
| 	 * @throws E_OTS_NotLoaded
 | |
| 	 */
 | |
| 	public static function canPost($account)
 | |
| 	{
 | |
| 		global $db, $config;
 | |
| 
 | |
| 		if(!$account->isLoaded() || $account->isBanned())
 | |
| 			return false;
 | |
| 
 | |
| 		if(self::isModerator())
 | |
| 			return true;
 | |
| 
 | |
| 		return
 | |
| 			$db->query(
 | |
| 				'SELECT `id` FROM `players` WHERE `account_id` = ' . $db->quote($account->getId()) .
 | |
| 				' AND `level` >= ' . $db->quote($config['forum_level_required']) .
 | |
| 				' LIMIT 1')->rowCount() > 0;
 | |
| 	}
 | |
| 
 | |
| 	public static function isModerator() {
 | |
| 		return hasFlag(FLAG_CONTENT_FORUM) || superAdmin();
 | |
| 	}
 | |
| 
 | |
| 	public static function add_thread($title, $body, $section_id, $player_id, $account_id, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		$thread_id = 0;
 | |
| 		if($db->insert(FORUM_TABLE_PREFIX . 'forum', array(
 | |
| 			'first_post' => 0,
 | |
| 			'last_post' => time(),
 | |
| 			'section' => $section_id,
 | |
| 			'replies' => 0,
 | |
| 			'views' => 0,
 | |
| 			'author_aid' => isset($account_id) ? $account_id : 0,
 | |
| 			'author_guid' => isset($player_id) ? $player_id : 0,
 | |
| 			'post_text' => $body, 'post_topic' => $title,
 | |
| 			'post_smile' => 0, 'post_html' => 1,
 | |
| 			'post_date' => time(),
 | |
| 			'last_edit_aid' => 0, 'edit_date' => 0,
 | |
| 			'post_ip' => $_SERVER['REMOTE_ADDR']
 | |
| 		))) {
 | |
| 			$thread_id = $db->lastInsertId();
 | |
| 			$db->query("UPDATE `" . FORUM_TABLE_PREFIX . "forum` SET `first_post`=".(int) $thread_id." WHERE `id` = ".(int) $thread_id);
 | |
| 		}
 | |
| 
 | |
| 		return $thread_id;
 | |
| 	}
 | |
| 
 | |
| 	public static function add_post($thread_id, $section, $author_aid, $author_guid, $post_text, $post_topic, $smile, $html)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		$db->insert(FORUM_TABLE_PREFIX . 'forum', array(
 | |
| 			'first_post' => $thread_id,
 | |
| 			'section' => $section,
 | |
| 			'author_aid' => $author_aid,
 | |
| 			'author_guid' => $author_guid,
 | |
| 			'post_text' => $post_text,
 | |
| 			'post_topic' => $post_topic,
 | |
| 			'post_smile' => $smile,
 | |
| 			'post_html' => $html,
 | |
| 			'post_date' => time(),
 | |
| 			'post_ip' => $_SERVER['REMOTE_ADDR']
 | |
| 		));
 | |
| 	}
 | |
| 	public static function add_board($name, $description, $access, $guild, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(isset($name[0]) && isset($description[0]))
 | |
| 		{
 | |
| 			$query = $db->select(TABLE_PREFIX . 'forum_boards', array('name' => $name));
 | |
| 
 | |
| 			if($query === false)
 | |
| 			{
 | |
| 				$query =
 | |
| 					$db->query(
 | |
| 						'SELECT ' . $db->fieldName('ordering') .
 | |
| 						' FROM ' . $db->tableName(TABLE_PREFIX . 'forum_boards') .
 | |
| 						' ORDER BY ' . $db->fieldName('ordering') . ' DESC LIMIT 1'
 | |
| 					);
 | |
| 
 | |
| 				$ordering = 0;
 | |
| 				if($query->rowCount() > 0) {
 | |
| 					$query = $query->fetch();
 | |
| 					$ordering = $query['ordering'] + 1;
 | |
| 				}
 | |
| 				$db->insert(TABLE_PREFIX . 'forum_boards', array('name' => $name, 'description' => $description, 'access' => $access, 'guild' => $guild, 'ordering' => $ordering));
 | |
| 			}
 | |
| 			else
 | |
| 				$errors[] = 'Forum board with this name already exists.';
 | |
| 		}
 | |
| 		else
 | |
| 			$errors[] = 'Please fill all inputs.';
 | |
| 
 | |
| 		return !count($errors);
 | |
| 	}
 | |
| 
 | |
| 	public static function get_board($id) {
 | |
| 		global $db;
 | |
| 		return $db->select(TABLE_PREFIX . 'forum_boards', array('id' => $id));
 | |
| 	}
 | |
| 
 | |
| 	public static function update_board($id, $name, $access, $guild, $description) {
 | |
| 		global $db;
 | |
| 		$db->update(TABLE_PREFIX . 'forum_boards', array('name' => $name, 'description' => $description, 'access' => $access, 'guild' => $guild), array('id' => $id));
 | |
| 	}
 | |
| 
 | |
| 	public static function delete_board($id, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(isset($id))
 | |
| 		{
 | |
| 			if(self::get_board($id) !== false)
 | |
| 				$db->delete(TABLE_PREFIX . 'forum_boards', array('id' => $id));
 | |
| 			else
 | |
| 				$errors[] = 'Forum board with id ' . $id . ' does not exists.';
 | |
| 		}
 | |
| 		else
 | |
| 			$errors[] = 'id not set';
 | |
| 
 | |
| 		return !count($errors);
 | |
| 	}
 | |
| 
 | |
| 	public static function toggleHidden_board($id, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		if(isset($id))
 | |
| 		{
 | |
| 			$query = self::get_board($id);
 | |
| 			if($query !== false)
 | |
| 				$db->update(TABLE_PREFIX . 'forum_boards', array('hidden' => ($query['hidden'] == 1 ? 0 : 1)), array('id' => $id));
 | |
| 			else
 | |
| 				$errors[] = 'Forum board with id ' . $id . ' does not exists.';
 | |
| 		}
 | |
| 		else
 | |
| 			$errors[] = 'id not set';
 | |
| 
 | |
| 		return !count($errors);
 | |
| 	}
 | |
| 
 | |
| 	public static function move_board($id, $i, &$errors)
 | |
| 	{
 | |
| 		global $db;
 | |
| 		$query = self::get_board($id);
 | |
| 		if($query !== false)
 | |
| 		{
 | |
| 			$ordering = $query['ordering'] + $i;
 | |
| 			$old_record = $db->select(TABLE_PREFIX . 'forum_boards', array('ordering' => $ordering));
 | |
| 			if($old_record !== false)
 | |
| 				$db->update(TABLE_PREFIX . 'forum_boards', array('ordering' => $query['ordering']), array('ordering' => $ordering));
 | |
| 
 | |
| 			$db->update(TABLE_PREFIX . 'forum_boards', array('ordering' => $ordering), array('id' => $id));
 | |
| 		}
 | |
| 		else
 | |
| 			$errors[] = 'Forum board with id ' . $id . ' does not exists.';
 | |
| 
 | |
| 		return !count($errors);
 | |
| 	}
 | |
| 
 | |
| 	public static function parseSmiles($text)
 | |
| 	{
 | |
| 		$smileys = array(
 | |
| 			';D' => 1,
 | |
| 			':D' => 1,
 | |
| 			':cool:' => 2,
 | |
| 			';cool;' => 2,
 | |
| 			':ekk:' => 3,
 | |
| 			';ekk;' => 3,
 | |
| 			';o' => 4,
 | |
| 			';O' => 4,
 | |
| 			':o' => 4,
 | |
| 			':O' => 4,
 | |
| 			':(' => 5,
 | |
| 			';(' => 5,
 | |
| 			':mad:' => 6,
 | |
| 			';mad;' => 6,
 | |
| 			';rolleyes;' => 7,
 | |
| 			':rolleyes:' => 7,
 | |
| 			':)' => 8,
 | |
| 			';d' => 9,
 | |
| 			':d' => 9,
 | |
| 			';)' => 10
 | |
| 		);
 | |
| 
 | |
| 		foreach($smileys as $search => $replace)
 | |
| 			$text = str_replace($search, '<img src="images/forum/smile/'.$replace.'.gif" alt="'. $search .'" title="' . $search . '" />', $text);
 | |
| 
 | |
| 		return $text;
 | |
| 	}
 | |
| 
 | |
| 	public static function parseBBCode($text, $smiles)
 | |
| 	{
 | |
| 		$rows = 0;
 | |
| 		while(stripos($text, '[code]') !== false && stripos($text, '[/code]') !== false )
 | |
| 		{
 | |
| 			$code = substr($text, stripos($text, '[code]')+6, stripos($text, '[/code]') - stripos($text, '[code]') - 6);
 | |
| 			if(!is_int($rows / 2)) { $bgcolor = 'ABED25'; } else { $bgcolor = '23ED25'; } $rows++;
 | |
| 			$text = str_ireplace('[code]'.$code.'[/code]', '<i>Code:</i><br /><table cellpadding="0" style="background-color: #'.$bgcolor.'; width: 480px; border-style: dotted; border-color: #CCCCCC; border-width: 2px"><tr><td>'.$code.'</td></tr></table>', $text);
 | |
| 		}
 | |
| 		$rows = 0;
 | |
| 		while(stripos($text, '[quote]') !== false && stripos($text, '[/quote]') !== false )
 | |
| 		{
 | |
| 			$quote = substr($text, stripos($text, '[quote]')+7, stripos($text, '[/quote]') - stripos($text, '[quote]') - 7);
 | |
| 			if(!is_int($rows / 2)) { $bgcolor = 'AAAAAA'; } else { $bgcolor = 'CCCCCC'; } $rows++;
 | |
| 			$text = str_ireplace('[quote]'.$quote.'[/quote]', '<table cellpadding="0" style="background-color: #'.$bgcolor.'; width: 480px; border-style: dotted; border-color: #007900; border-width: 2px"><tr><td>'.$quote.'</td></tr></table>', $text);
 | |
| 		}
 | |
| 		$rows = 0;
 | |
| 		while(stripos($text, '[url]') !== false && stripos($text, '[/url]') !== false )
 | |
| 		{
 | |
| 			$url = substr($text, stripos($text, '[url]')+5, stripos($text, '[/url]') - stripos($text, '[url]') - 5);
 | |
| 			$text = str_ireplace('[url]'.$url.'[/url]', '<a href="'.$url.'" target="_blank">'.$url.'</a>', $text);
 | |
| 		}
 | |
| 
 | |
| 		$xhtml = false;
 | |
| 		$tags = array(
 | |
| 			'#\[b\](.*?)\[/b\]#si' => ($xhtml ? '<strong>\\1</strong>' : '<b>\\1</b>'),
 | |
| 			'#\[i\](.*?)\[/i\]#si' => ($xhtml ? '<em>\\1</em>' : '<i>\\1</i>'),
 | |
| 			'#\[u\](.*?)\[/u\]#si' => ($xhtml ? '<span style="text-decoration: underline;">\\1</span>' : '<u>\\1</u>'),
 | |
| 			'#\[s\](.*?)\[/s\]#si' => ($xhtml ? '<strike>\\1</strike>' : '<s>\\1</s>'),
 | |
| 
 | |
| 			'#\[guild\](.*?)\[/guild\]#si' => urldecode(generateLink(getGuildLink('$1', false), '$1', true)),
 | |
| 			'#\[house\](.*?)\[/house\]#si' => urldecode(generateLink(getHouseLink('$1', false), '$1', true)),
 | |
| 			'#\[player\](.*?)\[/player\]#si' => urldecode(generateLink(getPlayerLink('$1', false), '$1', true)),
 | |
| 			// TODO: [poll] tag
 | |
| 
 | |
| 			'#\[color=(.*?)\](.*?)\[/color\]#si' => ($xhtml ? '<span style="color: \\1;">\\2</span>' : '<span style="color: \\1">\\2</span>'),
 | |
| 			'#\[img\](.*?)\[/img\]#si' => ($xhtml ? '<img class="forum-image" style="max-width:550px; max-height; 550px;" src="\\1" border="0" alt="" />' : '<img class="forum-image" style="max-width:550px; max-height; 550px;" src="\\1" border="0" alt="">'),
 | |
| 			'#\[url=(.*?)\](.*?)\[/url\]#si' => '<a href="\\1" title="\\2">\\2</a>',
 | |
| //		'#\[email\](.*?)\[/email\]#si' => '<a href="mailto:\\1" title="Email \\1">\\1</a>',
 | |
| 			'#\[code\](.*?)\[/code\]#si' => '<code>\\1</code>',
 | |
| //		'#\[align=(.*?)\](.*?)\[/align\]#si' => ($xhtml ? '<div style="text-align: \\1;">\\2</div>' : '<div align="\\1">\\2</div>'),
 | |
| //		'#\[br\]#si' => ($xhtml ? '<br style="clear: both;" />' : '<br>'),
 | |
| 		);
 | |
| 
 | |
| 		foreach($tags as $search => $replace)
 | |
| 			$text = preg_replace($search, $replace, $text);
 | |
| 
 | |
| 		return ($smiles ? Forum::parseSmiles($text) : $text);
 | |
| 	}
 | |
| 
 | |
| 	public static function showPost($topic, $text, $smiles = true, $html = false)
 | |
| 	{
 | |
| 		if($html) {
 | |
| 			return '<b>' . $topic . '</b><hr />' . $text;
 | |
| 		}
 | |
| 
 | |
| 		$post = '';
 | |
| 		if(!empty($topic))
 | |
| 			$post .= '<b>'.($smiles ? self::parseSmiles($topic) : $topic).'</b><hr />';
 | |
| 
 | |
| 		$post .= self::parseBBCode(nl2br($text), $smiles);
 | |
| 		return $post;
 | |
| 	}
 | |
| 
 | |
| 	public static function hasAccess($board_id) {
 | |
| 		global $sections, $logged, $account_logged, $logged_access;
 | |
| 		if(!isset($sections[$board_id]))
 | |
| 			return false;
 | |
| 
 | |
| 		$hasAccess = true;
 | |
| 		$section = $sections[$board_id];
 | |
| 		if($section['guild'] > 0) {
 | |
| 			if($logged) {
 | |
| 				$guild = new OTS_Guild();
 | |
| 				$guild->load($section['guild']);
 | |
| 				$status = false;
 | |
| 				if($guild->isLoaded()) {
 | |
| 					$account_players = $account_logged->getPlayers();
 | |
| 					foreach ($account_players as $player) {
 | |
| 						if($guild->hasMember($player)) {
 | |
| 							$status = true;
 | |
| 						}
 | |
| 					}
 | |
| 				}
 | |
| 
 | |
| 				if (!$status) $hasAccess = false;
 | |
| 			}
 | |
| 			else {
 | |
| 				$hasAccess = false;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if($section['access'] > 0) {
 | |
| 			if($logged_access < $section['access']) {
 | |
| 				$hasAccess = false;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		return $hasAccess;
 | |
| 	}
 | |
| }
 | |
| ?>
 | 
