mirror of
				https://github.com/v2board/v2board.git
				synced 2025-10-31 09:21:46 +08:00 
			
		
		
		
	update: add inventory limit
This commit is contained in:
		| @@ -9,6 +9,7 @@ use App\Models\Payment; | |||||||
| use App\Services\CouponService; | use App\Services\CouponService; | ||||||
| use App\Services\OrderService; | use App\Services\OrderService; | ||||||
| use App\Services\PaymentService; | use App\Services\PaymentService; | ||||||
|  | use App\Services\PlanService; | ||||||
| use App\Services\UserService; | use App\Services\UserService; | ||||||
| use Illuminate\Http\Request; | use Illuminate\Http\Request; | ||||||
| use Illuminate\Support\Facades\Cache; | use Illuminate\Support\Facades\Cache; | ||||||
| @@ -75,7 +76,9 @@ class OrderController extends Controller | |||||||
|             abort(500, __('You have an unpaid or pending order, please try again later or cancel it')); |             abort(500, __('You have an unpaid or pending order, please try again later or cancel it')); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         $plan = Plan::find($request->input('plan_id')); |         $planService = new PlanService($request->input('plan_id')); | ||||||
|  |  | ||||||
|  |         $plan = $planService->plan; | ||||||
|         $user = User::find($request->session()->get('id')); |         $user = User::find($request->session()->get('id')); | ||||||
|  |  | ||||||
|         if (!$plan) { |         if (!$plan) { | ||||||
| @@ -153,6 +156,10 @@ class OrderController extends Controller | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         if (!$planService->decrementInventory()) { | ||||||
|  |             abort(500, __('Failed to create order')); | ||||||
|  |         } | ||||||
|  |  | ||||||
|         if (!$order->save()) { |         if (!$order->save()) { | ||||||
|             DB::rollback(); |             DB::rollback(); | ||||||
|             abort(500, __('Failed to create order')); |             abort(500, __('Failed to create order')); | ||||||
|   | |||||||
| @@ -249,6 +249,11 @@ class OrderService | |||||||
|                 return false; |                 return false; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |         $planService = new PlanService($order->plan_id); | ||||||
|  |         if (!$planService->incrementInventory()) { | ||||||
|  |             DB::rollBack(); | ||||||
|  |             return false; | ||||||
|  |         } | ||||||
|         DB::commit(); |         DB::commit(); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								app/Services/PlanService.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								app/Services/PlanService.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,29 @@ | |||||||
|  | <?php | ||||||
|  |  | ||||||
|  | namespace App\Services; | ||||||
|  |  | ||||||
|  | use App\Models\Plan; | ||||||
|  |  | ||||||
|  | class PlanService | ||||||
|  | { | ||||||
|  |     public $plan; | ||||||
|  |  | ||||||
|  |     public function __construct(int $planId) | ||||||
|  |     { | ||||||
|  |         $this->plan = Plan::lockForUpdate()->find($planId); | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function incrementInventory() | ||||||
|  |     { | ||||||
|  |         if ($this->plan->inventory_limit !== NULL) { | ||||||
|  |             return $this->plan->increment('inventory_limit'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     public function decrementInventory() | ||||||
|  |     { | ||||||
|  |         if ($this->plan->inventory_limit !== NULL) { | ||||||
|  |             return $this->plan->decrement('inventory_limit'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | } | ||||||
		Reference in New Issue
	
	Block a user