mirror of
https://github.com/openvk/openvk
synced 2025-02-02 13:05:37 +03:00
Alexander Minkin
6ec54a379d
* feat(lint): add php-cs-fixer for linting Removing previous CODE_STYLE as it was not enforced anyway and using PER-CS 2.0. This is not the reformatting commit. * style: format code according to PER-CS 2.0 with php-cs-fixer * ci(actions): add lint action Resolves #1132.
64 lines
1.7 KiB
PHP
64 lines
1.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace openvk\VKAPI\Handlers;
|
|
|
|
use openvk\VKAPI\Exceptions\APIErrorException;
|
|
use openvk\Web\Models\Entities\IP;
|
|
use openvk\Web\Models\Entities\User;
|
|
use openvk\Web\Models\Repositories\IPs;
|
|
|
|
abstract class VKAPIRequestHandler
|
|
{
|
|
protected $user;
|
|
protected $platform;
|
|
|
|
public function __construct(?User $user = null, ?string $platform = null)
|
|
{
|
|
$this->user = $user;
|
|
$this->platform = $platform;
|
|
}
|
|
|
|
protected function fail(int $code, string $message): void
|
|
{
|
|
throw new APIErrorException($message, $code);
|
|
}
|
|
|
|
protected function getUser(): ?User
|
|
{
|
|
return $this->user;
|
|
}
|
|
|
|
protected function getPlatform(): ?string
|
|
{
|
|
return $this->platform ?? "";
|
|
}
|
|
|
|
protected function userAuthorized(): bool
|
|
{
|
|
return !is_null($this->getUser());
|
|
}
|
|
|
|
protected function requireUser(): void
|
|
{
|
|
if (!$this->userAuthorized()) {
|
|
$this->fail(5, "User authorization failed: no access_token passed.");
|
|
}
|
|
}
|
|
|
|
protected function willExecuteWriteAction(): void
|
|
{
|
|
$ip = (new IPs())->get(CONNECTING_IP);
|
|
$res = $ip->rateLimit();
|
|
|
|
if (!($res === IP::RL_RESET || $res === IP::RL_CANEXEC)) {
|
|
if ($res === IP::RL_BANNED && OPENVK_ROOT_CONF["openvk"]["preferences"]["security"]["rateLimits"]["autoban"]) {
|
|
$this->user->ban("User account has been suspended for breaking API terms of service", false);
|
|
$this->fail(18, "User account has been suspended due to repeated violation of API rate limits.");
|
|
}
|
|
|
|
$this->fail(29, "You have been rate limited.");
|
|
}
|
|
}
|
|
}
|