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