MerchantStatis.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  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. if (!empty($result['bet_amount'])) {
  78. $result['rtp'] = (float)bcmul(bcdiv((string)$result['total_winning_score'], (string)$result['bet_amount'], 4), '100', 2);
  79. } else {
  80. $result['rtp'] = 0;
  81. }
  82. $result['date_stage'] = implode(' ~ ', $filters);
  83. $result['game_profit'] = (float)$result['game_profit'];
  84. $result['bet_amount'] = (float)$result['bet_amount'];
  85. $result['total_winning_score'] = (float)$result['total_winning_score'];
  86. $result['commission_amount'] = (float)bcmul((string)$result['game_profit'], (string)$GLOBALS['CommissionRate'], 2);
  87. $result['platform_fee'] = (float)bcmul((string)$result['bet_amount'], (string)$GLOBALS['CommissionRate'], 2);
  88. $result['buy_free_bet'] = intval($result['buy_free_bet_count'] ?? 0);
  89. return json_success($result, '获取成功');
  90. } catch (\Exception $e) {
  91. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  92. }
  93. }
  94. /**
  95. * 获取商户历史数据统计
  96. */
  97. public function History()
  98. {
  99. $userInfo = $this->request->userInfo;
  100. try {
  101. // 获取商户历史数据
  102. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id']);
  103. // 获取商户登录、注册历史数据
  104. $result['login_users'] = 0;
  105. $result['register_users'] = 0;
  106. $playerData = MerchantsUserModel::getPlayerStatistics($userInfo['merchant_id']);
  107. if ($playerData) {
  108. foreach ($playerData as $key => $row) {
  109. if ($key == 'register') {
  110. $result['register_users'] = array_sum(array_column($row, 'count'));
  111. }
  112. if ($key == 'login') {
  113. $result['login_users'] = array_sum(array_column($row, 'count'));
  114. }
  115. }
  116. }
  117. // 格式化数据
  118. $result['rtp'] = (float)bcmul(bcdiv($result['total_winning_score'], $result['bet_amount'], 4), '100', 2);
  119. $result['game_profit'] = (float)$result['game_profit'];
  120. $result['bet_amount'] = (float)$result['bet_amount'];
  121. $result['total_winning_score'] = (float)$result['total_winning_score'];
  122. $result['commission_amount'] = (float)bcmul((string)$result['game_profit'], (string)$GLOBALS['CommissionRate'], 2);
  123. $result['platform_fee'] = (float)bcmul((string)$result['bet_amount'], (string)$GLOBALS['CommissionRate'], 2);
  124. $result['buy_free_bet'] = intval($result['buy_free_bet_count'] ?? 0);
  125. return json_success($result, '获取成功');
  126. } catch (\Exception $e) {
  127. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  128. }
  129. }
  130. }