S2OJ/web/app/models/UOJContext.php

181 lines
4.3 KiB
PHP
Raw Normal View History

2016-07-19 00:39:37 +08:00
<?php
class UOJContext {
2022-11-06 10:26:21 +08:00
public static $meta_default = [
2022-11-12 07:10:34 +08:00
'users_default_permissions' => [
'problems' => [
'view' => true,
'download_testdata' => false,
'create' => false,
'manage' => false,
],
'contests' => [
'view' => true,
'register' => true,
'create' => false,
'start_final_test' => false,
'manage' => false,
],
'lists' => [
'view' => true,
'create' => false,
'manage' => false,
],
'groups' => [
'view' => true,
'create' => false,
'manage' => false,
],
'blogs' => [
'view' => true,
'create' => true,
'manage' => false,
],
'users' => [
'view' => true,
'upload_image' => true,
],
],
'submission_frequency' => [
'interval' => 'PT1S',
'limit' => 1,
],
2022-11-06 10:26:21 +08:00
];
public static $data = [
'type' => 'main'
];
2022-11-12 07:10:34 +08:00
2016-07-19 00:39:37 +08:00
public static function pageConfig() {
2022-11-06 10:26:21 +08:00
switch (self::$data['type']) {
case 'main':
return [
'PageNav' => 'main-nav'
];
case 'blog':
return [
'PageNav' => 'blog-nav',
'PageMainTitle' => UOJUserBlog::id() . '的博客',
'PageMainTitleOnSmall' => '博客',
];
2016-07-19 00:39:37 +08:00
}
}
2022-11-12 07:10:34 +08:00
2016-07-19 00:39:37 +08:00
public static function isAjax() {
return isset($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest';
}
2022-11-12 07:10:34 +08:00
public static function contentLength() {
if (!isset($_SERVER['CONTENT_LENGTH'])) {
return null;
}
return (int)$_SERVER['CONTENT_LENGTH'];
}
2022-11-12 07:10:34 +08:00
2016-07-19 00:39:37 +08:00
public static function documentRoot() {
return $_SERVER['DOCUMENT_ROOT'];
}
public static function storagePath() {
2022-11-12 07:10:34 +08:00
return $_SERVER['DOCUMENT_ROOT'] . '/app/storage';
2016-07-19 00:39:37 +08:00
}
public static function remoteAddr() {
return $_SERVER['REMOTE_ADDR'];
}
2022-11-06 10:26:21 +08:00
public static function httpXForwardedFor() {
return isset($_SERVER['HTTP_X_FORWARDED_FOR']) ? $_SERVER['HTTP_X_FORWARDED_FOR'] : '';
}
public static function httpUserAgent() {
return isset($_SERVER['HTTP_USER_AGENT']) ? $_SERVER['HTTP_USER_AGENT'] : '';
}
2016-07-19 00:39:37 +08:00
public static function requestURI() {
return $_SERVER['REQUEST_URI'];
}
public static function requestPath() {
$uri = $_SERVER['REQUEST_URI'];
$p = strpos($uri, '?');
if ($p === false) {
return $uri;
} else {
return substr($uri, 0, $p);
}
}
public static function requestMethod() {
return $_SERVER['REQUEST_METHOD'];
}
public static function httpHost() {
2022-11-06 10:26:21 +08:00
return isset($_SERVER['HTTP_X_FORWARDED_HOST']) ? $_SERVER['HTTP_X_FORWARDED_HOST'] : (isset($_SERVER['HTTP_HOST']) ? $_SERVER['HTTP_HOST'] : '');
}
public static function requestDomain() {
$http_host = UOJContext::httpHost();
$ret = explode(':', $http_host);
if (!is_array($ret) || count($ret) > 2) {
return '';
}
return $ret[0];
}
public static function isUsingHttps() {
return (isset($_SERVER['HTTPS']) && ($_SERVER['HTTPS'] == 'on' || $_SERVER['HTTPS'] == 1))
|| (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && $_SERVER['HTTP_X_FORWARDED_PROTO'] == 'https')
|| $_SERVER['SERVER_PORT'] == 443;
}
public static function requestPort() {
$http_host = UOJContext::httpHost();
$ret = explode(':', $http_host);
if (!is_array($ret) || count($ret) > 2) {
return -1;
}
if (count($ret) == 1) {
return UOJContext::isUsingHttps() ? 443 : 80;
fix(uoj/1/app/models): session issue caused by wrong cookie domain After we changed the detection of the real httpHost value, the token check will fail when register. A long time ago we just simply added "Session_Start();" at the beginning of uoj/1/app/index.php. It temporally solved the problem but caused another series of issues that we can't see outside. There is also a session_start() when executing Session::init() at importing app/libs/uoj-lib.php. So, when we add one more "Session_Start();" it will execute this one more time, just cause warning: > session_name(): Cannot change session name when session is active > PHP Warning: ini_set(): A session is active. You cannot change the session module's ini settings at this time And, the session name and session path, session domain will not be set so may cause other problems. The reason is that using UOJContext::httpHost() as web hostname when default, it will add the port at the end. When using IP the validateIP() will return false, or using domain with port the cookie domain will be set wrongly. As a result the register process throws out the "Expired" error and refuses to register, and other uses token will fail too. We made it cut out the port when setting cookie domain, and also changed the style of UOJContext::httpHost() to make it easier to read. With this problem known and solved the "Session_Start();" in index.php will also say bye-bye, and there will be no multiple session_start()s. NOTICE: If you have set all your information to yours in .config.php, and not using address with port other than 80, you may not face this problem. But the warning of php will consistently shown in the error log file. So kick the annoying warning information out if you are angry with this ;-)
2018-10-11 18:46:58 +08:00
}
2022-11-06 10:26:21 +08:00
return validateUInt($ret[1]) ? (int)$ret[1] : -1;
2016-07-19 00:39:37 +08:00
}
public static function cookieDomain() {
$domain = UOJConfig::$data['web']['domain'];
if ($domain === null) {
$domain = UOJConfig::$data['web']['main']['host'];
}
2022-11-06 10:26:21 +08:00
if (validateIP($domain) || strpos($domain, '.') === false) {
2016-07-19 00:39:37 +08:00
$domain = '';
} else {
2022-11-12 07:10:34 +08:00
$domain = '.' . $domain;
2016-07-19 00:39:37 +08:00
}
return $domain;
}
2022-11-06 10:26:21 +08:00
public static function hasCDN() {
return isset(UOJConfig::$data['web']['cdn']);
}
public static function type() {
return self::$data['type'];
}
2022-11-12 07:10:34 +08:00
2016-07-19 00:39:37 +08:00
public static function setupBlog() {
2022-11-06 10:26:21 +08:00
UOJUserBlog::init();
2016-07-19 00:39:37 +08:00
self::$data['type'] = 'blog';
}
2022-11-06 10:26:21 +08:00
public static function getMeta($name) {
$value = DB::selectFirst([
"select value from meta",
"where", ['name' => $name]
]);
2022-11-06 10:26:21 +08:00
if ($value === null) {
return self::$meta_default[$name];
} else {
return json_decode($value['value'], true);
2016-07-19 00:39:37 +08:00
}
}
2022-11-06 10:26:21 +08:00
public static function setMeta($name, $value) {
$value = json_encode($value);
2022-11-06 10:26:21 +08:00
return DB::update([
"insert into meta", DB::bracketed_fields(['name', 'value', 'updated_at']),
"values", DB::tuple([$name, $value, DB::now()]),
"on duplicate key update", ['value' => $value]
]);
}
2016-07-19 00:39:37 +08:00
}