FinishScheduleJob.php 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace App\Jobs;
  3. use App\Models\Address;
  4. use App\Models\Client;
  5. use App\Models\Payment;
  6. use App\Models\Provider;
  7. use App\Models\Schedule;
  8. use App\Models\User;
  9. use App\Services\EmailService;
  10. use Carbon\Carbon;
  11. use Illuminate\Bus\Queueable;
  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 FinishScheduleJob implements ShouldQueue
  18. {
  19. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  20. public function __construct(
  21. public int $scheduleId
  22. ) {}
  23. public function handle()
  24. {
  25. try {
  26. $schedule = Schedule::find($this->scheduleId);
  27. $date_cleaned = Carbon::parse($schedule->date)->format('Y-m-d');
  28. if (! $schedule) {
  29. return;
  30. }
  31. Log::channel('schedule_end_jobs')->info('Verificando status do agendamento id: '.$schedule->id);
  32. Log::channel('schedule_end_jobs')->info('Status do agendamento: '.$schedule->status);
  33. if ($schedule->status !== 'started') {
  34. return;
  35. }
  36. Log::channel('schedule_end_jobs')->info('Verificando data');
  37. Log::channel('schedule_end_jobs')->info('Data do agendamento: '.$date_cleaned);
  38. Log::channel('schedule_end_jobs')->info('Data atual: '.now()->toDateString());
  39. if ($date_cleaned > now()->toDateString()) {
  40. return;
  41. }
  42. Log::channel('schedule_end_jobs')->info('Verificando horário');
  43. Log::channel('schedule_end_jobs')->info('Horário do agendamento: '.$schedule->end_time);
  44. Log::channel('schedule_end_jobs')->info('Horário atual: '.now()->toTimeString());
  45. $end_date_time = Carbon::parse($date_cleaned.' '.$schedule->end_time);
  46. if ($end_date_time > now()) {
  47. return;
  48. }
  49. Log::channel('schedule_end_jobs')->info('Validado com sucesso, atualizado agendamento id: '.$schedule->id.' para status finalizado');
  50. $schedule->update([
  51. 'status' => 'finished',
  52. ]);
  53. $provider = Provider::find($schedule->provider_id);
  54. $provider->update([
  55. 'total_services' => $provider->total_services + 1,
  56. ]);
  57. $client = Client::find($schedule->client_id);
  58. $client->update([
  59. 'total_services' => $client->total_services + 1,
  60. ]);
  61. $emailService = new EmailService;
  62. $serviceAmount = (float) $schedule->total_amount;
  63. $payment = Payment::query()
  64. ->where('schedule_id', $schedule->id)
  65. ->whereIn('status', ['paid', 'authorized'])
  66. ->latest('id')
  67. ->first();
  68. $paymentMethod = $payment?->payment_method ?? 'pix';
  69. $platformFeeRate = $paymentMethod === 'credit_card'
  70. ? (float) config('services.pagarme.platform_credit_card_fee_rate')
  71. : (float) config('services.pagarme.platform_pix_fee_rate');
  72. $serviceFee = round($serviceAmount * $platformFeeRate, 2);
  73. $finalAmount = $serviceAmount + $serviceFee;
  74. $email_cliente = User::find($schedule->client->user_id)->email;
  75. $address = Address::find($schedule->address_id);
  76. $emailService->sendEmailReceipt(
  77. email: $email_cliente,
  78. schedule: $schedule,
  79. client_name: $schedule->client->user->name,
  80. service_date: $schedule->date,
  81. start_time: $schedule->start_time,
  82. end_time: $schedule->end_time,
  83. address: $address->address.', '.$address->number.($address->has_complement ? ', '.$address->complement : '').' - '.$address->district.', '.$address->city->name.'/'.$address->state->code,
  84. total_amount: $serviceAmount,
  85. service_fee: $serviceFee,
  86. final_amount: $finalAmount,
  87. payment_method: $paymentMethod === 'credit_card' ? 'Cartão de crédito' : 'PIX'
  88. );
  89. } catch (\Exception $e) {
  90. Log::channel('schedule_end_jobs')->error('Erro ao finalizar agendamento id: '.$this->scheduleId.'. Erro: '.$e->getMessage());
  91. return;
  92. }
  93. }
  94. }