mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-10-31 16:06:24 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			122 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			4.0 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Account management
 | |
|  *
 | |
|  * @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!');
 | |
| 
 | |
| $title = 'Account Management';
 | |
| require __DIR__ . '/login.php';
 | |
| require __DIR__ . '/base.php';
 | |
| 
 | |
| if(!$logged) {
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| if(isset($_REQUEST['redirect']))
 | |
| {
 | |
| 	$redirect = urldecode($_REQUEST['redirect']);
 | |
| 
 | |
| 	// should never happen, unless hacker modify the URL
 | |
| 	if (!str_contains($redirect, BASE_URL)) {
 | |
| 		error('Fatal error: Cannot redirect outside the website.');
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	$twig->display('account.redirect.html.twig', array(
 | |
| 		'redirect' => $redirect
 | |
| 	));
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| csrfProtect();
 | |
| 
 | |
| $groups = new OTS_Groups_List();
 | |
| 
 | |
| /**
 | |
|  * @var OTS_Account $account_logged
 | |
|  */
 | |
| $premDays = $account_logged->getPremDays();
 | |
| 
 | |
| $freePremium = isset($config['lua']['freePremium']) && getBoolean($config['lua']['freePremium']) || $premDays == OTS_Account::GRATIS_PREMIUM_DAYS;
 | |
| $dayOrDays = ($premDays == 1 ? 'day' : 'days');
 | |
| 
 | |
| $vipSystemEnabled = isset($config['lua']['vipSystemEnabled']) && getBoolean($config['lua']['vipSystemEnabled']);
 | |
| $premiumLabel = $vipSystemEnabled ? 'VIP' : 'Premium Account';
 | |
| 
 | |
| if ($freePremium && !$vipSystemEnabled) {
 | |
| 	$account_status = '<b><span style="color: green">Gratis Premium Account</span></b>';
 | |
| } else if(!$account_logged->isPremium()) {
 | |
| 	$account_status = '<b><span style="color: red">Free Account</span></b>';
 | |
| } else {
 | |
| 	$account_status = '<b><span style="color: green">' . $premiumLabel . ', ' . $premDays . ' '.$dayOrDays.' left</span></b>';
 | |
| }
 | |
| 
 | |
| $recovery_key = $account_logged->getCustomField('key');
 | |
| if(empty($recovery_key))
 | |
| 	$account_registered = '<b><span style="color: red">No</span></b>';
 | |
| else
 | |
| {
 | |
| 	if(setting('core.account_generate_new_reckey') && setting('core.mail_enabled'))
 | |
| 		$account_registered = '<b><span style="color: green">Yes ( <a href="' . getLink('account/register-new') . '"> Buy new Recovery Key </a> )</span></b>';
 | |
| 	else
 | |
| 		$account_registered = '<b><span style="color: green">Yes</span></b>';
 | |
| }
 | |
| 
 | |
| $account_created = $account_logged->getCreated();
 | |
| $account_email = $account_logged->getEMail();
 | |
| $email_new_time = $account_logged->getCustomField("email_new_time");
 | |
| if($email_new_time > 1)
 | |
| 	$email_new = $account_logged->getCustomField("email_new");
 | |
| $account_rlname = $account_logged->getRLName();
 | |
| $account_location = $account_logged->getLocation();
 | |
| if($account_logged->isBanned())
 | |
| 	if($account_logged->getBanTime() > 0)
 | |
| 		$welcome_message = '<span style="color: red">Your account is banished until '.date("j F Y, G:i:s", $account_logged->getBanTime()).'!</span>';
 | |
| 	else
 | |
| 		$welcome_message = '<span style="color: red">Your account is banished FOREVER!</span>';
 | |
| else
 | |
| 	$welcome_message = 'Welcome to your account!';
 | |
| 
 | |
| $email_change = '';
 | |
| $email_request = false;
 | |
| if($email_new_time > 1)
 | |
| {
 | |
| 	if($email_new_time < time())
 | |
| 		$email_change = '<br>(You can accept <b>'.$email_new.'</b> as a new email.)';
 | |
| 	else
 | |
| 	{
 | |
| 		$email_change = ' <br>You can accept <b>new e-mail after '.date("j F Y", $email_new_time).".</b>";
 | |
| 		$email_request = true;
 | |
| 	}
 | |
| }
 | |
| 
 | |
| $actions = $account_logged->getActionsLog(1000);
 | |
| 
 | |
| /** @var OTS_Players_List $account_players */
 | |
| $account_players = $account_logged->getPlayersList();
 | |
| $account_players->orderBy('id');
 | |
| 
 | |
| $twig->display('account.management.html.twig', array(
 | |
| 	'welcome_message' => $welcome_message,
 | |
| 	'recovery_key' => $recovery_key,
 | |
| 	'email_change' => $email_change,
 | |
| 	'email_request' => $email_request,
 | |
| 	'email_new_time' => $email_new_time,
 | |
| 	'email_new' => isset($email_new) ? $email_new : '',
 | |
| 	'account' => (USE_ACCOUNT_NAME ? $account_logged->getName() : (USE_ACCOUNT_NUMBER ? $account_logged->getNumber() : $account_logged->getId())),
 | |
| 	'account_email' => $account_email,
 | |
| 	'account_created' => $account_created,
 | |
| 	'account_status' => $account_status,
 | |
| 	'account_registered' => $account_registered,
 | |
| 	'account_rlname' => $account_rlname,
 | |
| 	'account_location' => $account_location,
 | |
| 	'actions' => $actions,
 | |
| 	'players' => $account_players
 | |
| ));
 | 
