LogisticAliJiSuSync.php 2.0 KB

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