MerchantStatis.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <?php
  2. declare (strict_types = 1);
  3. namespace app\controller;
  4. use app\BaseController;
  5. use app\model\GameBetGameModel;
  6. use app\model\GameBetOrderModel;
  7. use app\model\MerchantStatisModel;
  8. use app\common\CommonUtils;
  9. use think\facade\Request;
  10. class MerchantStatis extends BaseController
  11. {
  12. /**
  13. * 获取商户每日数据
  14. */
  15. public function Daily()
  16. {
  17. $userInfo = $this->request->userInfo;
  18. // 获取查询参数
  19. $page = Request::get('page', 1, 'intval');
  20. $limit = Request::get('limit', 10, 'intval');
  21. // 筛选条件
  22. $filters = [
  23. // 时间筛选
  24. 'start_time' => Request::get('start_time', date('Y-m-d', strtotime('-7 days')), 'trim'),
  25. 'end_time' => Request::get('end_time', date('Y-m-d'), 'trim'),
  26. ];
  27. try {
  28. // 获取商户每日数据
  29. $result = MerchantStatisModel::getMerchantDailyList(
  30. $userInfo['merchant_id'],
  31. $page,
  32. $limit,
  33. $filters,
  34. );
  35. // 格式化数据
  36. foreach ($result['list'] as &$item) {
  37. $item['game_profit'] = CommonUtils::convertBalance($item['game_profit'], false);
  38. $item['bet_amount'] = CommonUtils::convertBalance($item['bet_amount'], false);
  39. $item['commission_amount'] = CommonUtils::convertBalance($item['game_profit'] * 0.08, false);
  40. $item['platform_fee'] = CommonUtils::convertBalance($item['bet_amount'] * 0.08, false);
  41. $item['buy_free_bet'] = $item['buy_free_bet_count'] ?? 0;
  42. }
  43. return json_success($result, '获取成功');
  44. } catch (\Exception $e) {
  45. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  46. }
  47. }
  48. /*
  49. * 获取商户时间阶段数据统计
  50. */
  51. public function Stage()
  52. {
  53. $userInfo = $this->request->userInfo;
  54. // 筛选条件
  55. $filters = [
  56. // 时间筛选
  57. 'start_time' => Request::get('start_time', date('Y-m-d', strtotime('-7 days')), 'trim'),
  58. 'end_time' => Request::get('end_time', date('Y-m-d'), 'trim'),
  59. ];
  60. try {
  61. // 获取商户每日数据
  62. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id'], $filters);
  63. // 格式化数据
  64. $result['rtp'] = !is_null($result["rtp"]) ? $result["rtp"] : 0;
  65. $result['date_stage'] = implode(' ~ ', $filters);
  66. $result['game_profit'] = CommonUtils::convertBalance($result['game_profit'], false);
  67. $result['bet_amount'] = CommonUtils::convertBalance($result['bet_amount'], false);
  68. $result['commission_amount'] = CommonUtils::convertBalance($result['game_profit'] * 0.08, false);
  69. $result['platform_fee'] = CommonUtils::convertBalance($result['bet_amount'] * 0.08, false);
  70. $result['buy_free_bet'] = $result['buy_free_bet_count'] ?? 0;
  71. return json_success($result, '获取成功');
  72. } catch (\Exception $e) {
  73. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  74. }
  75. }
  76. /**
  77. * 获取商户历史数据统计
  78. */
  79. public function History()
  80. {
  81. $userInfo = $this->request->userInfo;
  82. try {
  83. // 获取商户每日数据
  84. $result = MerchantStatisModel::getMerchantHistory($userInfo['merchant_id']);
  85. // 格式化数据
  86. $result['game_profit'] = CommonUtils::convertBalance($result['game_profit'], false);
  87. $result['bet_amount'] = CommonUtils::convertBalance($result['bet_amount'], false);
  88. $result['commission_amount'] = CommonUtils::convertBalance($result['game_profit'] * 0.08, false);
  89. $result['platform_fee'] = CommonUtils::convertBalance($result['bet_amount'] * 0.08, false);
  90. $result['buy_free_bet'] = $result['buy_free_bet_count'] ?? 0;
  91. return json_success($result, '获取成功');
  92. } catch (\Exception $e) {
  93. return json_error([], '获取商户每日数据失败:' . $e->getMessage());
  94. }
  95. }
  96. }