EngineGP/system/library/games/rust/action.php
Sergei Solovev 276ec7f3eb Updating the server name reference in code
This change replaces the use of $_SERVER['SERVER_NAME'] with $_SERVER['HTTP_HOST'] throughout the codebase. The modification ensures consistency and compliance with best practices, since $_SERVER['HTTP_HOST'] is often used to extract the host header from an HTTP request. This update may improve compatibility and security, especially in scenarios where the Host header plays a key role in proper server configuration and routing. Please review and test the changes carefully to ensure smooth functionality in different environments.
2023-12-23 04:50:14 +03:00

295 lines
14 KiB
PHP
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
if (!DEFINED('EGP'))
exit(header('Refresh: 0; URL=http://' . $_SERVER['HTTP_HOST'] . '/404'));
include(LIB . 'games/actions.php');
class action extends actions
{
public static function start($id, $type = 'start')
{
global $cfg, $sql, $user, $start_point;
$sql->query('SELECT `uid`, `unit`, `tarif`, `game`, `address`, `slots_start`, `name`, `tickrate`, `map_start`, `vac`, `time_start`, `core_fix`, `pingboost` FROM `servers` WHERE `id`="' . $id . '" LIMIT 1');
$server = $sql->get();
$sql->query('SELECT `install` FROM `tarifs` WHERE `id`="' . $server['tarif'] . '" LIMIT 1');
$tarif = $sql->get();
include(LIB . 'ssh.php');
$sql->query('SELECT `address`, `passwd` FROM `units` WHERE `id`="' . $server['unit'] . '" LIMIT 1');
$unit = $sql->get();
// Проверка ssh соедниения пу с локацией
if (!$ssh->auth($unit['passwd'], $unit['address']))
return array('e' => sys::text('error', 'ssh'));
list($ip, $port) = explode(':', $server['address']);
// Убить процессы
$ssh->set('kill -9 `ps aux | grep s_' . $server['uid'] . ' | grep -v grep | awk ' . "'{print $2}'" . ' | xargs;'
. 'lsof -i@' . $server['address'] . ' | awk ' . "'{print $2}'" . ' | grep -v PID | xargs`; sudo -u server' . $server['uid'] . ' screen -wipe');
$taskset = '';
// Если включена система автораспределения и не установлен фиксированный поток
if ($cfg['cpu_route'] and !$server['core_fix']) {
$proc_stat = array();
$proc_stat[0] = $ssh->get('cat /proc/stat');
}
// Проверка наличия стартовой карты
$ssh->set('cd ' . $tarif['install'] . $server['uid'] . '/game/csgo/maps/ && du -ah | grep -e "\.vpk$" | awk \'{print $2}\'');
include_once(LIB . 'games/games.php');
if (games::map2($server['map_start'], $ssh->get()))
return array('e' => sys::updtext(sys::text('servers', 'nomap'), array('map' => $server['map_start'] . '.vpk')));
// Если система автораспределения продолжить парсинг загрузки процессора
if (isset($proc_stat)) {
$proc_stat[1] = $ssh->get('cat /proc/stat');
// Ядро/поток, на котором будет запущен игровой сервер (поток выбран с рассчетом наименьшей загруженности в момент запуска игрового сервера)
$core = sys::cpu_idle($proc_stat, $server['unit'], false); // число от 1 до n (где n число ядер/потоков в процессоре (без нулевого)
if (!is_numeric($core))
return array('e' => sys::text('error', 'cpu'));
$taskset = 'taskset -c ' . $core;
}
if ($server['core_fix']) {
$core = $server['core_fix'] - 1;
$taskset = 'taskset -c ' . $core;
}
// Античит VAC
$vac = $server['vac'] == 0 ? '-insecure' : '-secure';
// Боты
$bots = $cfg['bots'][$server['game']] ? '' : '-nobots';
// TV
$tv = isset($server['tv']) ? '+tv_enable 1 +tv_maxclients 30 +tv_port ' . ($port + 10000) : '-nohltv';
$check = explode('/', $server['map_start']);
// Стартовая карта
$map = $check[0] == 'workshop' ? '+workshop_start_map ' . $check[1] : '+map \'' . $server['map_start'] . '\'';
// Игровой режим
$mods = array(
1 => '+game_type 0 +game_mode 0',
2 => '+game_type 0 +game_mode 1',
3 => '+game_type 1 +game_mode 0',
4 => '+game_type 1 +game_mode 1',
5 => '+game_type 1 +game_mode 2'
);
$mod = !$server['pingboost'] ? $mods[2] : $mods[$server['pingboost']];
// Параметры запуска
$bash = './RustDedicated -dedicated -debug -norestart -condebug console.log -usercon -ip ' . $ip . ' -port ' . $port . ' -maxplayers ' . $server['slots_start'] . ' -tickrate ' . $server['tickrate'] . ' ' . $mod . ' +servercfgfile server.cfg ' . $map . ' ' . $vac . ' ' . $bots . ' ' . $tv;
// Временный файл
$temp = sys::temp($bash);
// Обновление файла start.sh
$ssh->setfile($temp, $tarif['install'] . $server['uid'] . '/start.sh', 0500);
// Строка запуска
$ssh->set('cd ' . $tarif['install'] . $server['uid'] . ';' // переход в директорию игрового сервера
. 'rm *.pid;' // Удаление *.pid файлов
. 'sudo -u server' . $server['uid'] . ' mkdir -p game/csgo/oldstart;' // Создание папки логов
. 'cat game/csgo/console.log >> game/csgo/oldstart/' . date('d.m.Y_H:i:s', $server['time_start']) . '.log; rm game/csgo/console.log; rm game/csgo/oldstart/01.01.1970_03:00:00.log;' // Перемещение лога предыдущего запуска
. 'chown server' . $server['uid'] . ':1000 start.sh;' // Обновление владельца файла start.sh
. 'sudo -u server' . $server['uid'] . ' screen -dmS s_' . $server['uid'] . ' ' . $taskset . ' sh -c "./start.sh"'); // Запуск игровго сервера
$core = !isset($core) ? 0 : $core + 1;
// Обновление информации в базе
$sql->query('UPDATE `servers` set `status`="' . $type . '", `online`="0", `players`="", `core_use`="' . $core . '", `time_start`="' . $start_point . '", `stop`="1" WHERE `id`="' . $id . '" LIMIT 1');
unlink($temp);
// Сброс кеша
actions::clmcache($id);
sys::reset_mcache('server_scan_mon_pl_' . $id, $id, array('name' => $server['name'], 'game' => $server['game'], 'status' => $type, 'online' => 0, 'players' => ''));
sys::reset_mcache('server_scan_mon_' . $id, $id, array('name' => $server['name'], 'game' => $server['game'], 'status' => $type, 'online' => 0));
return array('s' => 'ok');
}
public static function change($id, $map = false)
{
global $cfg, $sql, $html, $user, $mcache;
// Если в кеше есть карты
if ($mcache->get('server_maps_change_' . $id) != '' and !$map)
return array('maps' => $mcache->get('server_maps_change_' . $id));
include(LIB . 'ssh.php');
include(LIB . 'games/games.php');
$sql->query('SELECT `uid`, `unit`, `game`, `tarif`, `online`, `players`, `name` FROM `servers` WHERE `id`="' . $id . '" LIMIT 1');
$server = $sql->get();
$sql->query('SELECT `address`, `passwd` FROM `units` WHERE `id`="' . $server['unit'] . '" LIMIT 1');
$unit = $sql->get();
$sql->query('SELECT `install` FROM `tarifs` WHERE `id`="' . $server['tarif'] . '" LIMIT 1');
$tarif = $sql->get();
// Проверка ssh соедниения пу с локацией
if (!$ssh->auth($unit['passwd'], $unit['address']))
return array('e' => sys::text('error', 'ssh'));
// Массив карт игрового сервера (папка "maps")
$aMaps = explode("\n", $ssh->get('cd ' . $tarif['install'] . $server['uid'] . '/game/csgo/maps/ && du -ah | grep -e "\.vpk$" | awk \'{print $2}\''));
// Удаление пустого элемента
unset($aMaps[count($aMaps) - 1]);
// Удаление ".vpk"
$aMaps = str_ireplace(array('./', '.vpk'), '', $aMaps);
// Если выбрана карта
if ($map) {
$map = str_replace('|', '/', $map);
// Проверка наличия выбранной карты
if (games::map($map, $aMaps))
return array('e' => sys::updtext(sys::text('servers', 'change'), array('map' => $map . '.vpk')));
// Отправка команды changelevel
$ssh->set('sudo -u server' . $server['uid'] . ' screen -p 0 -S s_' . $server['uid'] . ' -X eval ' . "'stuff \"changelevel " . sys::cmd($map) . "\"\015'");
// Обновление информации в базе
$sql->query('UPDATE `servers` set `status`="change" WHERE `id`="' . $id . '" LIMIT 1');
// Сброс кеша
actions::clmcache($id);
sys::reset_mcache('server_scan_mon_pl_' . $id, $id, array('name' => $server['name'], 'game' => $server['game'], 'status' => 'change', 'online' => $server['online'], 'players' => base64_decode($server['players'])));
sys::reset_mcache('server_scan_mon_' . $id, $id, array('name' => $server['name'], 'game' => $server['game'], 'status' => 'change', 'online' => $server['online']));
return array('s' => 'ok');
}
// Сортировка списка карт
sort($aMaps);
reset($aMaps);
// Генерация списка карт для выбора
foreach ($aMaps as $map) {
$aName = explode('/', $map);
$name = end($aName);
$html->get('change_list', 'sections/servers/cs2');
$html->set('img', file_exists(DIR . '/maps/' . $server['game'] . '/' . $name . '.jpg') ? $cfg['http'] . 'maps/' . $server['game'] . '/' . $name . '.jpg' : $cfg['http'] . 'template/images/status/none.jpg');
$html->set('map', str_replace('/', '|', $map));
$html->set('name', $name);
$html->set('id', $id);
if (count($aName) > 1)
$html->unit('workshop', true);
else
$html->unit('workshop');
$html->pack('maps');
}
// Запись карт в кеш
$mcache->set('server_maps_change_' . $id, $html->arr['maps'], false, 60);
return array('maps' => $html->arr['maps']);
}
public static function update($id)
{
global $cfg, $sql, $user, $start_point;
include(LIB . 'ssh.php');
$sql->query('SELECT `uid`, `unit`, `tarif`, `game`, `name`, `ftp`, `update`, `core_fix` FROM `servers` WHERE `id`="' . $id . '" LIMIT 1');
$server = $sql->get();
// Проверка времени обновления
$update = $server['update'] + $cfg['update'][$server['game']] * 60;
if ($update > $start_point and $user['group'] != 'admin')
return array('e' => sys::updtext(sys::text('servers', 'update'), array('time' => sys::date('max', $update))));
$sql->query('SELECT `address`, `passwd`, `sql_login`, `sql_passwd`, `sql_port`, `sql_ftp` FROM `units` WHERE `id`="' . $server['unit'] . '" LIMIT 1');
$unit = $sql->get();
$sql->query('SELECT `install`, `plugins_install` FROM `tarifs` WHERE `id`="' . $server['tarif'] . '" LIMIT 1');
$tarif = $sql->get();
// Проверка ssh соедниения пу с локацией
if (!$ssh->auth($unit['passwd'], $unit['address']))
return array('e' => sys::text('error', 'ssh'));
$taskset = '';
// Если включена система автораспределения и не установлен фиксированный поток
if ($cfg['cpu_route'] and !$server['core_fix']) {
$proc_stat = array();
$proc_stat[0] = $ssh->get('cat /proc/stat');
}
// Директория игрового сервера
$install = $tarif['install'] . $server['uid'];
// Если система автораспределения продолжить парсинг загрузки процессора
if (isset($proc_stat)) {
$proc_stat[1] = $ssh->get('cat /proc/stat');
// Ядро/поток, на котором будет запущен игровой сервер (поток выбран с рассчетом наименьшей загруженности в момент запуска игрового сервера)
$core = sys::cpu_idle($proc_stat, $server['unit'], false); // число от 1 до n (где n число ядер/потоков в процессоре (без нулевого)
if (!is_numeric($core))
return array('e' => 'Не удается выполнить операцию, нет свободного потока.');
$taskset = 'taskset -c ' . $core;
}
if ($server['core_fix']) {
$core = $server['core_fix'] - 1;
$taskset = 'taskset -c ' . $core;
}
$ssh->set('cd ' . $cfg['steamcmd'] . ' && ' . $taskset . ' screen -dmS u_' . $server['uid'] . ' sh -c "'
. './steamcmd.sh +login anonymous +force_install_dir "' . $install . '" +app_update 730 +quit;'
. 'cd ' . $install . ';'
. 'chown -R server' . $server['uid'] . ':servers .;'
. 'find . -type d -exec chmod 700 {} \;;'
. 'find . -type f -exec chmod 600 {} \;;'
. 'chmod 500 ' . params::$aFileGame[$server['game']] . '"');
$core = !isset($core) ? 0 : $core + 1;
// Обновление информации в базе
$sql->query('UPDATE `servers` set `status`="update", `update`="' . $start_point . '", `core_use`="' . $core . '" WHERE `id`="' . $id . '" LIMIT 1');
// Логирование
$sql->query('INSERT INTO `logs_sys` set `user`="' . $user['id'] . '", `server`="' . $id . '", `text`="' . sys::text('syslogs', 'update') . '", `time`="' . $start_point . '"');
// Сброс кеша
actions::clmcache($id);
sys::reset_mcache('server_scan_mon_pl_' . $id, $id, array('name' => $server['name'], 'game' => $server['game'], 'status' => 'update', 'online' => 0, 'players' => ''));
sys::reset_mcache('server_scan_mon_' . $id, $id, array('name' => $server['name'], 'game' => $server['game'], 'status' => 'update', 'online' => 0));
return array('s' => 'ok');
}
}
?>