mirror of
https://github.com/vichan-devel/vichan.git
synced 2025-01-22 11:23:45 +01:00
Merge pull request #862 from vichan-devel/5.2.0-74compatibility
5.2.0 PHP 7.4 compatibility
This commit is contained in:
commit
32f0cb3a5f
124
inc/lock.php
124
inc/lock.php
@ -1,84 +1,76 @@
|
|||||||
<?php
|
<?php
|
||||||
|
|
||||||
class Locks {
|
class Locks {
|
||||||
private static function filesystem(string $key): Lock|false {
|
private static function filesystem(string $key) {
|
||||||
$key = str_replace('/', '::', $key);
|
$key = str_replace('/', '::', $key);
|
||||||
$key = str_replace("\0", '', $key);
|
$key = str_replace("\0", '', $key);
|
||||||
|
|
||||||
$fd = fopen("tmp/locks/$key", "w");
|
$fd = fopen("tmp/locks/$key", "w");
|
||||||
if ($fd === false) {
|
if ($fd === false) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
return new class($fd) implements Lock {
|
return new class($fd) implements Lock {
|
||||||
// Resources have no type in php.
|
// Resources have no type in PHP.
|
||||||
private mixed $f;
|
private $f;
|
||||||
|
|
||||||
|
public function __construct($fd) {
|
||||||
|
$this->f = $fd;
|
||||||
|
}
|
||||||
|
|
||||||
function __construct($fd) {
|
public function get(bool $nonblock = false) {
|
||||||
$this->f = $fd;
|
$wouldblock = false;
|
||||||
}
|
flock($this->f, LOCK_SH | ($nonblock ? LOCK_NB : 0), $wouldblock);
|
||||||
|
if ($nonblock && $wouldblock) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
public function get(bool $nonblock = false): Lock|false {
|
public function get_ex(bool $nonblock = false) {
|
||||||
$wouldblock = false;
|
$wouldblock = false;
|
||||||
flock($this->f, LOCK_SH | ($nonblock ? LOCK_NB : 0), $wouldblock);
|
flock($this->f, LOCK_EX | ($nonblock ? LOCK_NB : 0), $wouldblock);
|
||||||
if ($nonblock && $wouldblock) {
|
if ($nonblock && $wouldblock) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function get_ex(bool $nonblock = false): Lock|false {
|
public function free() {
|
||||||
$wouldblock = false;
|
flock($this->f, LOCK_UN);
|
||||||
flock($this->f, LOCK_EX | ($nonblock ? LOCK_NB : 0), $wouldblock);
|
return $this;
|
||||||
if ($nonblock && $wouldblock) {
|
}
|
||||||
return false;
|
};
|
||||||
}
|
}
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function free(): Lock {
|
public static function none() {
|
||||||
flock($this->f, LOCK_UN);
|
return new class() implements Lock {
|
||||||
return $this;
|
public function get(bool $nonblock = false) {
|
||||||
}
|
return $this;
|
||||||
};
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
public function get_ex(bool $nonblock = false) {
|
||||||
* No-op. Can be used for mocking.
|
return $this;
|
||||||
*/
|
}
|
||||||
public static function none(): Lock|false {
|
|
||||||
return new class() implements Lock {
|
|
||||||
public function get(bool $nonblock = false): Lock|false {
|
|
||||||
return $this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public function get_ex(bool $nonblock = false): Lock|false {
|
public function free() {
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
public function free(): Lock {
|
public static function get_lock(array $config, string $key) {
|
||||||
return $this;
|
if ($config['lock']['enabled'] == 'fs') {
|
||||||
}
|
return self::filesystem($key);
|
||||||
};
|
} else {
|
||||||
}
|
return self::none();
|
||||||
|
}
|
||||||
public static function get_lock(array $config, string $key): Lock|false {
|
}
|
||||||
if ($config['lock']['enabled'] == 'fs') {
|
|
||||||
return self::filesystem($key);
|
|
||||||
} else {
|
|
||||||
return self::none();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Lock {
|
interface Lock {
|
||||||
// Get a shared lock
|
public function get(bool $nonblock = false);
|
||||||
public function get(bool $nonblock = false): Lock|false;
|
|
||||||
|
|
||||||
// Get an exclusive lock
|
public function get_ex(bool $nonblock = false);
|
||||||
public function get_ex(bool $nonblock = false): Lock|false;
|
|
||||||
|
|
||||||
// Free a lock
|
public function free();
|
||||||
public function free(): Lock;
|
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ use Vichan\Functions\Net;
|
|||||||
defined('TINYBOARD') or exit;
|
defined('TINYBOARD') or exit;
|
||||||
|
|
||||||
// create a hash/salt pair for validate logins
|
// create a hash/salt pair for validate logins
|
||||||
function mkhash(string $username, ?string $password, mixed $salt = false): array|string {
|
function mkhash(string $username, $password = null, $salt = false) {
|
||||||
global $config;
|
global $config;
|
||||||
|
|
||||||
if (!$salt) {
|
if (!$salt) {
|
||||||
@ -79,7 +79,7 @@ function calc_cookie_name(bool $is_https, bool $is_path_jailed, string $base_nam
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function login(string $username, string $password): array|false {
|
function login(string $username, string $password) {
|
||||||
global $mod, $config;
|
global $mod, $config;
|
||||||
|
|
||||||
$query = prepare("SELECT `id`, `type`, `boards`, `password`, `version` FROM ``mods`` WHERE BINARY `username` = :username");
|
$query = prepare("SELECT `id`, `type`, `boards`, `password`, `version` FROM ``mods`` WHERE BINARY `username` = :username");
|
||||||
|
@ -73,7 +73,7 @@ class Queues {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function get_queue(array $config, string $name): Queue|false {
|
public static function get_queue(array $config, string $name) {
|
||||||
if (!isset(self::$queues[$name])) {
|
if (!isset(self::$queues[$name])) {
|
||||||
if ($config['queue']['enabled'] == 'fs') {
|
if ($config['queue']['enabled'] == 'fs') {
|
||||||
$lock = Locks::get_lock($config, $name);
|
$lock = Locks::get_lock($config, $name);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user