| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- <?php
- namespace app\v1\logic\tool;
- use support\think\Db;
- class GameTotalMonthLogic
- {
- protected string $table = "game_total_month";
- protected string $group = 'game_id, agent_id, site_id';
- protected array $data;
- protected string $month;
- public function run($params=[])
- {
- if(!empty($params['date'])){
- $sDate = is_array($params['date']) ? $params['date'][0] : $params['date'];
- $eDate = is_array($params['date']) ? $params['date'][1] : $params['date'];
- }else{
- $sDate = date('Y-m');
- $eDate = date('Y-m');
- }
- for ($date = $sDate; $date <= $eDate; $date = date('Y-m', strtotime($date . '+1 month'))){
- $this->month = $date;
- try {
- $this->initStart();
- }catch (\Exception $e){
- return json_encode(["status"=>"error", "msg"=>$e->getMessage()], 256);
- }
- }
- $this->reRun();
- return json_encode(["status"=>"success", "msg"=>""], 256);
- }
- // 重跑
- protected function reRun(): void
- {
- $day = date('d');
- $hour = date('H');
- $i = date('i');
- // 重跑上个整月
- if(($day==1 || $day==15) && $hour==4 && $i<10){
- $this->month = date('Y-m', strtotime("-1 month"));
- $this->initStart();
- }
- }
- protected function initStart(): void
- {
- // 重置数据
- $this->data = [];
- $this->regMonth();
- $this->loginMonth();
- $this->regPay();
- $this->payTotal();
- $this->roleCreate();
- $this->mediaCost();
- $this->siteAuth();
- $this->replaceData();
- }
- protected function regMonth()
- {
- $sTime = strtotime("{$this->month}-01 00:00:00");
- $eTime = strtotime(date('Y-m-t 23:59:59', strtotime($sTime)));
- $regTotalTb = "sdk_reg_log_" . date('Ym', strtotime($this->month));
- $filed = "{$this->group}, count(distinct uid) as reg_total, count(distinct imei) as reg_dev";
- $where = [
- ['reg_time', 'between', [$sTime, $eTime]],
- ];
- $result = Db::connect('db_game_log')->table($regTotalTb)->field($filed)->where($where)->group($this->group)->select();
- $this->pushData($result);
- }
- protected function loginMonth()
- {
- $tb = "sdk_active_log_" . date('Ym', strtotime($this->month)); // 按天去重
- $filed = "{$this->group}, count(distinct uid) as login_total";
- $result = Db::connect('db_game_log')->table($tb)->field($filed)->group($this->group)->select();
- $this->pushData($result);
- }
- protected function regPay()
- {
- $tb = "sdk_order_success";
- $sDate = "{$this->month}-01 00:00:00";
- $eDate = date('Y-m-t 23:59:59', strtotime($this->month));
- $filed = "{$this->group}, sum(money) as reg_pay_total, sum(paid_amount) as reg_pay_amount, count(distinct uid) as reg_pay_num";
- $where = [
- 'reg_date' => ['between', [$sDate, $eDate]],
- 'pay_date' => ['between', [$sDate, $eDate]],
- ];
- $result = Db::connect('db_game_log')->table($tb)->field($filed)->where($where)->group($this->group)->select()->toArray();
- $this->pushData($result);
- }
- protected function payTotal()
- {
- $tb = "sdk_order_success";
- $sDate = "{$this->month}-01 00:00:00";
- $eDate = date('Y-m-t 23:59:59', strtotime($this->month));
- $filed = "{$this->group}, sum(money) as pay_total, sum(paid_amount) as pay_amount, count(distinct uid) as pay_num";
- $where = [
- 'pay_date' => ['between', [$sDate, $eDate]],
- ];
- $result = Db::connect('db_game_log')->table($tb)->field($filed)->where($where)->group($this->group)->select()->toArray();
- $this->pushData($result);
- }
- protected function roleCreate(): void
- {
- $sDate = "{$this->month}-01 00:00:00";
- $eDate = date('Y-m-t 23:59:59', strtotime($this->month));
- $filed = "{$this->group}, COUNT(DISTINCT uid) as role_create_user";
- $where = [
- ['create_time', 'between', [$sDate, $eDate]],
- ];
- // 安卓
- $result = Db::connect('db_game_log')->table("role_data_and")->field($filed)->where($where)->group($this->group)->select();
- $this->pushData($result);
- // iOS
- $result = Db::connect('db_game_log')->table("role_data_ios")->field($filed)->where($where)->group($this->group)->select();
- $this->pushData($result);
- }
- protected function mediaCost(): void
- {
- $sDate = "{$this->month}-01";
- $eDate = date('Y-m-t', strtotime($this->month));
- $filed = "{$this->group}, SUM(money) as cost";
- $where = [
- 'tdate' => ['between', [$sDate, $eDate]],
- ];
- $result = Db::connect('db_advert')->table("media_cost")->field($filed)->where($where)->group($this->group)->select();
- $this->pushData($result);
- }
- protected function siteAuth(): void
- {
- $agentList = Db::connect('db_advert')->table("agent")->column("id, media_id, auth_id");
- $agentListMap = array_column($agentList, null, "id");
- if($this->data){
- foreach ($this->data as &$item){
- $item['tdate'] = $this->month;
- $item['auth_id'] = $agentListMap[$item['agent_id']]['auth_id'] ?? 0; // 负责人
- $item['media_id'] = $agentListMap[$item['agent_id']]['media_id'] ?? 0; // 媒体
- }
- }
- }
- protected function replaceData(): bool
- {
- // 先删除,再写入
- Db::connect('db_data_report')->table($this->table)->where(['tmonth' => $this->month])->delete();
- return Db::connect('db_data_report')->table($this->table)->insertAll($this->data) !== false;
- }
- protected function pushData($rows): void
- {
- if ($rows) {
- foreach ($rows as $row) {
- $groupArr = explode(',', $this->group);
- $uniqueKey = "";
- foreach ($groupArr as $groupKey){
- $uniqueKey .= $row[$groupKey] . "-";
- }
- foreach ($row as $k => $v) {
- $this->data[$uniqueKey][$k] = !empty($this->data[$uniqueKey][$k]) ? $this->data[$uniqueKey][$k] + $v :$v;
- }
- }
- }
- }
- }
|