[LIB][Util] Change methods in the Common class to camelCase, add isSystemPath (previously in Nickname.php)

This commit is contained in:
Hugo Sales 2020-07-21 21:35:10 +00:00 committed by Hugo Sales
parent d5b5d97bc1
commit df60e72fb3

View File

@ -31,6 +31,7 @@
namespace App\Util; namespace App\Util;
use App\Core\DB\DB; use App\Core\DB\DB;
use App\Core\Router;
abstract class Common abstract class Common
{ {
@ -45,7 +46,7 @@ abstract class Common
/** /**
* Set sysadmin's configuration preferences for GNU social * Set sysadmin's configuration preferences for GNU social
*/ */
public static function set_config(string $section, string $setting, mixed $value): void public static function setConfig(string $section, string $setting, mixed $value): void
{ {
$ojb = DB::getPartialReference('config', ['section' => $section, 'setting' => $setting]); $ojb = DB::getPartialReference('config', ['section' => $section, 'setting' => $setting]);
$obj->setValue(serialize($value)); $obj->setValue(serialize($value));
@ -53,6 +54,38 @@ abstract class Common
DB::flush(); DB::flush();
} }
/**
* Is the given string identical to a system path or route?
* This could probably be put in some other class, but at
* at the moment, only Nickname requires this functionality.
*/
public static function isSystemPath(string $str): bool
{
$paths = [];
// All directory and file names in site root should be blacklisted
$d = dir(PUBLICDIR);
while (false !== ($entry = $d->read())) {
$paths[$entry] = true;
}
$d->close();
// All top level names in the router should be blocked
$router = Router::get();
foreach ($router->m->getPaths() as $path) {
if (preg_match('/^([^\/\?]+)[\/\?]/', $path, $matches) && isset($matches[1])) {
$paths[$matches[1]] = true;
}
}
// FIXME: this assumes the 'path' is in the first-level directory, though common it's not certain
foreach (['avatar', 'attachments'] as $cat) {
$paths[basename(common_config($cat, 'path'))] = true;
}
return in_array($str, array_keys($paths));
}
/** /**
* An internal helper function that converts a $size from php.ini for * An internal helper function that converts a $size from php.ini for
* file size limit from the 'human-readable' shorthand into a int. If * file size limit from the 'human-readable' shorthand into a int. If
@ -61,7 +94,7 @@ abstract class Common
* *
* @return int the php.ini upload limit in machine-readable format * @return int the php.ini upload limit in machine-readable format
*/ */
public static function size_str_to_int(string $size): int public static function sizeStrToInt(string $size): int
{ {
// `memory_limit` can be -1 and `post_max_size` can be 0 // `memory_limit` can be -1 and `post_max_size` can be 0
// for unlimited. Consistency. // for unlimited. Consistency.
@ -96,12 +129,12 @@ abstract class Common
* *
* @return int * @return int
*/ */
public static function get_preferred_php_upload_limit(): int public static function getPreferredPhpUploadLimit(): int
{ {
return min( return min(
self::size_str_to_int(ini_get('post_max_size')), self::sizeStrToInt(ini_get('post_max_size')),
self::size_str_to_int(ini_get('upload_max_filesize')), self::sizeStrToInt(ini_get('upload_max_filesize')),
self::size_str_to_int(ini_get('memory_limit')) self::sizeStrToInt(ini_get('memory_limit'))
); );
} }
} }