mirror of
https://github.com/openvk/openvk
synced 2024-11-11 17:49:37 +03:00
86 lines
2.2 KiB
PHP
86 lines
2.2 KiB
PHP
|
<?php declare(strict_types=1);
|
||
|
namespace openvk\Web\Models\Entities;
|
||
|
use Chandler\Database\DatabaseConnection as DB;
|
||
|
use openvk\Web\Models\Repositories\Users;
|
||
|
use openvk\Web\Models\RowModel;
|
||
|
|
||
|
class Voucher extends RowModel
|
||
|
{
|
||
|
protected $tableName = "coin_vouchers";
|
||
|
|
||
|
function getCoins(): int
|
||
|
{
|
||
|
return $this->getRecord()->coins;
|
||
|
}
|
||
|
|
||
|
function getRating(): int
|
||
|
{
|
||
|
return $this->getRecord()->rating;
|
||
|
}
|
||
|
|
||
|
function getToken(): string
|
||
|
{
|
||
|
return $this->getRecord()->token;
|
||
|
}
|
||
|
|
||
|
function getFormattedToken(): string
|
||
|
{
|
||
|
$fmtTok = "";
|
||
|
$token = $this->getRecord()->token;
|
||
|
foreach(array_chunk(str_split($token), 6) as $chunk)
|
||
|
$fmtTok .= implode("", $chunk) . "-";
|
||
|
|
||
|
return substr($fmtTok, 0, -1);
|
||
|
}
|
||
|
|
||
|
function getRemainingUsages(): float
|
||
|
{
|
||
|
return (float) ($this->getRecord()->usages_left ?? INF);
|
||
|
}
|
||
|
|
||
|
function getUsers(int $page = -1, ?int $perPage = NULL): \Traversable
|
||
|
{
|
||
|
$relations = $this->getRecord()->related("voucher_users.voucher");
|
||
|
if($page !== -1)
|
||
|
$relations = $relations->page($page, $perPage ?? OPENVK_DEFAULT_PER_PAGE);
|
||
|
|
||
|
foreach($relations as $relation)
|
||
|
yield (new Users)->get($relation->user);
|
||
|
}
|
||
|
|
||
|
function isExpired(): bool
|
||
|
{
|
||
|
return $this->getRemainingUsages() < 1;
|
||
|
}
|
||
|
|
||
|
function wasUsedBy(User $user): bool
|
||
|
{
|
||
|
$record = $this->getRecord()->related("voucher_users.voucher")->where("user", $user->getId());
|
||
|
|
||
|
return sizeof($record) > 0;
|
||
|
}
|
||
|
|
||
|
function willUse(User $user): bool
|
||
|
{
|
||
|
if($this->wasUsedBy($user))
|
||
|
return false;
|
||
|
|
||
|
if($this->isExpired())
|
||
|
return false;
|
||
|
|
||
|
$this->setRemainingUsages($this->getRemainingUsages() - 1);
|
||
|
DB::i()->getContext()->table("voucher_users")->insert([
|
||
|
"voucher" => $this->getId(),
|
||
|
"user" => $user->getId(),
|
||
|
]);
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
function setRemainingUsages(float $usages): void
|
||
|
{
|
||
|
$this->stateChanges("usages_left", $usages === INF ? NULL : ((int) $usages));
|
||
|
$this->save();
|
||
|
}
|
||
|
}
|