mirror of
https://github.com/openvk/openvk
synced 2025-01-25 09:09:24 +03:00
53 lines
1.2 KiB
PHP
53 lines
1.2 KiB
PHP
<?php declare(strict_types=1);
|
|
namespace openvk\Web\Models\Entities;
|
|
use openvk\Web\Models\RowModel;
|
|
use openvk\Web\Models\Repositories\Users;
|
|
use Nette\InvalidStateException as ISE;
|
|
|
|
class APIToken extends RowModel
|
|
{
|
|
protected $tableName = "api_tokens";
|
|
|
|
function getUser(): User
|
|
{
|
|
return (new Users)->get($this->getRecord()->user);
|
|
}
|
|
|
|
function getSecret(): string
|
|
{
|
|
return $this->getRecord()->secret;
|
|
}
|
|
|
|
function getFormattedToken(): string
|
|
{
|
|
return $this->getId() . "-" . chunk_split($this->getSecret(), 8, "-") . "jill";
|
|
}
|
|
|
|
function isRevoked(): bool
|
|
{
|
|
return $this->isDeleted();
|
|
}
|
|
|
|
function setUser(User $user): void
|
|
{
|
|
$this->stateChanges("user", $user->getId());
|
|
}
|
|
|
|
function setSecret(string $secret): void
|
|
{
|
|
throw new ISE("Setting secret manually is prohbited");
|
|
}
|
|
|
|
function revoke(): void
|
|
{
|
|
$this->delete();
|
|
}
|
|
|
|
function save(): void
|
|
{
|
|
if(is_null($this->getRecord()))
|
|
$this->stateChanges("secret", bin2hex(openssl_random_pseudo_bytes(36)));
|
|
|
|
parent::save();
|
|
}
|
|
}
|