UserBoardController.php 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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. usort($board, function ($l, $r) {
  82. return $r['value'] <=> $l['value'];
  83. });
  84. $real_board['board'] = $board;
  85. $res = (new BoardRds)->set(BoardRds::DAILY, json_encode($real_board));
  86. if (!$res) {
  87. errlog("cache_board() returned $res");
  88. }
  89. }
  90. }