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
283 lines
8.9 KiB
PHP
283 lines
8.9 KiB
PHP
<?php
|
|
require_once 'common.php';
|
|
require_once SYSTEM . 'functions.php';
|
|
require_once SYSTEM . 'init.php';
|
|
require_once SYSTEM . 'status.php';
|
|
|
|
# error function
|
|
function sendError($message, $code = 3){
|
|
$ret = [];
|
|
$ret['errorCode'] = $code;
|
|
$ret['errorMessage'] = $message;
|
|
die(json_encode($ret));
|
|
}
|
|
|
|
# event schedule function
|
|
function parseEvent($table1, $date, $table2)
|
|
{
|
|
if ($table1) {
|
|
if ($date) {
|
|
if ($table2) {
|
|
$date = $table1->getAttribute('startdate');
|
|
return date_create("{$date}")->format('U');
|
|
} else {
|
|
$date = $table1->getAttribute('enddate');
|
|
return date_create("{$date}")->format('U');
|
|
}
|
|
} else {
|
|
foreach($table1 as $attr) {
|
|
if ($attr) {
|
|
return $attr->getAttribute($table2);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return 'error';
|
|
}
|
|
|
|
$request = json_decode(file_get_contents('php://input'));
|
|
$action = $request->type ?? '';
|
|
|
|
/** @var OTS_Base_DB $db */
|
|
/** @var array $config */
|
|
|
|
switch ($action) {
|
|
case 'cacheinfo':
|
|
$playersonline = $db->query("select count(*) from `players_online`")->fetchAll();
|
|
die(json_encode([
|
|
'playersonline' => (intval($playersonline[0][0])),
|
|
'twitchstreams' => 0,
|
|
'twitchviewer' => 0,
|
|
'gamingyoutubestreams' => 0,
|
|
'gamingyoutubeviewer' => 0
|
|
]));
|
|
|
|
case 'eventschedule':
|
|
$eventlist = [];
|
|
$file_path = config('server_path') . 'data/XML/events.xml';
|
|
if (!file_exists($file_path)) {
|
|
die(json_encode([]));
|
|
}
|
|
$xml = new DOMDocument;
|
|
$xml->load($file_path);
|
|
$tmplist = [];
|
|
$tableevent = $xml->getElementsByTagName('event');
|
|
|
|
foreach ($tableevent as $event) {
|
|
if ($event) { $tmplist = [
|
|
'colorlight' => parseEvent($event->getElementsByTagName('colors'), false, 'colorlight'),
|
|
'colordark' => parseEvent($event->getElementsByTagName('colors'), false, 'colordark'),
|
|
'description' => parseEvent($event->getElementsByTagName('description'), false, 'description'),
|
|
'displaypriority' => intval(parseEvent($event->getElementsByTagName('details'), false, 'displaypriority')),
|
|
'enddate' => intval(parseEvent($event, true, false)),
|
|
'isseasonal' => getBoolean(intval(parseEvent($event->getElementsByTagName('details'), false, 'isseasonal'))),
|
|
'name' => $event->getAttribute('name'),
|
|
'startdate' => intval(parseEvent($event, true, true)),
|
|
'specialevent' => intval(parseEvent($event->getElementsByTagName('details'), false, 'specialevent'))
|
|
];
|
|
$eventlist[] = $tmplist; } }
|
|
die(json_encode(['eventlist' => $eventlist, 'lastupdatetimestamp' => time()]));
|
|
|
|
case 'boostedcreature':
|
|
$boostDB = $db->query("select * from " . $db->tableName('boosted_creature'))->fetchAll();
|
|
foreach ($boostDB as $Tableboost) {
|
|
die(json_encode([
|
|
'boostedcreature' => true,
|
|
'raceid' => intval($Tableboost['raceid'])
|
|
]));
|
|
}
|
|
break;
|
|
|
|
case 'login':
|
|
|
|
$port = $config['lua']['gameProtocolPort'];
|
|
|
|
// default world info
|
|
$world = [
|
|
'id' => 0,
|
|
'name' => $config['lua']['serverName'],
|
|
'externaladdress' => $config['lua']['ip'],
|
|
'externalport' => $port,
|
|
'externaladdressprotected' => $config['lua']['ip'],
|
|
'externalportprotected' => $port,
|
|
'externaladdressunprotected' => $config['lua']['ip'],
|
|
'externalportunprotected' => $port,
|
|
'previewstate' => 0,
|
|
'location' => 'BRA', // BRA, EUR, USA
|
|
'anticheatprotection' => false,
|
|
'pvptype' => array_search($config['lua']['worldType'], ['pvp', 'no-pvp', 'pvp-enforced']),
|
|
'istournamentworld' => false,
|
|
'restrictedstore' => false,
|
|
'currenttournamentphase' => 2
|
|
];
|
|
|
|
$characters = [];
|
|
$account = new OTS_Account();
|
|
|
|
$inputEmail = $request->email ?? false;
|
|
$inputAccountName = $request->accountname ?? false;
|
|
$inputToken = $request->token ?? false;
|
|
|
|
if ($inputEmail != false) { // login by email
|
|
$account->findByEmail($request->email);
|
|
}
|
|
else if($inputAccountName != false) { // login by account name
|
|
$account->find($inputAccountName);
|
|
}
|
|
|
|
$current_password = encrypt((USE_ACCOUNT_SALT ? $account->getCustomField('salt') : '') . $request->password);
|
|
|
|
if (!$account->isLoaded() || $account->getPassword() != $current_password) {
|
|
sendError(($inputEmail != false ? 'Email' : 'Account name') . ' or password is not correct.');
|
|
}
|
|
|
|
//log_append('test.log', var_export($account->getCustomField('secret'), true));
|
|
$accountHasSecret = false;
|
|
if (fieldExist('secret', 'accounts')) {
|
|
$accountSecret = $account->getCustomField('secret');
|
|
if ($accountSecret != null && $accountSecret != '') {
|
|
$accountHasSecret = true;
|
|
if ($inputToken === false) {
|
|
sendError('Submit a valid two-factor authentication token.', 6);
|
|
} else {
|
|
require_once LIBS . 'rfc6238.php';
|
|
if (TokenAuth6238::verify($accountSecret, $inputToken) !== true) {
|
|
sendError('Two-factor authentication failed, token is wrong.', 6);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// common columns
|
|
$columns = 'id, name, level, sex, vocation, looktype, lookhead, lookbody, looklegs, lookfeet, lookaddons';
|
|
|
|
if (fieldExist('isreward', 'accounts')) {
|
|
$columns .= ', isreward';
|
|
}
|
|
|
|
if (fieldExist('istutorial', 'accounts')) {
|
|
$columns .= ', istutorial';
|
|
}
|
|
|
|
$players = $db->query("select {$columns} from players where account_id = " . $account->getId() . " AND deletion = 0");
|
|
if($players && $players->rowCount() > 0) {
|
|
$players = $players->fetchAll();
|
|
|
|
$highestLevelId = 0;
|
|
$highestLevel = 0;
|
|
foreach ($players as $player) {
|
|
if ($player['level'] >= $highestLevel) {
|
|
$highestLevel = $player['level'];
|
|
$highestLevelId = $player['id'];
|
|
}
|
|
}
|
|
|
|
foreach ($players as $player) {
|
|
$characters[] = create_char($player, $highestLevelId);
|
|
}
|
|
}
|
|
|
|
if (fieldExist('premdays', 'accounts') && fieldExist('lastday', 'accounts')) {
|
|
$save = false;
|
|
$timeNow = time();
|
|
$query = $db->query("select `premdays`, `lastday` from `accounts` where `id` = " . $account->getId());
|
|
if ($query->rowCount() > 0) {
|
|
$query = $query->fetch();
|
|
$premDays = (int)$query['premdays'];
|
|
$lastDay = (int)$query['lastday'];
|
|
$lastLogin = $lastDay;
|
|
} else {
|
|
sendError("Error while fetching your account data. Please contact admin.");
|
|
}
|
|
if ($premDays != 0 && $premDays != PHP_INT_MAX) {
|
|
if ($lastDay == 0) {
|
|
$lastDay = $timeNow;
|
|
$save = true;
|
|
} else {
|
|
$days = (int)(($timeNow - $lastDay) / 86400);
|
|
if ($days > 0) {
|
|
if ($days >= $premDays) {
|
|
$premDays = 0;
|
|
$lastDay = 0;
|
|
} else {
|
|
$premDays -= $days;
|
|
$reminder = ($timeNow - $lastDay) % 86400;
|
|
$lastDay = $timeNow - $reminder;
|
|
}
|
|
|
|
$save = true;
|
|
}
|
|
}
|
|
} else if ($lastDay != 0) {
|
|
$lastDay = 0;
|
|
$save = true;
|
|
}
|
|
if ($save) {
|
|
$db->query("update `accounts` set `premdays` = " . $premDays . ", `lastday` = " . $lastDay . " where `id` = " . $account->getId());
|
|
}
|
|
}
|
|
|
|
$worlds = [$world];
|
|
$playdata = compact('worlds', 'characters');
|
|
|
|
$sessionKey = ($inputEmail !== false) ? $inputEmail : $inputAccountName; // email or account name
|
|
$sessionKey .= "\n" . $request->password; // password
|
|
if (!fieldExist('istutorial', 'players')) {
|
|
$sessionKey .= "\n";
|
|
}
|
|
$sessionKey .= ($accountHasSecret && strlen($accountSecret) > 5) ? $inputToken : '';
|
|
|
|
// this is workaround to distinguish between TFS 1.x and otservbr
|
|
// TFS 1.x requires the number in session key
|
|
// otservbr requires just login and password
|
|
// so we check for istutorial field which is present in otservbr, and not in TFS
|
|
if (!fieldExist('istutorial', 'players')) {
|
|
$sessionKey .= "\n".floor(time() / 30);
|
|
}
|
|
|
|
//log_append('slaw.log', $sessionKey);
|
|
|
|
$session = [
|
|
'sessionkey' => $sessionKey,
|
|
'lastlogintime' => 0,
|
|
'ispremium' => $config['lua']['freePremium'] || $account->isPremium(),
|
|
'premiumuntil' => ($account->getPremDays()) > 0 ? (time() + ($account->getPremDays() * 86400)) : 0,
|
|
'status' => 'active', // active, frozen or suspended
|
|
'returnernotification' => false,
|
|
'showrewardnews' => true,
|
|
'isreturner' => true,
|
|
'fpstracking' => false,
|
|
'optiontracking' => false,
|
|
'tournamentticketpurchasestate' => 0,
|
|
'emailcoderequest' => false
|
|
];
|
|
die(json_encode(compact('session', 'playdata')));
|
|
|
|
default:
|
|
sendError("Unrecognized event {$action}.");
|
|
break;
|
|
}
|
|
|
|
function create_char($player, $highestLevelId) {
|
|
global $config;
|
|
return [
|
|
'worldid' => 0,
|
|
'name' => $player['name'],
|
|
'ismale' => intval($player['sex']) === 1,
|
|
'tutorial' => isset($player['istutorial']) && $player['istutorial'],
|
|
'level' => intval($player['level']),
|
|
'vocation' => $config['vocations'][$player['vocation']],
|
|
'outfitid' => intval($player['looktype']),
|
|
'headcolor' => intval($player['lookhead']),
|
|
'torsocolor' => intval($player['lookbody']),
|
|
'legscolor' => intval($player['looklegs']),
|
|
'detailcolor' => intval($player['lookfeet']),
|
|
'addonsflags' => intval($player['lookaddons']),
|
|
'ishidden' => isset($player['deletion']) && (int)$player['deletion'] === 1,
|
|
'istournamentparticipant' => false,
|
|
'ismaincharacter' => $highestLevelId == $player['id'],
|
|
'dailyrewardstate' => isset($player['isreward']) ? intval($player['isreward']) : 0,
|
|
'remainingdailytournamentplaytime' => 0
|
|
];
|
|
}
|