MerchantStatis.php 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. <?php
  2. declare (strict_types = 1);
  3. namespace app\controller;
  4. use app\BaseController;
  5. use app\model\MerchantsUserModel;
  6. use app\model\MerchantStatisModel;
  7. use think\facade\Request;
  8. class MerchantStatis extends BaseController
  9. {
  10. /**
  11. * 获取商户每日数据
  12. */
  13. public function Daily()
  14. {
  15. $userInfo = $this->request->userInfo;
  16. // 获取查询参数
  17. $page = Request::get('page', 1, 'intval');
  18. $limit = Request::get('limit', 10, 'intval');
  19. // 筛选条件
  20. $filters = [
  21. // 时间筛选
  22. 'start_time' => Request::get('start_time', date('Y-m-d', strtotime('-7 days')), 'trim'),
  23. 'end_time' => Request::get('end_time', date('Y-m-d'), 'trim'),
  24. ];
  25. try {
  26. // 获取商户每日数据
  27. $result = MerchantStatisModel::getMerchantDailyList(
  28. $userInfo['merchant_id'],
  29. $page,
  30. $limit,
  31. $filters,
  32. );
  33. // 格式化数据
  34. foreach ($result['list'] as &$item) {
  35. $item['game_profit'] = (float)$item['game_profit'];
  36. $item['bet_amount'] = (float)$item['bet_amount'];
  37. $item['total_winning_score'] = (float)$item['total_winning_score'];
  38. $item['commission_amount'] = (float)bcmul((string)$item['game_profit'], (string)$GLOBALS['CommissionRate'], 2);
  39. $item['platform_fee'] = (float)bcmul((string)$item['bet_amount'], (string)$GLOBALS['CommissionRate'], 2);
  40. $item['buy_free_bet'] = intval($item['buy_free_bet_count'] ?? 0);
  41. }
  42. return json_success($result, '获取成功');
  43. } catch (\Exception $e) {
  44. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  45. }
  46. }
  47. /*
  48. * 获取商户时间阶段数据统计
  49. */
  50. public function Stage()
  51. {
  52. $userInfo = $this->request->userInfo;
  53. // 筛选条件
  54. $filters = [
  55. // 时间筛选
  56. 'start_time' => Request::get('start_time', date('Y-m-d', strtotime('-7 days')), 'trim'),
  57. 'end_time' => Request::get('end_time', date('Y-m-d'), 'trim'),
  58. ];
  59. try {
  60. // 获取商户游戏记录每日数据
  61. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id'], $filters);
  62. // 获取商户登录、注册每日数据
  63. $result['login_users'] = 0;
  64. $result['register_users'] = 0;
  65. $playerData = MerchantsUserModel::getPlayerStatistics($userInfo['merchant_id'], $filters);
  66. if ($playerData) {
  67. foreach ($playerData as $key => $row) {
  68. if ($key == 'register') {
  69. $result['register_users'] = array_sum(array_column($row, 'count'));
  70. }
  71. if ($key == 'login') {
  72. $result['login_users'] = array_sum(array_column($row, 'count'));
  73. }
  74. }
  75. }
  76. // 格式化数据
  77. $result['rtp'] = calculateRTP($result['total_winning_score'], $result['bet_amount']);
  78. $result['date_stage'] = implode(' ~ ', $filters);
  79. $result['game_profit'] = (float)$result['game_profit'];
  80. $result['bet_amount'] = (float)$result['bet_amount'];
  81. $result['total_winning_score'] = (float)$result['total_winning_score'];
  82. $result['commission_amount'] = (float)bcmul((string)$result['game_profit'], (string)$GLOBALS['CommissionRate'], 2);
  83. $result['platform_fee'] = (float)bcmul((string)$result['bet_amount'], (string)$GLOBALS['CommissionRate'], 2);
  84. $result['buy_free_bet'] = intval($result['buy_free_bet_count'] ?? 0);
  85. return json_success($result, '获取成功');
  86. } catch (\Exception $e) {
  87. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  88. }
  89. }
  90. /**
  91. * 获取商户历史数据统计
  92. */
  93. public function History()
  94. {
  95. $userInfo = $this->request->userInfo;
  96. try {
  97. // 获取商户历史数据
  98. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id']);
  99. // 获取商户登录、注册历史数据
  100. $result['login_users'] = 0;
  101. $result['register_users'] = 0;
  102. $playerData = MerchantsUserModel::getPlayerStatistics($userInfo['merchant_id']);
  103. if ($playerData) {
  104. foreach ($playerData as $key => $row) {
  105. if ($key == 'register') {
  106. $result['register_users'] = array_sum(array_column($row, 'count'));
  107. }
  108. if ($key == 'login') {
  109. $result['login_users'] = array_sum(array_column($row, 'count'));
  110. }
  111. }
  112. }
  113. // 格式化数据
  114. $result['rtp'] = calculateRTP($result['total_winning_score'], $result['bet_amount']);
  115. $result['game_profit'] = (float)$result['game_profit'];
  116. $result['bet_amount'] = (float)$result['bet_amount'];
  117. $result['total_winning_score'] = (float)$result['total_winning_score'];
  118. $result['commission_amount'] = (float)bcmul((string)$result['game_profit'], (string)$GLOBALS['CommissionRate'], 2);
  119. $result['platform_fee'] = (float)bcmul((string)$result['bet_amount'], (string)$GLOBALS['CommissionRate'], 2);
  120. $result['buy_free_bet'] = intval($result['buy_free_bet_count'] ?? 0);
  121. return json_success($result, '获取成功');
  122. } catch (\Exception $e) {
  123. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  124. }
  125. }
  126. }