Task.php 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2017~2021 https://www.yiovo.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
  8. // +----------------------------------------------------------------------
  9. // | Author: 萤火科技 <admin@yiovo.com>
  10. // +----------------------------------------------------------------------
  11. declare (strict_types = 1);
  12. namespace app\console\task;
  13. use think\facade\Cache;
  14. /**
  15. * 定时任务监听器
  16. * Class Listener
  17. * @package app\console\task
  18. */
  19. class Task
  20. {
  21. /**
  22. * 定时执行任务
  23. * @param int $storeId
  24. * @param string $key
  25. * @param int|null $expire
  26. * @param callable $callback
  27. * @return mixed
  28. */
  29. protected function setInterval(int $storeId, string $key, int $expire, callable $callback)
  30. {
  31. if (!$this->hasTaskId($storeId, $key)) {
  32. $this->setTaskId($storeId, $key, $expire);
  33. return $callback();
  34. }
  35. }
  36. /**
  37. * 获取任务ID
  38. * @param int $storeId
  39. * @param string $key
  40. * @return mixed
  41. */
  42. protected function hasTaskId(int $storeId, string $key)
  43. {
  44. return Cache::has("Listener:$storeId:$key");
  45. }
  46. /**
  47. * 设置任务ID
  48. * 用于实现定时任务的间隔时间, 如果任务ID存在并未过期, 则不执行任务
  49. * @param int $storeId
  50. * @param string $key
  51. * @param int $expire 任务ID过期时长(单位:秒)
  52. * @return bool
  53. */
  54. protected function setTaskId(int $storeId, string $key, int $expire = 60)
  55. {
  56. return Cache::set("Listener:$storeId:$key", true, $expire);
  57. }
  58. }