AccountCodeJobs.php 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. <?php
  2. namespace App\Jobs\OpenWork\LicenseOrder;
  3. use App\Servers\DB\DbService;
  4. use Illuminate\Bus\Queueable;
  5. use Illuminate\Contracts\Queue\ShouldBeUnique;
  6. use Illuminate\Contracts\Queue\ShouldQueue;
  7. use Illuminate\Foundation\Bus\Dispatchable;
  8. use Illuminate\Queue\InteractsWithQueue;
  9. use Illuminate\Queue\SerializesModels;
  10. use App\Facades\Servers\Wechat\OpenWork;
  11. use App\Models\OpenWork\License\ClientOrderAccount;
  12. use App\Facades\Servers\Logs\Log;
  13. use App\Models\OpenWork\job\Records;
  14. use App\Models\OpenWork\Contact\UserActiveLog;
  15. use Illuminate\Support\Facades\DB;
  16. /**
  17. * 激活码用户绑定更新数据更新队列
  18. * @author 唐远望
  19. * @version 1.0
  20. * @date 2025-04-10
  21. */
  22. class AccountCodeJobs implements ShouldQueue
  23. {
  24. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  25. protected $active_code_info;
  26. protected $Records;
  27. /**
  28. * Create a new job instance.
  29. *
  30. * @return void
  31. */
  32. public function __construct(array $active_code_info)
  33. {
  34. $this->active_code_info = $active_code_info;
  35. }
  36. public function getCorpId()
  37. {
  38. return $this->active_code_info['corpid'] ?? null;
  39. }
  40. /**
  41. * Execute the job.
  42. *
  43. * @return void
  44. */
  45. public function handle()
  46. {
  47. $active_code_info = $this->active_code_info;
  48. $corpid = $active_code_info['corpid'];
  49. $active_code = $active_code_info['active_code'];
  50. $order_id = $active_code_info['order_id'];
  51. (new DbService())->getConnectionNameByCorpId($corpid);
  52. $this->Records = Records::create([
  53. 'job_id' => $this->active_code_info['corpid'] . '_AccountCodeJobs',
  54. 'name' => static::class,
  55. 'payload' => json_encode($this->active_code_info),
  56. 'status' => 'processing',
  57. 'started_at' => now()
  58. ]);
  59. $clientOrderAccountmODEL = new ClientOrderAccount();
  60. $UserActiveLog =new UserActiveLog();
  61. // 处理激活码用户绑定更新数据
  62. $app = OpenWork::getApp();
  63. // 数据结果
  64. $result = $app->license_account->getActiveCodeInfo($corpid, $active_code);
  65. if (!$result) {
  66. //删除任务记录
  67. $this->Records->delete();
  68. Log::info('job_error', '未找到激活码绑定用户数据-接口查询失败',[$active_code_info]);
  69. return true;
  70. }
  71. // 错误提示
  72. if ($result['errcode']) {
  73. //删除任务记录
  74. $this->Records->delete();
  75. Log::info('job_error', '激活码数据异常-查询错误', [$result]);
  76. return true;
  77. }
  78. // 处理数据
  79. if (!isset($result['active_info']['userid'])) {
  80. //删除任务记录
  81. $this->Records->delete();
  82. Log::info('job_error', '未找到激活码绑定用户数据', [$active_code_info]);
  83. return true;
  84. }
  85. $wheres = ['corpid' => $corpid, 'active_code' => $active_code];
  86. //查询数据
  87. $client_order_account = $clientOrderAccountmODEL->where($wheres)->first();
  88. $user_active_log_data=$UserActiveLog->where($wheres)->first();
  89. if (!$client_order_account) {
  90. //删除任务记录
  91. $this->Records->delete();
  92. Log::info('job_error', '未找到激活码绑定用户数据-本地数据库查询失败', [$wheres]);
  93. return true;
  94. };
  95. try {
  96. // 更新数据
  97. $update_data = [
  98. 'userid' => $result['active_info']['userid'],
  99. 'account_expire_time' => $result['active_info']['expire_time'],
  100. 'account_active_time' => $result['active_info']['active_time'],
  101. 'status' => isset($result['active_info']['userid']) ? 2 : $client_order_account->status, //状态0=正常1=无效2=已使用
  102. ];
  103. // 更新数据
  104. $clientOrderAccountmODEL->where($wheres)->update($update_data);
  105. if($user_active_log_data){
  106. $UserActiveLog->where($wheres)->update(['account_expire_time' => $result['active_info']['expire_time'],'account_active_time' => $result['active_info']['active_time']]);
  107. };
  108. //删除任务记录
  109. $this->Records->delete();
  110. // 成功处理...
  111. } catch (\Exception $e) {
  112. // 失败处理...
  113. if ($this->Records) {
  114. $this->Records->delete();
  115. }
  116. Log::info('job_error', 'AccountCodeJobs任务队列失败', ['data'=>$this->active_code_info,'error' => $e->getMessage()]);
  117. }
  118. }
  119. public function failed(\Throwable $exception)
  120. {
  121. Log::info('job_error', 'AccountCodeJobs彻底失败', ['data'=>$this->active_code_info,'error' => $exception]);
  122. // 失败处理...
  123. if ($this->Records) {
  124. $this->Records->delete();
  125. }
  126. }
  127. }