mirror of
https://github.com/openvk/openvk
synced 2025-01-26 01:29:57 +03:00
54 lines
1.2 KiB
PHP
54 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();
|
||
|
}
|
||
|
}
|