BargainTask.php 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. namespace app\job\event;
  3. use think\facade\Cache;
  4. use app\job\model\plus\bargain\Task as TaskModel;
  5. use app\common\library\helper;
  6. /**
  7. * 砍价任务行为管理
  8. */
  9. class BargainTask
  10. {
  11. private $model;
  12. /**
  13. * 执行函数
  14. */
  15. public function handle()
  16. {
  17. try {
  18. $this->model = new TaskModel();
  19. $cacheKey = "task_space_bargain_task";
  20. if (!Cache::has($cacheKey)) {
  21. // 将已过期的砍价任务标记为已结束
  22. $this->onSetIsEnd();
  23. Cache::set($cacheKey, time(), 10);
  24. }
  25. } catch (\Throwable $e) {
  26. echo 'ERROR BargainTask: ' . $e->getMessage() . PHP_EOL;
  27. log_write('BargainTask TASK : ' . '__ ' . $e->getMessage(), 'task');
  28. }
  29. return true;
  30. }
  31. /**
  32. * 将已过期的砍价任务标记为已结束
  33. */
  34. private function onSetIsEnd()
  35. {
  36. // 获取已过期但未结束的砍价任务
  37. $list = $this->model->getEndList();
  38. $taskIds = helper::getArrayColumn($list, 'bargain_task_id');
  39. // 将砍价任务标记为已结束(批量)
  40. !empty($taskIds) && $this->model->setIsEnd($taskIds);
  41. // 记录日志
  42. $this->dologs('close', [
  43. 'orderIds' => json_encode($taskIds),
  44. ]);
  45. return true;
  46. }
  47. /**
  48. * 记录日志
  49. */
  50. private function dologs($method, $params = [])
  51. {
  52. $value = 'behavior bargain Task --' . $method;
  53. foreach ($params as $key => $val)
  54. $value .= ' --' . $key . ' ' . $val;
  55. return log_write($value, 'task');
  56. }
  57. }