AutoFinishOrder.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php
  2. namespace App\Jobs;
  3. use App\Enums\OrderRecordStatus;
  4. use App\Enums\OrderStatus;
  5. use App\Models\CoachUser;
  6. use App\Models\Order;
  7. use App\Models\OrderRecord;
  8. use Illuminate\Bus\Queueable;
  9. use Illuminate\Contracts\Queue\ShouldQueue;
  10. use Illuminate\Foundation\Bus\Dispatchable;
  11. use Illuminate\Queue\InteractsWithQueue;
  12. use Illuminate\Queue\SerializesModels;
  13. use Illuminate\Support\Facades\DB;
  14. use Illuminate\Support\Facades\Log;
  15. class AutoFinishOrder implements ShouldQueue
  16. {
  17. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  18. /**
  19. * 任务最大尝试次数
  20. *
  21. * @var int
  22. */
  23. public $tries = 3;
  24. /**
  25. * 任务运行的超时时间
  26. *
  27. * @var int
  28. */
  29. public $timeout = 120;
  30. /**
  31. * Create a new job instance.
  32. */
  33. public function __construct(
  34. public Order $order
  35. ) {}
  36. /**
  37. * Execute the job.
  38. */
  39. public function handle(): void
  40. {
  41. try {
  42. DB::transaction(function () {
  43. // 获取订单信息并加锁
  44. $order = Order::query()
  45. ->with(['project'])
  46. ->where('id', $this->order->id)
  47. ->lockForUpdate()
  48. ->first();
  49. // 检查订单是否存在
  50. if (! $order) {
  51. Log::error('自动结束订单失败 - 订单不存在', [
  52. 'order_id' => $this->order->id,
  53. ]);
  54. return;
  55. }
  56. // 检查订单状态是否为服务中
  57. if ($order->state !== OrderStatus::SERVING->value) {
  58. Log::info('自动结束订单跳过 - 订单状态不是服务中', [
  59. 'order_id' => $order->id,
  60. 'current_state' => $order->state,
  61. ]);
  62. return;
  63. }
  64. // 更新订单状态为已完成
  65. $order->state = OrderStatus::FINISHED->value;
  66. $order->updated_at = now();
  67. $order->save();
  68. // 记录订单状态变更日志
  69. OrderRecord::create([
  70. 'order_id' => $order->id,
  71. 'state' => OrderStatus::FINISHED->value,
  72. 'object_id' => $order->coach_id,
  73. 'object_type' => CoachUser::class,
  74. 'remark' => '系统自动完成服务',
  75. ]);
  76. // TODO: 发送通知给用户和技师
  77. // event(new OrderFinishedEvent($order));
  78. Log::info('自动结束订单成功', [
  79. 'order_id' => $order->id,
  80. 'updated_at' => $order->updated_at,
  81. ]);
  82. });
  83. } catch (\Exception $e) {
  84. Log::error('自动结束订单失败', [
  85. 'order_id' => $this->order->id,
  86. 'error' => $e->getMessage(),
  87. 'trace' => $e->getTraceAsString(),
  88. ]);
  89. throw $e;
  90. }
  91. }
  92. /**
  93. * 处理失败的任务
  94. */
  95. public function failed(\Throwable $exception): void
  96. {
  97. Log::error('自动结束订单任务执行失败', [
  98. 'order_id' => $this->order->id,
  99. 'error' => $exception->getMessage(),
  100. 'trace' => $exception->getTraceAsString(),
  101. ]);
  102. }
  103. }