Nie możesz wybrać więcej, niż 25 tematów Tematy muszą się zaczynać od litery lub cyfry, mogą zawierać myślniki ('-') i mogą mieć do 35 znaków.

51 lines
1.0KB

  1. <?php
  2. namespace App\Jobs;
  3. use App\Util\DBUtil;
  4. use Illuminate\Bus\Queueable;
  5. use Illuminate\Contracts\Queue\ShouldQueue;
  6. use Illuminate\Foundation\Bus\Dispatchable;
  7. use Illuminate\Queue\InteractsWithQueue;
  8. use Illuminate\Queue\SerializesModels;
  9. use Illuminate\Support\Facades\DB;
  10. use Illuminate\Support\Facades\Log;
  11. abstract class BaseJob implements ShouldQueue
  12. {
  13. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  14. public function handle()
  15. {
  16. try {
  17. DB::beginTransaction();
  18. $this->logConfig();
  19. $this->handleJob();
  20. DB::commit();
  21. } catch (Exception $e) {
  22. DB::rollBack();
  23. throw $e;
  24. }
  25. }
  26. /**
  27. * ジョブを再試行する前に待機する秒数を計算
  28. */
  29. public function backoff(): int
  30. {
  31. return 5;
  32. }
  33. abstract protected function handleJob();
  34. private function logConfig()
  35. {
  36. Log::withContext([
  37. '__job_class__' => static::class,
  38. ]);
  39. }
  40. }