Edit File: AcceptOrderRequest.php
<?php namespace App\Http\Requests\Api\Provider\Order; use App\Enums\OrderStatusEnum; use App\Http\Requests\Api\BaseApiRequest; use App\Models\Order; class AcceptOrderRequest extends BaseApiRequest { /** * Determine if the user is authorized to make this request. * * @return bool */ public function authorize() { return true; } /** * Get the validation rules that apply to the request. * * @return array */ public function rules() { return [ 'order' => ['nullable'], 'status' => ['required'], ]; } public function prepareForValidation() { $this->merge([ 'order' => Order::where([ ['provider_id', auth()->id()], ['id', $this->order_id], ])->first(), 'status' => OrderStatusEnum::Accepted->value ]); } public function withValidator($validator) { $validator->after(function ($validator) { if ($this->order->expired_at < now()) { $validator->errors()->add('order_id', __('apis.order_expired')); } if ($this->order_id) { $result = Order::checkPreviousStatus( id: $this->order_id, newStatus: $this->status, oldStatus: OrderStatusEnum::New->value, user: 'provider_id' ); if (is_string($result)) { $validator->errors()->add('order_id', $result); } } else { $validator->errors()->add('order_id', __('apis.order_not_fount_or_not_for_you')); } }); } }
Back to File Manager