UserBoardController.php 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?php
  2. namespace app\api\controller\board;
  3. use crmeb\services\UtilService;
  4. use app\models\board\UserBoard;
  5. use \think\facade\Config;
  6. use tw\command\console;
  7. use tw\lib\robot\Robots;
  8. use tw\redis\BoardRds;
  9. /**
  10. * 协议见文档 docs/board.md, 协议可能变更
  11. *
  12. * 使用 UserBoard Model, 数据表为 store_order_cart_info
  13. *
  14. * 策略:定时利用 sql 生成排行榜,缓存 json 到 redis
  15. *
  16. * Class UserBoardController
  17. * @package app\api\controller\board
  18. */
  19. class UserBoardController
  20. {
  21. /**
  22. * @api {get} /boards 获取排行榜
  23. * @apiName GetBoards
  24. * @apiGroup Public
  25. *
  26. * @apiParam {int=1,2} type 1|2 日榜单|周榜单
  27. *
  28. * @apiSuccess {string} banner 顶部 banner 图片
  29. * @apiSuccess {string} name 排行榜名称, 暂未使用
  30. * @apiSuccess {Object[]} board 排行榜数据
  31. *
  32. * @apiSuccessExample
  33. * {
  34. * "banner": "http://xxx.png",
  35. * "name": "daily board",
  36. * "board": [{
  37. * "uid": 123,
  38. * "avatar": "http://2.png",
  39. * "nickname": "xxx",
  40. * "level": 1,
  41. * "value": 23.3,
  42. * "border": 1,
  43. * "vip": 2
  44. * }]
  45. * }
  46. */
  47. public function boards()
  48. {
  49. [$type,] = UtilService::getMore([
  50. ['type', BoardRds::DAILY],
  51. ], null, true);
  52. $board = json_decode((new BoardRds)->get($type), true);
  53. return app('json')->successful('ok', $board);
  54. }
  55. /**
  56. * 讀取数据库中每日榜单的今日榜单
  57. */
  58. protected function daily_win_money()
  59. {
  60. $board = new UserBoard();
  61. $res = $board->getDailyWinMoney();
  62. foreach ($res as &$row) {
  63. $row['value'] = floatval($row['value']);
  64. $row['border'] = 0;
  65. $row['vip'] = 0;
  66. }
  67. return [
  68. 'banner' => Config::get('app.leader_board_banner'),
  69. 'name' => "日榜",
  70. 'board' => $res,
  71. ];
  72. }
  73. /**
  74. * 缓存数据库取得的排行结果,定时调用
  75. */
  76. public function cache_board()
  77. {
  78. $real_board = $this->daily_win_money();
  79. $robot_board = Robots::first_n_by_value(30);
  80. $board = array_merge($robot_board, $real_board['board']);
  81. // 过滤掉 value == 0 的记录
  82. $board = array_filter($board, function ($v) {
  83. return $v['value'] > 0.0;
  84. });
  85. usort($board, function ($l, $r) {
  86. return $r['value'] <=> $l['value'];
  87. });
  88. $real_board['board'] = $board;
  89. $res = (new BoardRds)->set(BoardRds::DAILY, json_encode($real_board));
  90. if (!$res) {
  91. errlog("cache_board() returned $res");
  92. }
  93. }
  94. }