mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-10-24 22:34:17 +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>
		
			
				
	
	
		
			216 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			216 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| /**
 | |
|  * Account Admin Tool
 | |
|  *
 | |
|  * @package   MyAAC
 | |
|  * @author    Slawkens <slawkens@gmail.com>
 | |
|  * @author    Lee
 | |
|  * @copyright 2020 MyAAC
 | |
|  * @link      https://my-aac.org
 | |
|  */
 | |
| defined('MYAAC') or die('Direct access not allowed!');
 | |
| 
 | |
| $title = 'Mass Account Actions';
 | |
| 
 | |
| $hasCoinsColumn = $db->hasColumn('accounts', 'coins');
 | |
| $hasPointsColumn = $db->hasColumn('accounts', 'premium_points');
 | |
| $freePremium = $config['lua']['freePremium'];
 | |
| 
 | |
| function admin_give_points($points)
 | |
| {
 | |
| 	global $db, $hasPointsColumn;
 | |
| 
 | |
| 	if (!$hasPointsColumn) {
 | |
| 		displayMessage('Points not supported.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	$statement = $db->prepare('UPDATE `accounts` SET `premium_points` = `premium_points` + :points');
 | |
| 	if (!$statement) {
 | |
| 		displayMessage('Failed to prepare query statement.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	if (!$statement->execute([
 | |
| 		'points' => $points
 | |
| 	])) {
 | |
| 		displayMessage('Failed to add points.');
 | |
| 		return;
 | |
| 	}
 | |
| 	displayMessage($points . ' points added to all accounts.', true);
 | |
| }
 | |
| 
 | |
| function admin_give_coins($coins)
 | |
| {
 | |
| 	global $db, $hasCoinsColumn;
 | |
| 
 | |
| 	if (!$hasCoinsColumn) {
 | |
| 		displayMessage('Coins not supported.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	$statement = $db->prepare('UPDATE `accounts` SET `coins` = `coins` + :coins');
 | |
| 	if (!$statement) {
 | |
| 		displayMessage('Failed to prepare query statement.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	if (!$statement->execute([
 | |
| 		'coins' => $coins
 | |
| 	])) {
 | |
| 		displayMessage('Failed to add coins.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	displayMessage($coins . ' coins added to all accounts.', true);
 | |
| }
 | |
| 
 | |
| function query_add_premium($column, $value_query, $condition_query = '1=1', $params = [])
 | |
| {
 | |
| 	global $db;
 | |
| 
 | |
| 	$statement = $db->prepare("UPDATE `accounts` SET `{$column}` = $value_query WHERE $condition_query");
 | |
| 	if (!$statement) {
 | |
| 		displayMessage('Failed to prepare query statement.');
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	if (!$statement->execute($params)) {
 | |
| 		displayMessage('Failed to add premium days.');
 | |
| 		return false;
 | |
| 	}
 | |
| 
 | |
| 	return true;
 | |
| }
 | |
| 
 | |
| function admin_give_premdays($days)
 | |
| {
 | |
| 	global $db, $freePremium;
 | |
| 
 | |
| 	if ($freePremium) {
 | |
| 		displayMessage('Premium days not supported. Free Premium enabled.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	$value = $days * 86400;
 | |
| 	$now = time();
 | |
| 	// othire
 | |
| 	if ($db->hasColumn('accounts', 'premend')) {
 | |
| 		// append premend
 | |
| 		if (query_add_premium('premend', '`premend` + :value', '`premend` > :now', ['value' => $value, 'now' => $now])) {
 | |
| 			// set premend
 | |
| 			if (query_add_premium('premend', ':value', '`premend` <= :now', ['value' => $now + $value, 'now' => $now])) {
 | |
| 				displayMessage($days . ' premium days added to all accounts.', true);
 | |
| 				return;
 | |
| 			} else {
 | |
| 				displayMessage('Failed to execute set query.');
 | |
| 				return;
 | |
| 			}
 | |
| 		} else {
 | |
| 			displayMessage('Failed to execute append query.');
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	// tfs 0.x
 | |
| 	if ($db->hasColumn('accounts', 'premdays')) {
 | |
| 		// append premdays
 | |
| 		if (query_add_premium('premdays', '`premdays` + :value', '1=1', ['value' => $days])) {
 | |
| 			// append lastday
 | |
| 			if (query_add_premium('lastday', '`lastday` + :value', '`lastday` > :now', ['value' => $value, 'now' => $now])) {
 | |
| 				// set lastday
 | |
| 				if (query_add_premium('lastday', ':value', '`lastday` <= :now', ['value' => $now + $value, 'now' => $now])) {
 | |
| 					displayMessage($days . ' premium days added to all accounts.', true);
 | |
| 					return;
 | |
| 				} else {
 | |
| 					displayMessage('Failed to execute set query.');
 | |
| 					return;
 | |
| 				}
 | |
| 
 | |
| 				return;
 | |
| 			} else {
 | |
| 				displayMessage('Failed to execute append query.');
 | |
| 				return;
 | |
| 			}
 | |
| 		} else {
 | |
| 			displayMessage('Failed to execute set days query.');
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	// tfs 1.x
 | |
| 	if ($db->hasColumn('accounts', 'premium_ends_at')) {
 | |
| 		// append premium_ends_at
 | |
| 		if (query_add_premium('premium_ends_at', '`premium_ends_at` + :value', '`premium_ends_at` > :now', ['value' => $value, 'now' => $now])) {
 | |
| 			// set premium_ends_at
 | |
| 			if (query_add_premium('premium_ends_at', ':value', '`premium_ends_at` <= :now', ['value' => $now + $value, 'now' => $now])) {
 | |
| 				displayMessage($days . ' premium days added to all accounts.', true);
 | |
| 				return;
 | |
| 			} else {
 | |
| 				displayMessage('Failed to execute set query.');
 | |
| 				return;
 | |
| 			}
 | |
| 		} else {
 | |
| 			displayMessage('Failed to execute append query.');
 | |
| 			return;
 | |
| 		}
 | |
| 
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	displayMessage('Premium Days not supported.');
 | |
| }
 | |
| 
 | |
| if (isset($_POST['action']) && $_POST['action']) {
 | |
| 
 | |
| 	$action = $_POST['action'];
 | |
| 
 | |
| 	if (preg_match("/[^A-z0-9_\-]/", $action)) {
 | |
| 		displayMessage('Invalid action.');
 | |
| 	} else {
 | |
| 		$value = isset($_POST['value']) ? intval($_POST['value']) : 0;
 | |
| 
 | |
| 		if (!$value) {
 | |
| 			displayMessage('Please fill all inputs');
 | |
| 		} else {
 | |
| 			switch ($action) {
 | |
| 				case 'give-points':
 | |
| 					admin_give_points($value);
 | |
| 					break;
 | |
| 				case 'give-coins':
 | |
| 					admin_give_coins($value);
 | |
| 					break;
 | |
| 				case 'give-premdays':
 | |
| 					admin_give_premdays($value);
 | |
| 					break;
 | |
| 				default:
 | |
| 					displayMessage('Action ' . $action . 'not found.');
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| }
 | |
| else {
 | |
| 	$twig->display('admin.tools.account.html.twig', array(
 | |
| 		'hasCoinsColumn' => $hasCoinsColumn,
 | |
| 		'hasPointsColumn' => $hasPointsColumn,
 | |
| 		'freePremium' => $freePremium,
 | |
| 	));
 | |
| }
 | |
| 
 | |
| function displayMessage($message, $success = false) {
 | |
| 	global $twig, $hasCoinsColumn, $hasPointsColumn, $freePremium;
 | |
| 
 | |
| 	$success ? success($message): error($message);
 | |
| 
 | |
| 	$twig->display('admin.tools.account.html.twig', array(
 | |
| 		'hasCoinsColumn' => $hasCoinsColumn,
 | |
| 		'hasPointsColumn' => $hasPointsColumn,
 | |
| 		'freePremium' => $freePremium,
 | |
| 	));
 | |
| }
 |