openvk/Web/Models/Entities/APIToken.php
2020-08-12 11:39:06 +00:00

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();
}
}