TrackManiaControl/application/ManiaControl.php

118 lines
3.3 KiB
PHP
Raw Normal View History

2013-11-09 11:19:21 +01:00
<?php
// Run configuration
define('LOG_WRITE_CURRENT_FILE', 'ManiaControl.log'); // Write current log to extra file in base dir
define('LOG_NAME_USE_DATE', true); // Use current date as suffix for log file name in logs folder
define('LOG_NAME_USE_PID', true); // Use current process id as suffix for log file name in logs folder
2014-05-02 17:50:30 +02:00
// Define base dir
2014-05-03 21:37:28 +02:00
define('ManiaControlDir', __DIR__ . DIRECTORY_SEPARATOR);
2013-11-09 11:19:21 +01:00
2014-05-03 22:30:38 +02:00
// Enable error reporting
error_reporting(E_ALL);
2014-03-19 11:11:25 +01:00
// Define fatal error level
define('E_FATAL', E_ERROR | E_CORE_ERROR | E_COMPILE_ERROR | E_RECOVERABLE_ERROR | E_USER_ERROR);
2013-11-09 11:19:21 +01:00
// Set process settings
ini_set('memory_limit', '64M');
2013-11-09 11:19:21 +01:00
if (function_exists('date_default_timezone_get') && function_exists('date_default_timezone_set')) {
date_default_timezone_set(@date_default_timezone_get());
}
// Build log file name
2014-05-03 21:37:28 +02:00
$logFileName = ManiaControlDir . 'logs' . DIRECTORY_SEPARATOR;
if (!is_dir($logFileName)) {
mkdir($logFileName);
}
2014-03-19 11:11:25 +01:00
$logFileName .= 'ManiaControl';
if (LOG_NAME_USE_DATE) {
$logFileName .= '_' . date('Y-m-d');
}
if (LOG_NAME_USE_PID) {
$logFileName .= '_' . getmypid();
}
$logFileName .= '.log';
define('LOG_FILE', $logFileName);
2013-11-09 11:19:21 +01:00
// Delete old current log file
if (LOG_WRITE_CURRENT_FILE) {
2014-05-03 21:37:28 +02:00
$currentLogFileName = ManiaControlDir . LOG_WRITE_CURRENT_FILE;
if (file_exists($currentLogFileName) && is_writable($currentLogFileName)) {
unlink($currentLogFileName);
}
define('LOG_CURRENT_FILE', $currentLogFileName);
}
logMessage('Starting ManiaControl ...');
/**
* Checking if all the needed libraries are installed.
* - MySQLi
* - cURL
*/
logMessage('Checking for installed MySQLi ... ', false);
2014-04-13 13:11:19 +02:00
if (extension_loaded('mysqli')) {
logMessage('FOUND!');
2014-05-02 17:50:30 +02:00
} else {
logMessage('NOT FOUND!');
logMessage(' -- You don\'t have MySQLi installed, make sure to check: http://www.php.net/manual/en/mysqli.installation.php');
exit();
}
logMessage('Checking for installed cURL ... ', false);
2014-05-01 20:18:55 +02:00
if (extension_loaded('curl')) {
logMessage('FOUND!');
2014-05-02 17:50:30 +02:00
} else {
logMessage('NOT FOUND!');
logMessage('You don\'t have cURL installed, make sure to check: http://www.php.net/manual/en/curl.installation.php');
exit();
}
2013-12-14 23:30:51 +01:00
/**
* Log and echo the given text
2014-05-02 17:50:30 +02:00
*
2013-12-14 23:30:51 +01:00
* @param string $message
2014-05-02 17:50:30 +02:00
* @param bool $eol
2013-12-14 23:30:51 +01:00
*/
function logMessage($message, $eol = true) {
2014-05-03 21:37:28 +02:00
$date = date('d.M y H:i:s');
2014-05-01 20:18:55 +02:00
$message = $date . ' ' . $message;
if ($eol) {
$message .= PHP_EOL;
}
if (defined('LOG_CURRENT_FILE')) {
2014-03-19 11:11:25 +01:00
if (!file_put_contents(LOG_CURRENT_FILE, $message, FILE_APPEND)) {
2014-05-03 21:37:28 +02:00
echo 'Logfile not write-able, please check the File Permissions!';
2014-03-13 18:47:40 +01:00
}
}
2014-03-19 11:11:25 +01:00
if (!file_put_contents(LOG_FILE, $message, FILE_APPEND)) {
2014-05-03 21:37:28 +02:00
echo 'Logfile not write-able, please check the File Permissions!';
}
echo $message;
}
2013-11-09 11:19:21 +01:00
2014-01-27 09:07:25 +01:00
// Autoload Function that loads ManiaControl Class Files on Demand
2014-05-01 20:18:55 +02:00
spl_autoload_register(function ($className) {
$classPath = str_replace('\\', DIRECTORY_SEPARATOR, $className);
2014-05-02 17:50:30 +02:00
2014-05-01 20:18:55 +02:00
// Core file
$classDirectoryPath = preg_replace('/ManiaControl/', 'core', $classPath, 1);
2014-05-03 21:37:28 +02:00
$filePath = ManiaControlDir . $classDirectoryPath . '.php';
2014-05-01 20:18:55 +02:00
if (file_exists($filePath)) {
require_once $filePath;
return;
}
2014-05-02 17:50:30 +02:00
2014-05-01 20:18:55 +02:00
// Plugin file
2014-05-03 21:37:28 +02:00
$filePath = ManiaControlDir . 'plugins'.DIRECTORY_SEPARATOR . $classPath . '.php';
2014-05-01 20:18:55 +02:00
if (file_exists($filePath)) {
require_once $filePath;
return;
}
});
2014-01-27 09:07:25 +01:00
// Start ManiaControl
2014-01-27 09:07:25 +01:00
$maniaControl = new \ManiaControl\ManiaControl();
$maniaControl->run();