CloseDeviceJob.php 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. namespace App\Jobs;
  3. use App\Handlers\ClientServer;
  4. use App\Models\Device;
  5. use App\Models\Order;
  6. use App\Repositories\Enums\DeviceLuTypeEnum;
  7. use App\Repositories\Enums\OrderStatusEnum;
  8. use App\Repositories\Enums\OrderWorkTypeCodeEnum;
  9. use Carbon\Carbon;
  10. use Illuminate\Bus\Queueable;
  11. use Illuminate\Contracts\Queue\ShouldBeUnique;
  12. use Illuminate\Contracts\Queue\ShouldQueue;
  13. use Illuminate\Foundation\Bus\Dispatchable;
  14. use Illuminate\Queue\InteractsWithQueue;
  15. use Illuminate\Queue\SerializesModels;
  16. use Illuminate\Support\Facades\Log;
  17. class CloseDeviceJob implements ShouldQueue
  18. {
  19. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  20. private $order_id = 0;
  21. /**
  22. * Create a new job instance.
  23. *
  24. * @return void
  25. */
  26. public function __construct($order_id)
  27. {
  28. $this->order_id = $order_id;
  29. }
  30. /**
  31. * Execute the job.
  32. *
  33. * @return void
  34. */
  35. public function handle()
  36. {
  37. $order = Order::query()->find($this->order_id);
  38. if (!$order) return;
  39. if (!in_array($order->status, [OrderStatusEnum::IN_SERVICE, OrderStatusEnum::ORDER_PAUSE])) {
  40. return;
  41. }
  42. $order->status = OrderStatusEnum::ORDER_OVER;
  43. $order->end_use_time = now();
  44. $order->save();
  45. //关闭设备
  46. $device = Device::query()->where('id', $order->device_id)->first();
  47. if (!$device) return;
  48. switch ($order->work_type) {
  49. case OrderWorkTypeCodeEnum::A:
  50. $device->a = DeviceLuTypeEnum::FREE;
  51. break;
  52. case OrderWorkTypeCodeEnum::B:
  53. $device->b = DeviceLuTypeEnum::FREE;
  54. break;
  55. case OrderWorkTypeCodeEnum::AB:
  56. $device->a = DeviceLuTypeEnum::FREE;
  57. $device->b = DeviceLuTypeEnum::FREE;
  58. break;
  59. }
  60. $device->save();
  61. Log::error("CloseDeviceJob||" . $order->no . '||' . $order->pay_time . '||' . $order->work_time . '||' . now());
  62. ClientServer::closeBoxByOrder($order, $device->box_no, $device->a, $device->b);
  63. }
  64. }