mirror of
				https://github.com/v2board/v2board.git
				synced 2025-10-31 17:31:49 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.2 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();
 | |
|     }
 | |
| }
 |