215 lines
14 KiB
PHP
215 lines
14 KiB
PHP
<?php
|
|
|
|
require_once (__DIR__ . '/internals/base.php');
|
|
|
|
$URL_RULES =
|
|
[
|
|
[ 'url' => [], 'target' => 'pages/main.php', 'options' => [], ],
|
|
[ 'url' => ['index'], 'target' => 'pages/main.php', 'options' => [], ],
|
|
[ 'url' => ['index.php'], 'target' => 'pages/main.php', 'options' => [], ],
|
|
[ 'url' => ['msmain', 'index'], 'target' => 'pages/main.php', 'options' => [], ],
|
|
[ 'url' => ['about'], 'target' => 'pages/about.php', 'options' => [], ],
|
|
[ 'url' => ['msmain', 'about'], 'target' => 'pages/about.php', 'options' => [], ],
|
|
[ 'url' => ['login'], 'target' => 'pages/login.php', 'options' => [ 'login_target' => '/' ], ],
|
|
[ 'url' => ['logout'], 'target' => 'pages/logout.php', 'options' => [ 'logout_target' => '/' ], ],
|
|
|
|
[ 'url' => ['programs'], 'target' => 'pages/programs_list.php', 'options' => [ 'categoryfilter' => '' ], ],
|
|
[ 'url' => ['programs', 'index'], 'target' => 'pages/programs_list.php', 'options' => [ 'categoryfilter' => '%GET%' ], ],
|
|
[ 'url' => ['programs', 'index'], 'target' => 'pages/programs_list.php', 'options' => [ 'categoryfilter' => '' ], ],
|
|
[ 'url' => ['programs', 'cat', '?{categoryfilter}'], 'target' => 'pages/programs_list.php', 'options' => [ 'categoryfilter' => '%URL%' ], ],
|
|
[ 'url' => ['downloads', 'details.php'], 'target' => 'pages/programs_list.php', 'options' => [ 'categoryfilter' => '' ], ],
|
|
[ 'url' => ['downloads', 'downloads.php'], 'target' => 'pages/programs_list.php', 'options' => [ 'categoryfilter' => '' ], ],
|
|
[ 'url' => ['programs', 'view', '?{id}'], 'target' => 'pages/programs_view.php', 'options' => [ 'id' => '%URL%' ], ],
|
|
[ 'url' => ['programs', 'view'], 'target' => 'pages/programs_view.php', 'options' => [ 'id' => '%GET%' ], ],
|
|
[ 'url' => ['downloads', '?{id}'], 'target' => 'pages/programs_download.php', 'options' => [ 'id' => '%URL%' ], ],
|
|
[ 'url' => ['programs', 'download', '?{id}'], 'target' => 'pages/programs_download.php', 'options' => [ 'id' => '%URL%' ], ],
|
|
[ 'url' => ['programs', 'download'], 'target' => 'pages/programs_download.php', 'options' => [ 'id' => '%GET%' ], ],
|
|
|
|
[ 'url' => ['books'], 'target' => 'pages/books_list.php', 'options' => [], ],
|
|
[ 'url' => ['books', 'list'], 'target' => 'pages/books_list.php', 'options' => [], ],
|
|
[ 'url' => ['books', 'view', '?{id}'], 'target' => 'pages/books_view.php', 'options' => [ 'id' => '%GET%' ], ],
|
|
[ 'url' => ['books', 'view', '?{id}', '*'], 'target' => 'pages/books_view.php', 'options' => [ 'id' => '%URL%' ], ],
|
|
|
|
[ 'url' => ['update.php'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%GET%' ], ],
|
|
[ 'url' => ['update.php', '?{Name}'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%URL%' ], ],
|
|
[ 'url' => ['update'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%GET%' ], ],
|
|
[ 'url' => ['update', '?{Name}'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%URL%' ], ],
|
|
[ 'url' => ['update2'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%GET%' ], ],
|
|
[ 'url' => ['api', 'update'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%GET%' ], ],
|
|
[ 'url' => ['api', 'update', '?{Name}'], 'target' => 'pages/api_updatecheck.php', 'options' => [ '_opt' => 'http', 'Name' => '%URL%' ], ],
|
|
[ 'url' => ['api', 'test'], 'target' => 'pages/api_test.php', 'options' => [ '_opt' => 'http', ], ],
|
|
[ 'url' => ['api', 'setselfadress'], 'target' => 'pages/api_setselfadress.php', 'options' => [ '_opt' => 'http', ], ],
|
|
[ 'url' => ['api', 'statsping'], 'target' => 'pages/api_stats.php', 'options' => [ '_opt' => 'http', 'Name' => '%GET%', 'ClientID' => '%GET%', 'Version' => '%GET%', 'ProviderStr' => '%GET%', 'ProviderID' => '%GET%', 'NoteCount' => '%GET%', ], ],
|
|
[ 'url' => ['api', 'webhook', '${target}'], 'target' => 'pages/api_webhook.php', 'options' => [ '_opt' => 'http', 'target' => '%URL%', 'secret' => '%GET%', ],],
|
|
|
|
[ 'url' => ['admin'], 'target' => 'pages/admin.php', 'options' => [ '_opt' => 'password'], ],
|
|
[ 'url' => ['admin', 'cmd', '?{cmd}'], 'target' => 'pages/admin_cmd.php', 'options' => [ '_opt' => 'password', 'cmd' => '%URL%'], ],
|
|
[ 'url' => ['admin', 'egh', '?{cmd}'], 'target' => 'pages/su_ajax.php', 'options' => [ 'suffix' => 'egh', 'cmd' => '%URL%', 'secret' => '%GET%' ], ],
|
|
|
|
[ 'url' => ['su_ajax', '?{cmd}'], 'target' => 'pages/su_ajax.php', 'options' => [ 'suffix' => '', 'cmd' => '%URL%', 'secret' => '%GET%' ], ],
|
|
[ 'url' => ['su_ajax'], 'target' => 'pages/su_ajax.php', 'options' => [ 'suffix' => '', 'cmd' => '%GET%', 'secret' => '%GET%' ], ],
|
|
|
|
[ 'url' => ['blog'], 'target' => 'pages/blog_list.php', 'options' => [], ],
|
|
[ 'url' => ['log'], 'target' => 'pages/blog_list.php', 'options' => [], ],
|
|
[ 'url' => ['blogpost', 'index'], 'target' => 'pages/blog_list.php', 'options' => [], ],
|
|
[ 'url' => ['blog', '?{id}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '' ], ],
|
|
[ 'url' => ['blog', '?{id}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '' ], ],
|
|
[ 'url' => ['blog', '?{id}', '?{name}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '' ], ],
|
|
[ 'url' => ['blog', '?{id}', '?{name}', '?{subview}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '%URL%' ], ],
|
|
[ 'url' => ['log', '?{id}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '' ], ],
|
|
[ 'url' => ['log', '?{id}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '' ], ],
|
|
[ 'url' => ['log', '?{id}', '?{name}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '' ], ],
|
|
[ 'url' => ['log', '?{id}', '?{name}', '?{subview}'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%URL%', 'subview' => '%URL%' ], ],
|
|
[ 'url' => ['blogpost', 'view'], 'target' => 'pages/blog_view.php', 'options' => [ 'id' => '%GET%', 'subview' => '' ], ],
|
|
|
|
[ 'url' => ['highscores', 'list.php'], 'target' => 'pages/highscores_listentries.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'list'], 'target' => 'pages/highscores_listentries.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'listentries'], 'target' => 'pages/highscores_listentries.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'list.php'], 'target' => 'pages/highscores_listgames.php', 'options' => [ '_opt' => 'http' ], ],
|
|
[ 'url' => ['highscores', 'list'], 'target' => 'pages/highscores_listgames.php', 'options' => [ '_opt' => 'http' ], ],
|
|
[ 'url' => ['highscores', 'listgames'], 'target' => 'pages/highscores_listgames.php', 'options' => [ '_opt' => 'http' ], ],
|
|
[ 'url' => ['highscores', 'insert.php'], 'target' => 'pages/highscores_insert.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%', 'check' => '%GET%', 'name' => '%GET%', 'rand' => '%GET%', 'points' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'insert'], 'target' => 'pages/highscores_insert.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%', 'check' => '%GET%', 'name' => '%GET%', 'rand' => '%GET%', 'points' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'update.php'], 'target' => 'pages/highscores_update.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%', 'check' => '%GET%', 'name' => '%GET%', 'rand' => '%GET%', 'points' => '%GET%', 'nameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'update'], 'target' => 'pages/highscores_update.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%', 'check' => '%GET%', 'name' => '%GET%', 'rand' => '%GET%', 'points' => '%GET%', 'nameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'list_top50.php'], 'target' => 'pages/highscores_top50.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'list_top50'], 'target' => 'pages/highscores_top50.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'getNewID.php'], 'target' => 'pages/highscores_newid.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
[ 'url' => ['highscores', 'newid'], 'target' => 'pages/highscores_newid.php', 'options' => [ '_opt' => 'http', 'gameid' => '%GET%' ], ],
|
|
|
|
[ 'url' => ['404'], 'target' => 'pages/error_404.php', 'options' => [], ],
|
|
];
|
|
|
|
//#############################################################################
|
|
|
|
try {
|
|
InitPHP();
|
|
|
|
if (isProd())
|
|
$requri = $_SERVER['REQUEST_URI'];
|
|
else
|
|
$requri = isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : 'localhost:80/';
|
|
|
|
$parse = parse_url($requri);
|
|
|
|
$path = isset($parse['path']) ? $parse['path'] : '';
|
|
$pathparts = preg_split('@/@', $path, NULL, PREG_SPLIT_NO_EMPTY);
|
|
$partcount = count($pathparts);
|
|
|
|
global $OPTIONS;
|
|
global $HEADER_ACTIVE;
|
|
|
|
$HEADER_ACTIVE = 'none';
|
|
|
|
foreach ($URL_RULES as $rule)
|
|
{
|
|
if ($partcount !== count($rule['url'])) continue;
|
|
|
|
$urlparams = [];
|
|
$opt = key_exists('_opt', $rule['options']) ? explode($rule['options']['_opt'], '|') : [];
|
|
$target = $rule['target'];
|
|
|
|
$match = true;
|
|
for($i = 0; $i < $partcount; $i++)
|
|
{
|
|
$comp = $rule['url'][$i];
|
|
if (startsWith($comp, '?{') && endsWith($comp, '}'))
|
|
{
|
|
$ident = substr($comp, 2, strlen($comp)-3);
|
|
$urlparams[$ident] = $pathparts[$i];
|
|
}
|
|
else if ($comp === '*')
|
|
{
|
|
// ok
|
|
}
|
|
else
|
|
{
|
|
if (strtolower($comp) !== strtolower($pathparts[$i])) { $match = false; break; }
|
|
}
|
|
}
|
|
if (!$match) continue;
|
|
|
|
$opt = [];
|
|
foreach($rule['options'] as $optname => $optvalue)
|
|
{
|
|
$value = $optvalue;
|
|
|
|
if ($value === '%GET%')
|
|
{
|
|
if (!isset($_GET[$optname])) { $match = false; break; }
|
|
$value = $_GET[$optname];
|
|
}
|
|
else if ($value === '%POST%')
|
|
{
|
|
if (!isset($_POST[$optname])) { $match = false; break; }
|
|
$value = $_POST[$optname];
|
|
}
|
|
else if ($value === '%URL%')
|
|
{
|
|
if (!isset($urlparams[$optname])) { $match = false; break; }
|
|
$value = urldecode($urlparams[$optname]);
|
|
}
|
|
|
|
$opt[strtolower($optname)] = $value;
|
|
}
|
|
if (!$match) continue;
|
|
|
|
if (in_array('disabled', $opt)) continue;
|
|
|
|
if (in_array('password', $opt))
|
|
{
|
|
if (!isLoggedInByCookie())
|
|
{
|
|
$opt['login_target'] = $path;
|
|
$target = 'pages/login.php';
|
|
}
|
|
}
|
|
|
|
$is_http = (!isset($_SERVER['HTTPS'])) || empty($_SERVER['HTTPS']) || $_SERVER['HTTPS'] == "off";
|
|
|
|
if ($is_http && !in_array('http', $opt))
|
|
{
|
|
ob_clean();
|
|
$redirect = 'https://' . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI'];
|
|
header('HTTP/1.1 301 Moved Permanently');
|
|
header('Location: ' . $redirect);
|
|
exit();
|
|
}
|
|
|
|
$OPTIONS = $opt;
|
|
include $target;
|
|
return;
|
|
|
|
}
|
|
|
|
{
|
|
// [404] - Page Not Found
|
|
$OPTIONS = [];
|
|
httpError('404', 'Page not found');
|
|
return;
|
|
}
|
|
|
|
} catch (Exception $e) {
|
|
|
|
if (isProd())
|
|
{
|
|
sendExceptionMail($e);
|
|
httpError('500 ', 'Internal server error');
|
|
}
|
|
else
|
|
{
|
|
echo '<table class="xdebug-error xe-uncaught-exception" dir="ltr" border="1" cellspacing="0" cellpadding="1">'.$e->xdebug_message.'</table>';
|
|
}
|
|
|
|
}
|
|
|
|
|
|
//TODO fast
|
|
//TODO gzip (?)
|
|
//TODO better gh widget
|
|
//TODO remove db table prefixes
|
|
//TODO euler insert+show 32bit | 64bit mode
|
|
//TODO send cache header (?)
|
|
//TODO self update (admin+webhook)
|
|
//TODO v4 subdomain+static
|