mirror of
https://github.com/slawkens/myaac.git
synced 2025-05-01 19:59:21 +02:00

* 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>
151 lines
4.3 KiB
PHP
151 lines
4.3 KiB
PHP
<?php
|
|
defined('MYAAC') or die('Direct access not allowed!');
|
|
|
|
ini_set('max_execution_time', 300);
|
|
if(isset($config['installed']) && $config['installed'] && !isset($_SESSION['saved'])) {
|
|
warning($locale['already_installed']);
|
|
}
|
|
else {
|
|
require SYSTEM . 'init.php';
|
|
if(!$error) {
|
|
if(USE_ACCOUNT_NAME)
|
|
$account = isset($_SESSION['var_account']) ? $_SESSION['var_account'] : null;
|
|
else
|
|
$account_id = isset($_SESSION['var_account_id']) ? $_SESSION['var_account_id'] : null;
|
|
|
|
$password = $_SESSION['var_password'];
|
|
|
|
if(USE_ACCOUNT_SALT)
|
|
{
|
|
$salt = generateRandomString(10, false, true, true);
|
|
$password = $salt . $password;
|
|
}
|
|
|
|
$account_db = new OTS_Account();
|
|
if(isset($account))
|
|
$account_db->find($account);
|
|
else
|
|
$account_db->load($account_id);
|
|
|
|
$player_name = $_SESSION['var_player_name'];
|
|
$player_db = new OTS_Player();
|
|
$player_db->find($player_name);
|
|
|
|
if(!$player_db->isLoaded())
|
|
{
|
|
$player = new OTS_Player();
|
|
$player->setName($player_name);
|
|
|
|
$player_used = &$player;
|
|
}
|
|
else {
|
|
$player_used = &$player_db;
|
|
}
|
|
|
|
$groups = new OTS_Groups_List();
|
|
$player_used->setGroupId($groups->getHighestId());
|
|
|
|
$email = $_SESSION['var_email'];
|
|
if($account_db->isLoaded()) {
|
|
$account_db->setPassword(encrypt($password));
|
|
$account_db->setEMail($email);
|
|
$account_db->save();
|
|
|
|
$account_used = &$account_db;
|
|
}
|
|
else {
|
|
$new_account = new OTS_Account();
|
|
if(USE_ACCOUNT_NAME) {
|
|
$new_account->create($account);
|
|
}
|
|
else {
|
|
$new_account->create(null, $account_id);
|
|
}
|
|
|
|
$new_account->setPassword(encrypt($password));
|
|
$new_account->setEMail($email);
|
|
|
|
$new_account->unblock();
|
|
$new_account->save();
|
|
|
|
$new_account->setCustomField('created', time());
|
|
$new_account->logAction('Account created.');
|
|
|
|
$account_used = &$new_account;
|
|
}
|
|
|
|
if(USE_ACCOUNT_SALT)
|
|
$account_used->setCustomField('salt', $salt);
|
|
|
|
$account_used->setCustomField('web_flags', FLAG_ADMIN + FLAG_SUPER_ADMIN);
|
|
$account_used->setCustomField('country', 'us');
|
|
if($db->hasColumn('accounts', 'group_id'))
|
|
$account_used->setCustomField('group_id', $groups->getHighestId());
|
|
if($db->hasColumn('accounts', 'type'))
|
|
$account_used->setCustomField('type', 6);
|
|
|
|
if(!$player_db->isLoaded())
|
|
$player->setAccountId($account_used->getId());
|
|
else
|
|
$player_db->setAccountId($account_used->getId());
|
|
|
|
success($locale['step_database_created_account']);
|
|
|
|
setSession('account', $account_used->getId());
|
|
setSession('password', encrypt($password));
|
|
setSession('remember_me', true);
|
|
|
|
if($player_db->isLoaded()) {
|
|
$player_db->save();
|
|
}
|
|
else {
|
|
$player->save();
|
|
}
|
|
|
|
$player_id = 0;
|
|
$query = $db->query("SELECT `id` FROM `players` WHERE `name` = " . $db->quote($player_name) . ";");
|
|
if($query->rowCount() == 1) {
|
|
$query = $query->fetch();
|
|
$player_id = $query['id'];
|
|
}
|
|
|
|
$query = $db->query("SELECT `id` FROM `" . TABLE_PREFIX ."news` WHERE `title` LIKE 'Hello!';");
|
|
if($query->rowCount() == 0) {
|
|
if(query("INSERT INTO `" . TABLE_PREFIX ."news` (`id`, `type`, `date`, `category`, `title`, `body`, `player_id`, `comments`, `hidden`) VALUES (NULL, '1', UNIX_TIMESTAMP(), '2', 'Hello!', 'MyAAC is just READY to use!', " . $player_id . ", 'https://my-aac.org', '0');
|
|
INSERT INTO `myaac_news` (`id`, `type`, `date`, `category`, `title`, `body`, `player_id`, `comments`, `hidden`) VALUES (NULL, '2', UNIX_TIMESTAMP(), '4', 'Hello tickets!', 'https://my-aac.org', " . $player_id . ", '', '0');")) {
|
|
success($locale['step_database_created_news']);
|
|
}
|
|
}
|
|
|
|
$twig->display('install.installer.html.twig', array(
|
|
'url' => 'tools/7-finish.php',
|
|
'message' => $locale['importing_spinner']
|
|
));
|
|
|
|
if(!isset($_SESSION['installed'])) {
|
|
$report_url = 'https://my-aac.org/report_install.php?v=' . MYAAC_VERSION . '&b=' . urlencode(BASE_URL);
|
|
if (function_exists('curl_version'))
|
|
{
|
|
$curl = curl_init();
|
|
curl_setopt($curl, CURLOPT_URL, $report_url);
|
|
curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
|
|
curl_exec($curl);
|
|
curl_close($curl);
|
|
}
|
|
else if (ini_get('allow_url_fopen') ) {
|
|
file_get_contents($report_url);
|
|
}
|
|
$_SESSION['installed'] = true;
|
|
}
|
|
|
|
foreach($_SESSION as $key => $value) {
|
|
if(strpos($key, 'var_') !== false)
|
|
unset($_SESSION[$key]);
|
|
}
|
|
unset($_SESSION['saved']);
|
|
if(file_exists(CACHE . 'install.txt')) {
|
|
unlink(CACHE . 'install.txt');
|
|
}
|
|
}
|
|
}
|