FinishScheduleJob.php 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <?php
  2. namespace App\Jobs;
  3. use App\Models\Client;
  4. use App\Models\Provider;
  5. use App\Models\Schedule;
  6. use Carbon\Carbon;
  7. use Illuminate\Bus\Queueable;
  8. use Illuminate\Contracts\Queue\ShouldQueue;
  9. use Illuminate\Foundation\Bus\Dispatchable;
  10. use Illuminate\Queue\InteractsWithQueue;
  11. use Illuminate\Queue\SerializesModels;
  12. use App\Services\EmailService;
  13. use Illuminate\Support\Facades\Log;
  14. class FinishScheduleJob implements ShouldQueue
  15. {
  16. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  17. public function __construct(
  18. public int $scheduleId
  19. ) {}
  20. public function handle()
  21. {
  22. try {
  23. $schedule = Schedule::find($this->scheduleId);
  24. $date_cleaned = Carbon::parse($schedule->date)->format('Y-m-d');
  25. if (!$schedule) {
  26. return;
  27. }
  28. Log::channel('schedule_end_jobs')->info('Verificando status do agendamento id: ' . $schedule->id);
  29. Log::channel('schedule_end_jobs')->info('Status do agendamento: ' . $schedule->status);
  30. if ($schedule->status !== 'started') {
  31. return;
  32. }
  33. Log::channel('schedule_end_jobs')->info('Verificando data');
  34. Log::channel('schedule_end_jobs')->info('Data do agendamento: ' . $date_cleaned);
  35. Log::channel('schedule_end_jobs')->info('Data atual: ' . now()->toDateString());
  36. if ($date_cleaned > now()->toDateString()) {
  37. return;
  38. }
  39. Log::channel('schedule_end_jobs')->info('Verificando horário');
  40. Log::channel('schedule_end_jobs')->info('Horário do agendamento: ' . $schedule->end_time);
  41. Log::channel('schedule_end_jobs')->info('Horário atual: ' . now()->toTimeString());
  42. $end_date_time = Carbon::parse($date_cleaned . ' ' . $schedule->end_time);
  43. if ($end_date_time > now()) {
  44. return;
  45. }
  46. Log::channel('schedule_end_jobs')->info('Validado com sucesso, atualizado agendamento id: ' . $schedule->id . ' para status finalizado');
  47. $schedule->update([
  48. 'status' => 'finished'
  49. ]);
  50. $provider = Provider::find($schedule->provider_id);
  51. $provider->update([
  52. 'total_services' => $provider->total_services + 1,
  53. ]);
  54. $client = Client::find($schedule->client_id);
  55. $client->update([
  56. 'total_services' => $client->total_services + 1,
  57. ]);
  58. $emailService = new EmailService();
  59. $serviceAmount = (float) $schedule->total_amount;
  60. $serviceFee = 7.00;
  61. $finalAmount = $serviceAmount + $serviceFee;
  62. $emailService->sendEmailReceipt(
  63. email: $schedule->client->user->email,
  64. schedule: $schedule,
  65. client_name: $schedule->client->user->name,
  66. service_date: $schedule->date,
  67. start_time: $schedule->start_time,
  68. end_time: $schedule->end_time,
  69. address: $schedule->address->address,
  70. total_amount: $serviceAmount,
  71. service_fee: $serviceFee,
  72. final_amount: $finalAmount,
  73. payment_method: 'PIX'
  74. );
  75. } catch (\Exception $e) {
  76. Log::channel('schedule_end_jobs')->error('Erro ao finalizar agendamento id: ' . $this->scheduleId . '. Erro: ' . $e->getMessage());
  77. return;
  78. }
  79. }
  80. }