LogisticAliJiSuSync.php 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <?php
  2. namespace App\Jobs;
  3. use App\OrderPackage;
  4. use App\Services\LogisticAliJiSuApiService;
  5. use App\Services\LogService;
  6. use App\Services\OrderPackageReceivedSyncService;
  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. class LogisticAliJiSuSync implements ShouldQueue
  13. {
  14. public $tries = 2;
  15. public $timeout = 10;
  16. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  17. /** @var $logistic_number string */
  18. protected $logistic_number;
  19. /** @var $logisticAliJiSuApiService LogisticAliJiSuApiService */
  20. protected $logisticAliJiSuApiService;
  21. /** @var $orderPackageReceivedSyncService OrderPackageReceivedSyncService */
  22. protected $orderPackageReceivedSyncService;
  23. /**
  24. * Create a new job instance.
  25. *
  26. * @param $logistic_number
  27. */
  28. public function __construct($logistic_number)
  29. {
  30. $this->logistic_number = $logistic_number;
  31. }
  32. /**
  33. * Execute the job.
  34. *
  35. * @return void
  36. */
  37. public function handle()
  38. {
  39. LogService::log(LogisticAliJiSuSync::class, "{$this->logistic_number}-JOB-AliJiSu", '');
  40. //标记上有同步的操作
  41. OrderPackage::query()->where('logistic_number', $this->logistic_number)->update(['sync_routes_flag'=> true]);
  42. $this->logisticAliJiSuApiService = app('LogisticAliJiSuApiService');
  43. $response = $this->logisticAliJiSuApiService->query($this->logistic_number);
  44. $format = $this->logisticAliJiSuApiService->format($response,$this->logistic_number);
  45. try {
  46. $this->orderPackageReceivedSyncService = app('OrderPackageReceivedSyncService');
  47. if (count($format) > 0 && $format['logistic_number'] ?? false) $this->orderPackageReceivedSyncService->update([$format]);
  48. } catch (\Exception $e) {
  49. app('LogService')->log(__METHOD__, __FUNCTION__, "阿里极速数据同步快递数据 ERROR " . ' || ' . json_encode($this->logistic_number) . ' || ' . json_encode($e->getMessage()) . ' || ' . json_encode($e->getTraceAsString()));
  50. }
  51. }
  52. }