StartScheduleJob.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. <?php
  2. namespace App\Jobs;
  3. use App\Models\Schedule;
  4. use Carbon\Carbon;
  5. use Illuminate\Bus\Queueable;
  6. use Illuminate\Contracts\Queue\ShouldQueue;
  7. use Illuminate\Foundation\Bus\Dispatchable;
  8. use Illuminate\Queue\InteractsWithQueue;
  9. use Illuminate\Queue\SerializesModels;
  10. use Illuminate\Support\Facades\Log;
  11. class StartScheduleJob implements ShouldQueue
  12. {
  13. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  14. public function __construct(
  15. public int $scheduleId
  16. ) {}
  17. public function handle()
  18. {
  19. try {
  20. $schedule = Schedule::find($this->scheduleId);
  21. $date_cleaned = Carbon::parse($schedule->date)->format('Y-m-d');
  22. if (!$schedule) {
  23. return;
  24. }
  25. Log::channel('schedule_start_jobs')->info('Verificando status do agendamento id: ' . $schedule->id);
  26. Log::channel('schedule_start_jobs')->info('Status do agendamento: ' . $schedule->status);
  27. if ($schedule->status !== 'paid') {
  28. return;
  29. }
  30. Log::channel('schedule_start_jobs')->info('Verificando data');
  31. Log::channel('schedule_start_jobs')->info('Data do agendamento: ' . $date_cleaned);
  32. Log::channel('schedule_start_jobs')->info('Data atual: ' . now()->toDateString());
  33. if ($date_cleaned > now()->toDateString()) {
  34. return;
  35. }
  36. Log::channel('schedule_start_jobs')->info('Verificando horário');
  37. Log::channel('schedule_start_jobs')->info('Horário do agendamento: ' . $schedule->start_time);
  38. Log::channel('schedule_start_jobs')->info('Horário atual: ' . now()->toTimeString());
  39. $start_date_time = Carbon::parse($date_cleaned . ' ' . $schedule->start_time);
  40. if ($start_date_time > now()) {
  41. return;
  42. }
  43. Log::channel('schedule_start_jobs')->info('Validado com sucesso, atualizado agendamento id: ' . $schedule->id . ' para status iniciado');
  44. $schedule->update([
  45. 'status' => 'started'
  46. ]);
  47. $date_time_dispatch = Carbon::parse($date_cleaned . ' ' . $schedule->end_time);
  48. FinishScheduleJob::dispatch($schedule->id)->delay($date_time_dispatch);
  49. // dispatch de teste em local
  50. // FinishScheduleJob::dispatch($schedule->id)->delay(now()->addSeconds(15));
  51. } catch (\Exception $e) {
  52. Log::channel('schedule_start_jobs')->error('Erro ao iniciar agendamento id: ' . $this->scheduleId . '. Erro: ' . $e->getMessage());
  53. return;
  54. }
  55. }
  56. }