mirror of
https://github.com/v2board/v2board.git
synced 2024-11-14 07:29:13 +08:00
67 lines
1.5 KiB
PHP
67 lines
1.5 KiB
PHP
<?php
|
|
|
|
namespace App\Services;
|
|
|
|
use App\Models\User;
|
|
|
|
class UserService
|
|
{
|
|
public function isAvailable(User $user)
|
|
{
|
|
if (!$user->banned && $user->transfer_enable && ($user->expired_at > time() || $user->expired_at === NULL)) {
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
public function getAvailableUsers()
|
|
{
|
|
return User::whereRaw('u + d < transfer_enable')
|
|
->where(function ($query) {
|
|
$query->where('expired_at', '>=', time())
|
|
->orWhere('expired_at', NULL);
|
|
})
|
|
->where('banned', 0)
|
|
->get();
|
|
}
|
|
|
|
public function getUnAvailbaleUsers()
|
|
{
|
|
return User::where(function ($query) {
|
|
$query->where('expired_at', '<', time())
|
|
->orWhere('expired_at', 0);
|
|
})
|
|
->where(function ($query) {
|
|
$query->where('plan_id', NULL)
|
|
->orWhere('transfer_enable', 0);
|
|
})
|
|
->get();
|
|
}
|
|
|
|
public function getUsersByIds($ids)
|
|
{
|
|
return User::whereIn('id', $ids)->get();
|
|
}
|
|
|
|
public function getAllUsers()
|
|
{
|
|
return User::all();
|
|
}
|
|
|
|
public function addBalance(int $userId, int $balance):bool
|
|
{
|
|
$user = User::find($userId);
|
|
if (!$user) {
|
|
return false;
|
|
}
|
|
$user->balance = $user->balance + $balance;
|
|
if ($user->balance < 0) {
|
|
return false;
|
|
}
|
|
if (!$user->save()) {
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
}
|