// +---------------------------------------------------------------------- namespace Admin\Controller; use User\Api\UserApi as UserApi; use function GuzzleHttp\Psr7\str; use Base\Factory\BaseFactory; /** * 后台首页控制器 * @author 麦当苗儿 */ class TimingController extends AdminController { private $affairRatioList = []; public function _initialize(){ } public function caculateDeviceInfo() { $start = strtotime(date("Ymd",time()))-86400; $end = $start+1; // if (I('time')) { // $start = strtotime(I('time')); // $end = $start+1; // } if (I('start')&&I('end')) { $start = strtotime(I('start')); $end = strtotime(I('end'))+1; } else if (I('start')&&!I('end')) { $start = strtotime(I('start')); $end = strtotime(I('start'))+1; } else if (!I('start')&&I('end')) { $start = strtotime(I('end')); $end = strtotime(I('end'))+1; } if ($start>$end) { echo '开始时间不能大于结束时间'; } ini_set('memory_limit','1024M'); // $device = D('DeviceRecord'); // echo 1; for($startTime = $start;$startTime<$end;$startTime=$startTime+86400) { echo date("Y-m-d",$startTime).' 安卓 '; //当日新增设备 $newSql = M('device_record','tab_')->field('min(create_time) as create_time,model,unique_code,id')->where(['version'=>1])->group('unique_code')->select(false); $data['new_device'] = M('device_record','tab_')->table('(' . $newSql . ') as a')->where(['create_time'=>array('between',[$startTime,$startTime+86399])])->order('create_time')->count(); echo $data['new_device'].' '; //当日活跃设备 $data['active_device'] = $this->active(['create_time'=>array('between',[$startTime,$startTime+86399]),'version'=>1]); echo $data['active_device'].' '; $data['time'] = $startTime; $data['version'] = 1; $data['today_new_device'] =json_encode($this->news_on_time(['create_time'=>['between',[$startTime,$startTime+86399]]],'news',5,'time,version','time',1)); // echo M('device_record','tab_')->_sql()."\n"; $data['today_active_device'] =json_encode($this->active_on_time(['create_time'=>['between',[$startTime,$startTime+86399]],'version'=>1],'active',5,'time,version')); // echo M('device_record','tab_')->_sql()."\n"; $data['today_model_device'] = json_encode($this->model(['create_time'=>['between',[$startTime,$startTime+86399]],'version'=>1])); $data['model'] = json_encode($this->modelDevice(['create_time'=>['between',[$startTime,$startTime+86399]],'version'=>1])); $duration = $this->duration(['create_time'=>array('between',[$startTime-86400*7,$startTime-1])]); $newSqls = M('device_record','tab_')->field('min(create_time) as create_time,model,unique_code,id')->group('unique_code')->select(false); $data['duration7'] = ($duration/M('device_record','tab_')->table('(' . $newSqls . ') as a')->where(['create_time'=>array('between',[$startTime-86400*7,$startTime-1])])->order('create_time')->count())/7; $getStatistics = M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>1])->find(); echo "\n"; if (!$getStatistics) { M('device_statistics','tab_')->add($data); } else { M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>1])->save($data); } echo date("Y-m-d",$startTime).' 苹果 '; //当日新增设备 $newSql = M('device_record','tab_')->field('min(create_time) as create_time,model,unique_code,id')->where(['version'=>2])->group('unique_code')->select(false); $data['new_device'] = M('device_record','tab_')->table('(' . $newSql . ') as a')->where(['create_time'=>array('between',[$startTime,$startTime+86399])])->order('create_time')->count(); echo $data['new_device'].' '; //当日活跃设备 $data['active_device'] = $this->active(['create_time'=>array('between',[$startTime,$startTime+86399]),'version'=>2]); echo $data['active_device'].' '; $data['time'] = $startTime; $data['version'] = 2; $data['today_new_device'] =json_encode($this->news_on_time(['create_time'=>['between',[$startTime,$startTime+86399]]],'news',5,'time,version','time',2)); // echo M('device_record','tab_')->_sql();die(); $data['today_active_device'] =json_encode($this->active_on_time(['create_time'=>['between',[$startTime,$startTime+86399]],'version'=>2],'active',5,'time,version')); $data['today_model_device'] = json_encode($this->model(['create_time'=>['between',[$startTime,$startTime+86399]],'version'=>2])); $data['model'] = json_encode($this->modelDevice(['create_time'=>['between',[$startTime,$startTime+86399]],'version'=>2])); // $duration = $this->duration(['create_time'=>array('between',[$startTime-86400*7,$startTime-1]),'version'=>2]); // $data['duration7'] = ($duration/M('device_record','tab_')->table('(' . $newSql . ') as a')->where(['create_time'=>array('between',[$startTime-86400*7,$startTime-1])])->order('create_time')->count())/7; $data['duration7'] = 0; $getStatistics = M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>2])->find(); echo "\n"; if (!$getStatistics) { M('device_statistics','tab_')->add($data); } else { M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>2])->save($data); } } } public function caculateTodayDevice() { $start = strtotime(date("Ymd",time())); $end = $start+1; if (I('start')&&I('end')) { $start = strtotime(I('start')); $end = strtotime(I('end'))+1; } else if (I('start')&&!I('end')) { $start = strtotime(I('start')); $end = strtotime(I('start'))+1; } else if (!I('start')&&I('end')) { $start = strtotime(I('end')); $end = strtotime(I('end'))+1; } if ($start>$end) { echo '开始时间不能大于结束时间'; } ini_set('memory_limit','1024M'); // $device = D('DeviceRecord'); // echo 1; for($startTime = $start;$startTime<$end;$startTime=$startTime+86400) { echo date("Y-m-d",$startTime).' 安卓 '; //当日新增设备 $newSql = M('device_record','tab_')->field('min(create_time) as create_time,model,unique_code,id')->where(['version'=>1])->group('unique_code')->select(false); $data['new_device'] = M('device_record','tab_')->table('(' . $newSql . ') as a')->where(['create_time'=>array('between',[$startTime,$startTime+86399])])->order('create_time')->count(); $data['time'] = $startTime; echo $data['new_device'].' '; $duration = $this->duration(['create_time'=>array('between',[$startTime-86400*7,$startTime-1])]); $newSqls = M('device_record','tab_')->field('min(create_time) as create_time,model,unique_code,id')->group('unique_code')->select(false); $data['duration7'] = ($duration/M('device_record','tab_')->table('(' . $newSqls . ') as a')->where(['create_time'=>array('between',[$startTime-86400*7,$startTime-1])])->order('create_time')->count())/7; $data['version'] = 1; $getStatistics = M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>1])->find(); echo "\n"; if (!$getStatistics) { M('device_statistics','tab_')->add($data); } else { M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>1])->save($data); } $data['duration7'] = 0; echo date("Y-m-d",$startTime).' 苹果 '; //当日新增设备 $newSql = M('device_record','tab_')->field('min(create_time) as create_time,model,unique_code,id')->where(['version'=>2])->group('unique_code')->select(false); $data['new_device'] = M('device_record','tab_')->table('(' . $newSql . ') as a')->where(['create_time'=>array('between',[$startTime,$startTime+86399])])->order('create_time')->count(); echo $data['new_device'].' '; $data['version'] = 2; $getStatistics = M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>2])->find(); echo "\n"; if (!$getStatistics) { M('device_statistics','tab_')->add($data); } else { M('device_statistics','tab_')->where(['time'=>$startTime,'version'=>2])->save($data); } } } public function duration($map=array()) { return M('device_record','tab_')->where($map)->sum('duration'); } public function active($map=array()) { $sql = M('device_record','tab_')->field('create_time,model,unique_code')->where($map)->select(false); $sql = M('device_record','tab_')->table('(' . $sql . ') as a')->group('unique_code')->order('create_time')->select(false); $sql = "select count(*) as count from ({$sql})t"; $count = M('device_record','tab_')->query($sql); return $count[0]['count']; } public function news_on_time($map=array(),$field='news',$flag=1,$group='time',$order='time',$version = 1) { switch($flag) { case 2:{$dateform = '%Y-%m';};break; case 3:{$dateform = '%Y-%u';};break; case 4:{$dateform = '%Y';};break; case 5:{$dateform = '%Y-%m-%d %H';};break; default:$dateform = '%Y-%m-%d'; } $sql = M('device_record','tab_')->field('min(create_time) as create_time,version,unique_code,id')->where(['version'=>$version])->group('unique_code')->select(false); $news = M('device_record','tab_')->table('(' . $sql . ') as a') ->field('FROM_UNIXTIME(a.create_time, "'.$dateform.'") as '.$group.',group_concat(a.id) as id,group_concat(a.unique_code) as unique_code ,COUNT(a.unique_code) AS '.$field) ->where($map)->group($group)->order($order)->select(); // echo M('device_record','tab_')->_sql();die(); return $news; } public function active_on_time($map=array(),$field='active',$flag=1,$group='time',$order='time') { switch($flag) { case 2:{$dateform = '%Y-%m';};break; case 3:{$dateform = '%Y-%u';};break; case 4:{$dateform = '%Y';};break; case 5:{$dateform = '%Y-%m-%d %H';};break; default:$dateform = '%Y-%m-%d'; } $sql = M('device_record','tab_')->field('create_time,version,unique_code,id')->where($map)->select(false); $mid = M('device_record','tab_')->table('(' . $sql . ') as m')->group('unique_code')->select(false); $active = M('device_record','tab_')->table('(' . $mid . ') as a') ->field('FROM_UNIXTIME(a.create_time, "'.$dateform.'") as '.$group.',group_concat(a.id) as id,group_concat(a.unique_code) as unique_code ,COUNT(a.unique_code) AS '.$field) ->group($group)->order($order)->select(); // echo $this->_sql();die(); return $active; } public function model($map=array()) { $sql = M('device_record','tab_')->field('create_time,model,version,unique_code')->where($map)->select(false); $mid = M('device_record','tab_')->table('(' .$sql. ') as m')->group('unique_code')->select(false); return M('device_record','tab_')->table('(' .$mid. ') as a')->field('a.model,version,count(a.unique_code) as count')->group('model,version')->order('count desc')->select(); } public function modelDevice($map=array()) { $sql = M('device_record','tab_')->field('model,version,unique_code')->where($map)->select(false); $mid = M('device_record','tab_')->table('(' .$sql. ') as m')->group('unique_code')->select(); return $mid; } //格式 starttime 20200229 endtime 20200230 public function setAvailableBalance() { if (strtotime($_GET['endtime'])field("sum(`pay_amount`) as pay_amount,promote_id,promote_account,tab_spend.game_id,tab_spend.game_name,tab_spend.server_id,tab_spend.server_name,CASE WHEN old_value_ratio is NULL THEN 0 ELSE sum(`pay_amount`) * old_value_ratio END as available_balance") ->join('left join tab_resource_verify_config as config on tab_spend.game_id = config.game_id and config.status = 1') ->where(['pay_status'=>1,'pay_way'=>['egt',1],'pay_time'=>['between',[$start,$start+86399]]]) ->group('promote_id,game_id,server_id') ->select(); // dump($data);die(); foreach ($data as $key => $value) { $insert['promote_id'] = $value['promote_id']; $insert['promote_account'] = $value['promote_account']; $insert['game_id'] = $value['game_id']; $insert['game_name'] = $value['game_name']; $insert['available_balance'] = round($value['available_balance'],0); $insert['server_id'] = $value['server_id']; $insert['server_name'] = $value['server_name']; $availableBalanceData = M('promote_game_available_balance','tab_') ->where(['promote_id'=>$value['promote_id'],'game_id'=>$value['game_id'],'server_id'=>$value['server_id']]) ->find(); if (round($value['available_balance'],0) > 0 && !$availableBalanceData) { M('promote_game_available_balance','tab_')->add($insert); } else if (round($value['available_balance'],0) > 0 && $availableBalanceData) { M('promote_game_available_balance','tab_') ->where(['promote_id'=>$value['promote_id'],'game_id'=>$value['game_id'],'server_id'=>$value['server_id']]) ->setInc('available_balance',round($value['available_balance'],0)); } // dump(round($value['available_balance'],0)); } } echo '执行成功'; } public function getTogetherUserAccount() { if (I('user_id','')) { $user_id = I('user_id',''); } else { return false; } $data = M('user','tab_')->field('account')->where(['id'=>$user_id])->find(); // var_dump($data); if (!$data) { return false; } $this->ajaxReturn($data); } public function getChannelConfig($pay_way = 0,$config=false) { if(!$config) { $payWayName = $this->pay_way_name[$pay_way]; $toolConfig = M('tool','tab_')->where(['name'=>$payWayName])->find(); $config = json_decode($toolConfig['config'],true); if(empty($config['channel_rate'])){ $channel_rate = 0; }else { $channel_rate = $config['channel_rate']; } }else { foreach($this->pay_way_name as $key => $value) { $name = $value; $toolConfig = M('tool','tab_')->where(['name'=>$name])->find(); $config = json_decode($toolConfig['config'],true); if(empty($config['channel_rate'])){ $channel_rate[$key] = 0; }else { $channel_rate[$key] = $config['channel_rate']; } } } return $channel_rate; } public function setPromoteStatistics() { echo "-------------------------------------------------------------\n"; $startTime = strtotime("20190829"); if (I("start_time")=="yesterday") { $startTime = strtotime(date("Y-m-d",strtotime("-1 day"))); } $endTime = time(); if (I("start_time")) { $startTime = strtotime(I("start_time")); } if (I("end_time")) { $endTime = strtotime(I("end_time")); } if ($endTime < $startTime) { echo "错误,开始时间不得大于结束时间";die(); } for($start = $startTime;$start<$endTime;$start=$start+86400) { $map['pay_time'] = ['between', array($start, $start+86399)]; $map['tp1.chain'] = '/'; $map['pay_status'] = 1; $map['promote_id'] = array('egt', 0); $data = M('promote', 'tab_')->alias('tp1') ->field('tp1.account as promote_account,tp1.id as promote_id,floor(sum(pay_amount)*100) as count') ->join("tab_promote AS tp2 ON tp2.`chain` LIKE CONCAT('%/', tp1.id, '/%') OR tp2.id = tp1.id", 'left') ->join("tab_spend as s on tp2.id = s.promote_id", 'left') ->where($map) ->group('tp1.id') ->order('count desc') ->select(); foreach($data as $key => $value) { $insert['promote_id'] = $value['promote_id']; $insert['promote_account'] = $value['promote_account']; $insert['count'] = $value['count']?$value['count']:0; $insert['time'] = $start; $statisticsData = M("promote_statistics","tab_") ->where(['promote_id'=>$value['promote_id'],'time'=>$start]) ->find(); $date = date("Y-m-d",$start); if ($statisticsData) { M("promote_statistics","tab_") ->where(['promote_id'=>$value['promote_id'],'time'=>$start]) ->save($insert); echo "更新{$value['promote_account']}在{$date}充值:{$value['count']}\n"; } else { M("promote_statistics","tab_")->add($insert); echo "新增{$value['promote_account']}在{$date}充值:{$value['count']}\n"; } } } echo "-------------------------------------------------------------\n"; } public function shiftPromoteStatistics() { $data = M("shift_task")->where(['change_status'=>0,'type'=>2])->select(); $promote_data = []; $change_id = []; foreach ($data as $key => $value) { $promote_data[] = $value['from_promote_id']; $promote_data[] = $value['to_promote_id']; $change_id[] = $value['id']; } $promote_data=array_unique($promote_data); sort($promote_data); if(!$promote_data) { echo "没有数据"; die(); } $chain_data = M("promote","tab_") ->field("id") ->where(['chain'=>'/','id'=>['in',$promote_data]]) ->select(); $chain_data = array_column($chain_data,'id'); $chain_data_secord = M("promote","tab_") ->field("substring_index(chain, '/', 2) as id") ->where(['id'=>['in',$promote_data]]) ->select(); $chain_data_secord = array_column($chain_data_secord,'id'); foreach($chain_data_secord as $k=>$v){ if($v == '/'){ unset($chain_data_secord[$k]); } $chain_data_secord[$k] = substr($chain_data_secord[$k],1,strlen($v)); if ($chain_data_secord[$k] == false) { unset($chain_data_secord[$k]); } // var_dump(strlen($chain_data_secord[$k])); } $data = []; $data = array_merge(array_unique($chain_data),array_unique($chain_data_secord)); $this->PromoteStatistics($data); M("shift_task")->where(['id'=>['in',$change_id]])->save(['change_status'=>1]); // dump($data); // dump(array_unique($chain_data_secord)); } public function PromoteStatistics($promote) { echo "-------------------------------------------------------------\n"; $startTime = strtotime("20190829"); $endTime = time(); if (I("start_time")) { $startTime = strtotime(I("start_time")); } if ($promote) { $map['tp2.id'] = ['in',$promote]; } if (I("end_time")) { $endTime = strtotime(I("end_time")); } if ($endTime < $startTime) { echo "错误,开始时间不得大于结束时间";die(); } for($start = $startTime;$start<$endTime;$start=$start+86400) { $map['pay_time'] = ['between', array($start, $start+86399)]; $map['tp1.chain'] = '/'; $map['pay_status'] = 1; $map['promote_id'] = array('egt', 0); $data = M('promote', 'tab_')->alias('tp1') ->field('tp1.account as promote_account,tp1.id as promote_id,floor(sum(pay_amount)*100) as count') ->join("tab_promote AS tp2 ON tp2.`chain` LIKE CONCAT('%/', tp1.id, '/%') OR tp2.id = tp1.id", 'left') ->join("tab_spend as s on tp2.id = s.promote_id", 'left') ->where($map) ->group('tp1.id') ->order('count desc') ->select(); foreach($data as $key => $value) { $insert['promote_id'] = $value['promote_id']; $insert['promote_account'] = $value['promote_account']; $insert['count'] = $value['count']?$value['count']:0; $insert['time'] = $start; $statisticsData = M("promote_statistics","tab_") ->where(['promote_id'=>$value['promote_id'],'time'=>$start]) ->find(); $date = date("Y-m-d",$start); if ($statisticsData) { M("promote_statistics","tab_") ->where(['promote_id'=>$value['promote_id'],'time'=>$start]) ->save($insert); echo "更新{$value['promote_account']}在{$date}充值:{$value['count']}\n"; } else { M("promote_statistics","tab_")->add($insert); echo "新增{$value['promote_account']}在{$date}充值:{$value['count']}\n"; } } } echo "-------------------------------------------------------------\n"; } function getPayway($name) { switch ($name){ case 'alipay': //支付宝 1 return 1; case 'wei_xin': //微信支付 2 3 return 2; case 'heepay': //汇付宝 6 return 6; case 'sqpay': //双乾支付9,10,15 return 9; case 'yeepay': //易宝支付17 return 17; case 'ptb_pay': return 0; default: return ''; } } /** * 获取下游公司的特殊补点金额 * @param int $start_time * @param int $end_time * @return array */ public function getSpecialComplement($start_time=0,$end_time =0,$promote_id = 0) { $data = SM("company_statement","tab_") // ->where("statement_begin_time<={$start_time} and statement_end_time<={$end_time} and withdraw_type=3") ->where("(statement_begin_time <={$end_time} AND ( statement_end_time = 0 OR statement_end_time >= {$start_time})) and withdraw_type=3") ->select(); $return = []; foreach ($data as $key => $value) { $info = []; $pool_data = SM("company_statement_pool","tab_") ->field("id") ->where("(statement_begin_time <={$end_time} AND ( statement_end_time = 0 OR statement_end_time >= {$start_time})) and withdraw_type=3 and statement_ids like '%{$value['id']}%'") ->select(); foreach ($pool_data as $pk => $pv) { $info = SM("company_statement_info","tab_") ->field("statement_info") ->where("(statement_begin_time <={$end_time} AND ( statement_end_time = 0 OR statement_end_time >= {$start_time})) and withdraw_type=3 and pool_id = {$pv['id']} and company_id = {$value['company_id']}") ->find()['statement_info']; if ($info) { break; } } if ($info) { $statement_info = json_decode($info,true); } else { $statement_info = json_decode($value['statement_info'],true); } $is_inside = M("PromoteCompany","tab_")->field("is_inside")->where("id='{$value['company_id']}'")->find()['is_inside']; if ($value['company_type'] == 2) { foreach ($statement_info as $skey => $sval) { $info = $sval['game_list']; foreach ($info as $k => $v) { $statement_begin_time = strtotime(str_replace('.','-',$v['statement_begin_time'])); $statement_end_time = strtotime(str_replace('.','-',$v['statement_end_time']))+86399; if (date("m",$statement_begin_time)!=date("m",$start_time) || date("m",$statement_end_time)!=date("m",$end_time)) { continue; } // if (!isset($return[$value['company_id']."-".$sval['promote_id']."-".$v['relation_game_id']])) { $return[$value['company_id']."-".$sval['promote_id']."-".$v['relation_game_id']] = !$is_inside?($v['sum_money']-($v['withhold']?$v['withhold']:0)):0; } else { $return[$value['company_id']."-".$sval['promote_id']."-".$v['relation_game_id']] += !$is_inside?($v['sum_money']-($v['withhold']?$v['withhold']:0)):0; } } } } else { //判断公司比例是不是隶属于这个会长 $compamy_info = M("promote","tab_")->where(['id'=>$promote_id,'company_id'=>$value['company_id']])->find(); if ($compamy_info) { foreach ($statement_info as $k => $v) { $statement_begin_time = strtotime(str_replace('.','-',$v['statement_begin_time'])); $statement_end_time = strtotime(str_replace('.','-',$v['statement_end_time']))+86399; if (date("m",$statement_begin_time)!=date("m",$start_time) || date("m",$statement_end_time)!=date("m",$end_time)) { continue; } $amount_time['is_check'] = ['neq',2]; $amount_time['tab_spend.pay_status'] = 1; $amount_time['pay_way'] = ['egt',0]; $amount_time['_string'] = "payed_time between {$statement_begin_time} and {$statement_end_time} and relation_game_id={$v['relation_game_id']}"; D("Spend")->addSubsiteWhere($amount_time); $dataAmount = M("spend","tab_") ->field("pay_amount,relation_game_id,relation_game_name,payed_time,game_type_name,substring_index(substring_index(promote.`chain`,'/',2),'/',-1) promote_id,chain,admin_id") ->join("left join tab_promote promote on tab_spend.promote_id=promote.id") ->join("left join tab_game game on tab_spend.game_id=game.id") ->where($amount_time) ->select(false); $dataAmount = M()->table("({$dataAmount})a") ->field("a.*,sum(pay_amount) pay_amount,promote.account,member.real_name") ->join("left join tab_promote promote on promote_id=promote.id") ->join("left join sys_member member on promote.admin_id=member.uid ") ->where(['promote_id'=>$promote_id]) ->group("promote_id") ->find(); $return[$value['company_id']."-".$promote_id."-".$v['relation_game_id']] += !$is_inside?(($dataAmount['pay_amount']*$v['increment_ratio'])/100):0; } } } } // dump($return); return $return; } public function test() { $this->getSpecialComplement(strtotime(date("Y-m-1",strtotime("2020-08"))),strtotime(date("Y-m-t",strtotime("2020-08")))+86399,2259); // dump(D("CompanyGameRatio")->getPromoteCompanyGameRatio(18,(string)207,1600099200,1603728000,1)); // $this->createMarketBonus("all"); } // $admin_id = 0,$promote_id = 0,$company_id=0,$relation_game_id=0,$date ='',$pay_amount = 0 public function getCompanyGameRadio($admin_id = 0,$promote_id = 0,$company_id=0,$relation_game_id=0,$begintime=0,$endtime =0,$pay_amount = 0) { // $company_id=239; // $relation_game_id=213; // $pay_amount = 440; // $date = "2020-08"; // $admin_id = 27; // $promote_id = 3235; // $begintime = strtotime(date("Y-m-1",strtotime($date))); // $endtime = strtotime(date("Y-m-t",strtotime($date)))+86399; $is_inside = M("PromoteCompany","tab_")->field("is_inside")->where("id='{$company_id}'")->find()['is_inside']; if ($is_inside == 1) { return 0; } // $company_game_ratio = M("company_game_ratio","tab_") // ->where(['company_id'=>$company_id,'relation_game_id'=>$relation_game_id]) // ->where("(end_time>={$begintime} and (end_time<={$endtime} and end_time!=0)) or (begin_time>={$begintime} and begin_time<={$endtime}) or (begin_time<={$begintime} and (end_time>={$endtime} or end_time=0))") // ->order("begin_time ASC") // ->select(); // $company_data = M('promote_company','tab_') ->field("company_belong") ->where("id={$company_id}") ->find(); // // $game_ratio_mould = M("game_ratio_mould","tab_") // ->where(['relation_game_id'=>$relation_game_id,'company_belong'=>$company_data['company_belong'], // "_string"=>"begin_time <={$endtime} AND ( end_time = 0 OR end_time >= {$begintime})"]) // ->select(); $company_game_ratio = D("CompanyGameRatio")->getPromoteCompanyGameRatio($company_id,(string)$relation_game_id,$begintime,$endtime,$company_data['company_belong']); $company_game_ratio = $company_game_ratio[$relation_game_id]; // $mould = json_decode($company_game_ratio['turnover_ratio'],true); $amount = 0; if (!$company_game_ratio) { // $spend = $this->getSpendData($begintime,$endtime,$company_id,$relation_game_id,$admin_id,$promote_id); // $amount += $this->setSpendData($spend,$mould,$game_ratio_mould['ratio'],$pay_amount); return 0; } foreach ($company_game_ratio as $key => $value) { $turnover_ratio = json_decode($value['turnover_ratio'],true); // dump($value); $spend = $this->getSpendData($value['begintime'],$value['endtime'],$company_id,$relation_game_id,$admin_id,$promote_id); // dump($spend); $amount += $this->setSpendData($spend,$turnover_ratio,$value['ratio'],$pay_amount); } // dump($amount);die(); return $amount?$amount:0; } public function setSpendData($spend=[],$turnover_ratio=[],$radio=0,$pay_amount=0) { $turnover = 0; $amount= 0; foreach ($spend as $k => $v) { //获取的金额 $amount = ($v['pay_amount'] * ($radio?$radio:0))/100; foreach ( $turnover_ratio as $tk => $tv ) { //判断大于的流水是否比前一个要小 if ($turnover >= $tv['turnover']) { continue; } if ($tv['instanceof']==1) { if ($pay_amount >= $tv['turnover']) { $amount = ($v['pay_amount'] * ($tv['ratio']?$tv['ratio']:0))/100; $turnover = $tv['turnover']; } } else { if ($pay_amount > $tv['turnover']) { $amount = ($v['pay_amount'] * ($tv['ratio']?$tv['ratio']:0))/100; $turnover = $tv['turnover']; } } } } return $amount; } public function getSpendData($begintime = 0,$endtime = 0,$company_id=0,$relation_game_id=0,$admin_id=0,$promote_id=0) { $map['tab_spend.pay_status'] = 1; $map['pay_way'] = ['egt',0]; D("Spend")->addSubsiteWhere($map,"tab_spend"); $spend = M("spend","tab_") ->field("sum(pay_amount) pay_amount, CASE WHEN substring_index(substring_index(`chain`,'/',2),'/',-1) !='' THEN substring_index(substring_index(`chain`,'/',2),'/',-1) ELSE promote_id END promote_id,game.relation_game_id,company_id") ->join("left join tab_game game on tab_spend.game_id = game.id") ->join("left join tab_promote promote on tab_spend.promote_id = promote.id") ->where($map) ->where(['payed_time'=>['between',[$begintime,$endtime]],'company_id'=>$company_id,'relation_game_id'=>$relation_game_id,'market_admin_id'=>$admin_id,'is_check'=>['neq',2]]) ->group("tab_spend.id") ->select(false); $spend = M()->table("({$spend})a") ->field("*,sum(pay_amount) pay_amount") ->where(['promote_id'=>$promote_id]) ->group("promote_id") ->select(); return $spend; } //计算市场专员业绩公式 参数 time 2020-10 public function caculateMarketStream () { echo date("Y-m-d H:i:s")."----------------------市场结算管理计算----------------------\n"; $map['pay_time'] = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')); if ($_REQUEST['time']) { $map['pay_time'] = $_REQUEST['time']; } $spend_map = []; $time_start = 0; $time_end = 0; $month_time = []; if($_REQUEST['time'] == 'all') { $belong_map = []; $month_time[] = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')); // $month_time[] = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-2).'-01')); $map['pay_time'] = ['in',$month_time]; $spend_map['pay_time'] = ['elt',strtotime(date('Y-m-t 23:59:59', strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')))]; $time_end = strtotime(date('Y-m-t',strtotime($month_time))); } else { $month_time = $map['pay_time']; $time_start = strtotime(date('Y-m-1',strtotime($map['pay_time']))); $time_end = strtotime(date('Y-m-t',strtotime($map['pay_time']))); $belong_map = "((begin_time<={$time_start} and (end_time >={$time_start} or end_time=0)) or (begin_time<={$time_end} and end_time >={$time_end}) or (end_time>={$time_start} and end_time <={$time_end}))"; } if ($map['pay_time']) { SM("settleup_marketorder","tab_") ->where(['pay_time'=>['in',$month_time]]) ->delete(); } $data = M("auth_group") ->where(['title'=>['like','%市场%']]) ->select(false); $data = M("auth_group_access") ->field("auth.market_percentage,real_name,sys_member.uid,sys_auth_group_access.group_id") ->join("left join ({$data}) auth on auth.id = sys_auth_group_access.group_id") ->join("left join sys_member on sys_member.uid = sys_auth_group_access.uid") ->where("auth.title is not null") ->select(false); $belong_game = M("company_belong_game","tab_") ->field("game_ids,begin_time,end_time") ->where($belong_map) ->select(); // if($belong_game) { // unset($spend_map['pay_time']); // } $unsettlement = $spend_map; foreach ($belong_game as $key => $value) { $value['game_ids'] = explode(',',$value['game_ids']); foreach ($value['game_ids'] as $k => $v) { if (!$v) { unset($value['game_ids'][$k]); } } if (!$value['end_time']) { $value['end_time'] = $time_end; } $value['game_ids'] = implode(',',$value['game_ids']); if (!$spend_map['_string']) { $spend_map['_string'] = "(pay_time between {$value['begin_time']} and {$value['end_time']}+86399 and relation_game_id in({$value['game_ids']}))"; } else { $spend_map['_string'] .= " or (pay_time between {$value['begin_time']} and {$value['end_time']}+86399 and relation_game_id in({$value['game_ids']}))"; } } if (!$spend_map['_string']) { $spend_map['_string'] = "relation_game_id = 0"; } D("Spend")->addSubsiteWhere($spend_map,"tab_spend"); $spend = M("spend","tab_") ->field("sum(pay_amount) as pay_amount,FROM_UNIXTIME(pay_time,'%Y-%m') pay_time, substring_index(substring_index(tab_spend.game_name,'(',1),'(',-1) game_name,game_id,relation_game_id,tab_spend.sdk_version, CASE WHEN substring_index(substring_index(`chain`,'/',2),'/',-1) !='' THEN substring_index(substring_index(`chain`,'/',2),'/',-1) ELSE promote_id END promote_id,pay_way,market_admin_id,0 is_settlement,is_check") ->join("left join tab_promote on tab_spend.promote_id = tab_promote.id") ->join("left join tab_game game on game.id=tab_spend.game_id") ->where(['tab_spend.pay_status'=>1,'pay_way'=>['egt',0]]) ->where($spend_map) ->group("tab_spend.id") ->select(false); $not_in_spend = M("spend","tab_") ->field("tab_spend.id id") ->join("left join tab_promote on tab_spend.promote_id = tab_promote.id") ->join("left join tab_game game on game.id=tab_spend.game_id") ->where(['tab_spend.pay_status'=>1,'pay_way'=>['egt',0]]) ->where($spend_map) ->group("tab_spend.id") ->select(false); $unsettlement['_string'] = "tab_spend.id not in($not_in_spend)"; D("Spend")->addSubsiteWhere($unsettlement,"tab_spend"); $unsettlement_spend = M("spend","tab_") ->field("sum(pay_amount) as pay_amount,FROM_UNIXTIME(pay_time,'%Y-%m') pay_time, substring_index(substring_index(tab_spend.game_name,'(',1),'(',-1) game_name,game_id,relation_game_id,tab_spend.sdk_version, CASE WHEN substring_index(substring_index(`chain`,'/',2),'/',-1) !='' THEN substring_index(substring_index(`chain`,'/',2),'/',-1) ELSE promote_id END promote_id,pay_way,market_admin_id,1 is_settlement,is_check") ->join("left join tab_promote on tab_spend.promote_id = tab_promote.id") ->join("left join tab_game game on game.id=tab_spend.game_id") ->where(['tab_spend.pay_status'=>1,'pay_way'=>['egt',0]]) ->where($unsettlement) ->group("tab_spend.id") ->select(false); $spend = "{$spend} UNION ALL {$unsettlement_spend}"; $payway_spend = M()->table("({$spend}) spend") ->field("sum(pay_amount) as pay_amount,pay_time,promote_id,game_name,game_id,relation_game_id,pay_way,sdk_version,market_admin_id,is_settlement") ->where(['is_check'=>['neq',2]]) ->where($map) ->group("pay_time,promote_id,game_name,pay_way,market_admin_id,is_settlement") ->select(); $channel_fee = []; $paywayData = M("tool","tab_") ->field("name,config") ->where(['name'=>['in',"alipay,weixin,wei_xin,wei_xin_app,jubaobar,weixin_gf,jft,jft_wap,goldpig,ptb_pay,bind_pay,sqpay,heepay,yeepay,ptb_pay"]]) ->select(); //公司税费计算 $tax_radio = []; $tax_data = M("tax_radio","tab_") ->field("tax_radio,time") ->order("time ASC") ->select(); foreach ($tax_data as $key => $value) { $tax_radio[$key]['start'] = $value['time']; $tax_radio[$key]['end'] = $tax_data[$key+1]['time']; $tax_radio[$key]['tax_radio'] = $value['tax_radio']; if (!$tax_data[$key+1]['time']) { $tax_radio[$key]['end'] = 99999999999; } } $pay_rate = []; foreach ($paywayData as $key => $value) { $pay_config = json_decode($value['config'],true); if ($this->getPayway($value['name'])||$this->getPayway($value['name'])=='0') { $pay_rate[$this->getPayway($value['name'])] = $pay_config['channel_rate']?$pay_config['channel_rate']:0; } } foreach ($payway_spend as $key => $value) { switch ($value['pay_way']){ case 3: //微信同步 $value['pay_way'] = '2'; break; case 10: //双乾同步 $value['pay_way'] = '9'; break; case 15: //双乾同步 $value['pay_way'] = '9'; break; } //将时间、推广员id、游戏名、设备类型作为键值标记渠道费用 if (!$channel_fee[$value['pay_time'].$value['promote_id'].$value['game_name'].$value['market_admin_id'].$value['is_settlement']]) { if (!$value['pay_way']) { $channel_fee[$value['pay_time'].$value['promote_id'].$value['game_name'].$value['market_admin_id'].$value['is_settlement']] = 0; } $channel_fee[$value['pay_time'].$value['promote_id'].$value['game_name'].$value['market_admin_id'].$value['is_settlement']] = $value['pay_amount'] * ($pay_rate[$value['pay_way']]/100); } else { $channel_fee[$value['pay_time'].$value['promote_id'].$value['game_name'].$value['market_admin_id'].$value['is_settlement']] = $channel_fee[$value['pay_time'].$value['promote_id'].$value['game_name'].$value['market_admin_id'].$value['is_settlement']]+($value['pay_amount'] * ($pay_rate[$value['pay_way']]/100)); } } $spend = M()->table("({$spend}) spend") ->field("sum(pay_amount) as pay_amount,pay_time,promote_id,game_name,game_id,relation_game_id,sdk_version,market_admin_id,is_settlement") ->where(['is_check'=>['neq',2]]) ->where($map) ->group("pay_time,promote_id,game_name,market_admin_id,is_settlement") ->select(false); $promote_data = M()->table("({$spend}) spend") ->field("pay_time,company_id,company.company_name,account as promote_account,company.company_belong,develop_type,spend.promote_id,spend.game_name,game_id,relation_game_id,spend.pay_amount,auth.real_name,market_admin_id as admin_id,market_percentage,sdk_version,is_settlement") ->join("left join tab_promote promote on spend.promote_id = promote.id") ->join("left join tab_promote_company company on promote.company_id = company.id") ->join("left join ({$data}) auth on auth.uid=market_admin_id") ->where(['develop_type'=>['egt',1],'group_id'=>['in',['11','12','21']]]) // ->where(['company_id'=>43,'spend.promote_id'=>1498,'relation_game_id'=>191]) // ->order("is_settlement ASC") ->select(); $specialPayAmount = []; $unsettlement_amount = []; foreach ($promote_data as $key => $value) { if ($value['pay_time'] == date("Y-m",time())) { continue; } $cp_radio = getGameCpRadio($value['game_id'],$value['pay_amount'],true); if (!$cp_radio) { $cp_radio = getGameCpRadio($value['game_id'],$value['pay_amount'],false); } //上游流水 $promote_data[$key]['cp_amount'] = $value['pay_amount'] * ($cp_radio * 0.01); //下游 // $promote_radio = getGamePromoteCompanyRadio($value['company_id'],$value['relation_game_id'],time(),$value['pay_amount'],true,$value['company_belong']); // if (!$promote_radio) { // $promote_radio = getGamePromoteCompanyRadio($value['company_id'],$value['relation_game_id'],time(),$value['pay_amount'],false,$value['company_belong']); // } $begin_pay_time = strtotime(date("Y-m-1",strtotime($value['pay_time']))); $end_pay_time = strtotime(date("Y-m-t",strtotime($value['pay_time'])))+86399; $company_belong_game = M("company_belong_game","tab_") ->field("game_ids,begin_time,end_time") ->where("begin_time <={$end_pay_time} AND ( end_time = 0 OR end_time >= {$begin_pay_time})") // ->where("((begin_time<={$begin_pay_time} and (end_time >={$begin_pay_time} or end_time=0)) or (begin_time<={$end_pay_time} and end_time >={$end_pay_time}) or (end_time>={$begin_pay_time} and end_time <={$end_pay_time}))") ->order("begin_time ASC") ->select(); // dump($company_belong_game); $promote_data[$key]['promote_amount'] = 0; foreach ($company_belong_game as $ck => $cv) { $ungame_ids = explode(',',$cv['game_ids']); if ($cv['end_time'] == 0 || !$cv['end_time']) { $cv['end_time'] = 99999999999; } $use_begin = 0; $use_end = 0; if ($value['is_settlement'] == '0') { if ($begin_pay_time > $cv['begin_time']) { $use_begin = $begin_pay_time; if ($end_pay_time > $cv['end_time']+86399) { $use_end = $cv['end_time']+86399; } else { $use_end = $end_pay_time; } } else { $use_begin = $cv['begin_time']; if ($end_pay_time > $cv['end_time']) { $use_end = $cv['end_time']+86399; } else { $use_end = $end_pay_time; } } //下游流水 $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$use_begin,$use_end,$value['pay_amount']); } elseif($value['is_settlement'] == '1') { if ($ck == 0) { // echo 1; if ($cv['begin_time'] >= $begin_pay_time) { $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$begin_pay_time,$cv['begin_time']-1,$value['pay_amount']); // dump(date($begin_pay_time)."-".date($cv['begin_time']-1)); // dump($promote_data[$key]['promote_amount']); } } if (!$company_belong_game[$ck+1]) { // dump($end_pay_time); // dump($cv['end_time']); if ($end_pay_time > $cv['end_time']) { // echo 2; $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$cv['end_time']+86400,$end_pay_time,$value['pay_amount']); } } if ($ck > 0) { if (($cv['begin_time'] - $company_belong_game[$ck-1]['end_time'] + 86399) > 1) { // echo 3; $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$company_belong_game[$ck-1]['end_time'] + 86400,$cv['begin_time']-1,$value['pay_amount']); } } if (!in_array($value['relation_game_id'],$ungame_ids)) { // echo 4; if (($cv['end_time']+86399) > $end_pay_time) { $cv['end_time'] = $end_pay_time; } else { $cv['end_time'] = $cv['end_time']+86399; } if ($cv['begin_time'] < $begin_pay_time) { $cv['begin_time'] = $begin_pay_time; } // dump($promote_data[$key]['promote_amount']); // dump(date($cv['begin_time'])."-".date($cv['end_time'])); $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$cv['begin_time'],$cv['end_time'],$value['pay_amount']); // dump($promote_data[$key]['promote_amount']); } } // if (!in_array($value['relation_game_id'],$ungame_ids)) { // // if ($begin_pay_time > $cv['begin_time']) { // $use_begin = $begin_pay_time; // if ($end_pay_time > $cv['end_time']+86399) { // $use_end = $cv['end_time']+86399; // } else { // $use_end = $end_pay_time; // } // } else { // // $use_begin = $cv['begin_time']; // if ($end_pay_time > $cv['end_time']) { // $use_end = $cv['end_time']+86399; // } else { // $use_end = $end_pay_time; // } // // } // // //下游流水 // $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$use_begin,$use_end,$value['pay_amount']); // } } if (!$company_belong_game) { $promote_data[$key]['promote_amount'] += $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$begin_pay_time,$end_pay_time,$value['pay_amount']); } //下游流水 // $promote_data[$key]['promote_amount'] = $this->getCompanyGameRadio($value['admin_id'],$value['promote_id'],$value['company_id'],$value['relation_game_id'],$value['pay_time'],$value['pay_amount'],$value['is_settlement']); //下游流水 // $promote_data[$key]['promote_amount'] = $value['pay_amount'] * ($promote_radio * 0.01); //特殊补点 $specialPayAmount[$value['pay_time']] = $this->getSpecialComplement(strtotime(date("Y-m-1",strtotime($value['pay_time']))),strtotime(date("Y-m-t",strtotime($value['pay_time'])))+86399,$value['promote_id']); $specialAmount = $specialPayAmount[$value['pay_time']][$value['company_id']."-".$value['promote_id']."-".$value['relation_game_id']]?$specialPayAmount[$value['pay_time']][$value['company_id']."-".$value['promote_id']."-".$value['relation_game_id']]:0; //渠道费用 $promote_data[$key]['channel_amount'] = $channel_fee[$value['pay_time'].$value['promote_id'].$value['game_name'].$value['admin_id'].$value['is_settlement']]; $tax = 0; //公司税费 foreach($tax_radio as $k => $v) { if (strtotime($value['pay_time'])>=$v['start'] && strtotime($value['pay_time'])<$v['end']) { $tax = $v['tax_radio']; } } // $belong_game = M("company_belong_game","tab_") // ->field("game_ids") // ->where("time='{$value['pay_time']}'") // ->find(); // // $belong_game = array_values(explode(",",$belong_game['game_ids'])); // // if ((in_array($value['relation_game_id'],$belong_game) && $value['company_belong'] ==1) || $value['company_belong'] !=1) { // $promote_data[$key]['is_settlement']=1; // } else { // $promote_data[$key]['is_settlement']=0; // } $promote_data[$key]['is_settlement'] = $value['is_settlement']; $promote_data[$key]['promote_amount'] += $specialAmount; $promote_data[$key]['company_tax'] = ($value['pay_amount']-$promote_data[$key]['cp_amount']- $promote_data[$key]['promote_amount'])*($tax/100); //毛利 $promote_data[$key]['company_profit'] = $value['pay_amount']-$promote_data[$key]['cp_amount']-$promote_data[$key]['promote_amount']-$promote_data[$key]['channel_amount']-$promote_data[$key]['company_tax']; // dump($promote_data[$key]['promote_amount']); if ($value['promote_id'] == 0) { // $promote_data[$key]['promote_account']='官方渠道'; // $promote_data[$key]['company_id']='0'; // $promote_data[$key]['company_belong']='3'; // $promote_data[$key]['develop_type']='0'; continue; } unset($promote_data[$key]['market_percentage']); $marker_data = SM("settleup_marketorder","tab_") ->where(['pay_time'=>$value['pay_time'],'promote_id'=>$value['promote_id'],'game_name'=>$value['game_name'],'admin_id'=>$value['admin_id'],'is_settlement'=>$value['is_settlement']]) ->find(); echo "日期:{$value['pay_time']},游戏:{$value['game_name']},推广员:{$value['promote_account']}\n"; echo "市场员:{$value['admin_id']} 推广员:{$value['promote_id']} 公司id:{$value['company_id']} 游戏关联id:{$value['relation_game_id']} 支付时间:{$value['pay_time']} 金额:{$value['pay_amount']}\n"; // dump($promote_data[$key]);die(); if (!$marker_data) { SM("settleup_marketorder","tab_") ->add($promote_data[$key]); } else { SM("settleup_marketorder","tab_") ->where(['pay_time'=>$value['pay_time'],'promote_id'=>$value['promote_id'],'game_name'=>$value['game_name'],'admin_id'=>$value['admin_id'],'is_settlement'=>$value['is_settlement']]) ->save($promote_data[$key]); } } // var_dump($_REQUEST['time']); $this->createMarketBonus($_REQUEST['time']); echo date("Y-m-d H:i:s")."----------------------市场结算管理计算----------------------\n"; } public function insertAllUserBonus($time) { // $time = $_REQUEST['time']; $data = M("member") ->field("access.uid admin_id,real_name,nickname,group_id level") ->join("left join sys_auth_group_access access on sys_member.uid = access.uid") ->join("left join sys_auth_group auth on access.group_id=auth.id") ->where(['group_id'=>['in','11,12,21']]) ->select(); foreach ($data as $key => $value) { $value['pay_time'] = $time; $value['remark'] = ""; $value['create_time'] = time(); $sign = SM("market_altogether","tab_") ->where(['admin_id'=>$value['admin_id'],'pay_time'=>$time]) ->find(); if (!$sign) { SM("market_altogether","tab_")->add($value); } elseif(!$sign['real_name']) { SM("market_altogether","tab_")->where(['admin_id'=>$value['admin_id'],'pay_time'=>$time])->save(['real_name'=>$value['real_name']]); } } } public function createMarketBonus($pay_time) { if ($pay_time&&$pay_time!='all') { $map['pay_time'] = $pay_time; } if (!$pay_time) { $pay_time = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')); $map['pay_time'] = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')); } // dump(date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')));die(); if ($pay_time == 'all') { $end = date("Y-m",time()); $start = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')); $i = 0; do { $date = date('Y-m', strtotime($start . ' + ' . $i . ' month')); $i++; M("market_altogether","tab_")->where(['pay_time'=>$date])->delete(); $this->insertAllUserBonus($date); } while ($date < date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01'))); $map['pay_time'] = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01'));; // unset($map['pay_time']); } else{ SM("market_altogether","tab_")->where(['pay_time'=>$pay_time])->delete(); $this->insertAllUserBonus($pay_time); } $map['is_settlement'] = 1; //获取admin_id $accessData = M("auth_group_access") ->alias("access") ->join("left join sys_auth_group auth on access.group_id=auth.id") ->join("left join sys_member member on access.uid=member.uid") ->where(['group_id'=>['in','11,12,21']]) ->getField("access.uid,group_id,market_percentage,nickname"); $all_data = SM("settleup_marketorder","tab_") ->field("id,admin_id,pay_time,promote_account,company_belong,tab_settleup_marketorder.real_name,develop_type,game_name, sum(pay_amount) pay_amount,sum(company_profit) company_profit, sum(if((develop_type = 1 or develop_type = 2), pay_amount, 0)) performance_revenue,sum(if(develop_type = 3, pay_amount, 0)) appraisal_bonuses, sum(company_tax) company_tax, sum(cp_amount) cp_amount,sum(promote_amount) promote_amount") ->where($map) ->where(["admin_id"=>['in',array_keys($accessData)]]) ->group("admin_id,pay_time") ->select(); foreach ($all_data as $key => $value) { $admin_id = $value['admin_id']; if(isset($accessData[$admin_id])){ $value = array_merge($value,$accessData[$admin_id]); } $sum_amount = $value['performance_revenue'] + $value['appraisal_bonuses']; $market_percentage = json_decode($value['market_percentage'],true);//业绩提成 if ($value['performance_revenue']=='0.00') { $market_percentage['develop_commission_ratio'] = 0; $market_percentage['appraisal_bonuses_ratio'] = 0; } if ($value['appraisal_bonuses']=='0.00') { $market_percentage['maintain_commission_ratio'] = 0; $market_percentage['maintain_appraisal_bonuses_ratio'] = 0; } // echo "{$value['nickname']}:{$value['pay_time']}\n"; // dump($market_percentage); $settleup_marketorder = SM("settleup_marketorder","tab_") ->where(['admin_id'=>$value['admin_id'],'pay_time'=>$value['pay_time'],'is_settlement'=>1]) ->select(); $all_data[$key]['performance_commission'] = 0; $all_data[$key]['achievement_bonus'] = 0; foreach ($settleup_marketorder as $k => $v) { if($v['develop_type'] == 1 || $v['develop_type'] == 2) { $all_data[$key]['performance_commission'] += $v['company_profit']*($market_percentage['develop_commission_ratio']/100); $all_data[$key]['achievement_profit'] += $v['company_profit']; } if ($v['develop_type'] == 3) { $all_data[$key]['performance_commission'] += $v['company_profit']*($market_percentage['maintain_commission_ratio']/100); $all_data[$key]['performance_profit'] += $v['company_profit']; } //绩效考核奖金 if($v['develop_type'] == 1 || $v['develop_type'] == 2) { $all_data[$key]['achievement_bonus'] +=$v['company_profit']*($market_percentage['appraisal_bonuses_ratio']/100); } if ($v['develop_type'] == 3) { $all_data[$key]['achievement_bonus'] += $v['company_profit']*($market_percentage['maintain_appraisal_bonuses_ratio']/100); } } $all_data[$key]['performance_commission'] = number_format($all_data[$key]['performance_commission'], 2, '.', ''); $all_data[$key]['achievement_bonus'] = number_format($all_data[$key]['achievement_bonus'], 2, '.', ''); $sum_amount <$market_percentage['performance_revenue'] ? ($all_data[$key]['performance_commission'] = 0):""; $sum_amount <$market_percentage['performance_revenue'] ? ($all_data[$key]['achievement_profit'] = 0):""; $sum_amount <$market_percentage['appraisal_bonuses'] ? ($all_data[$key]['achievement_bonus'] = 0):""; $sum_amount <$market_percentage['appraisal_bonuses'] ? ($all_data[$key]['performance_profit'] = 0):""; //总提成 $all_data[$key]['commission'] = number_format($all_data[$key]['performance_commission']+$all_data[$key]['achievement_bonus'], 2, '.', ''); //应发金额 $all_data[$key]['extend_commission'] = substr(number_format($all_data[$key]['performance_commission'] * ($market_percentage['performance_monthly_ratio']/100)+ $all_data[$key]['achievement_bonus'] * ($market_percentage['month_bonus_ratio']/100), 4, '.', ''),0,-2); //待发金额 $all_data[$key]['wait_commission'] = substr(number_format($all_data[$key]['commission'] - ( $all_data[$key]['performance_commission'] * ($market_percentage['performance_monthly_ratio']/100)+ $all_data[$key]['achievement_bonus'] * ($market_percentage['month_bonus_ratio']/100) ), 4, '.', ''),0,-2); $insert['pay_time'] = $value['pay_time']; $insert['real_name'] = $value['real_name']; $insert['admin_id'] = $value['admin_id']; $insert['nickname'] = $value['nickname']; $insert['level'] = $value['group_id']; $insert['pay_amount'] = $value['pay_amount']; $insert['extend_commission'] = substr( number_format(($all_data[$key]['performance_commission'] * ($market_percentage['performance_monthly_ratio']/100) + $all_data[$key]['achievement_bonus'] * ($market_percentage['month_bonus_ratio']/100)), 4, '.', ''),0,-2); $insert['wait_commission'] = $all_data[$key]['wait_commission']; $insert['remark'] = ''; $insert['create_time'] = time(); $insert['company_profit'] = $value['company_profit']; $insert['company_tax'] = $value['company_tax']; $insert['cp_amount'] = $value['cp_amount']; $insert['promote_amount'] = $value['promote_amount']; $insert['performance_revenue'] = $value['performance_revenue']; $insert['appraisal_bonuses'] = $value['appraisal_bonuses']; $insert['performance_commission'] = $all_data[$key]['performance_commission']; $insert['achievement_bonus'] = $all_data[$key]['achievement_bonus']; //待发业绩奖金 $insert['wait_performance_commission'] = number_format($all_data[$key]['performance_commission'] * (1-($market_percentage['performance_monthly_ratio']/100)), 2, '.', ''); //待发绩效奖金 $insert['wait_achievement_commission'] = number_format($all_data[$key]['achievement_bonus'] * (1-($market_percentage['month_bonus_ratio']/100)), 2, '.', ''); $insert['achievement_profit'] = number_format($all_data[$key]['achievement_profit'], 2, '.', ''); $insert['performance_profit'] = number_format($all_data[$key]['performance_profit'], 2, '.', ''); // $insert['wait_commission'] = ($insert['wait_performance_commission']+$insert['wait_achievement_commission']); $is_hav = SM("market_altogether","tab_") ->where(['admin_id'=>$value['admin_id'],'pay_time'=>$value['pay_time']]) ->find(); if (!$is_hav) { SM("market_altogether","tab_")->add($insert); } else { SM("market_altogether","tab_") ->where(['admin_id'=>$value['admin_id'],'pay_time'=>$value['pay_time']]) ->save($insert); } } } public function sendMarketBonus(){ echo date("Y-m-d H:i:s")."----------------------月初发放市场专员应发份额----------------------\n"; $map['pay_time'] = date('Y-m',strtotime(date('Y',time()).'-'.(date('m',time())-1).'-01')); if ($_REQUEST['time']) { $map['pay_time'] = $_REQUEST['time']; } if ($_REQUEST['time'] == 'all') { unset($map['pay_time']); } $data = SM("market_altogether","tab_") ->where($map) ->select(); // dump($map);die(); foreach ($data as $key => $value) { $group_config = M("auth_group_access access") ->field("market_percentage") ->join("left join sys_auth_group auth on access.group_id=auth.id") ->where(['uid'=>$value['admin_id']]) ->find(); $group_config = json_decode($group_config['market_percentage'],true); $month = date("m",strtotime($value['pay_time'])); $yes = date("Y",strtotime($value['pay_time'])); $where =[]; if ($group_config['time'] == 1) { // var_dump($month);die(); if ($month == '07') { $where = [$yes.'-'.'01',$yes.'-'.'02',$yes.'-'.'03']; } elseif($month == '10') { $where = [$yes.'-'.'04',$yes.'-'.'05',$yes.'-'.'06']; } elseif($month == '04') { $where = [($yes-1).'-'.'10',($yes-1).'-'.'11',($yes-1).'-'.'12']; } elseif($month == '01') { $where = [($yes-1).'-'.'07',($yes-1).'-'.'08',($yes-1).'-'.'09']; } } elseif($group_config['time'] == 2) { if ($month == '07') { $where = [$yes.'-'.'01',$yes.'-'.'02',$yes.'-'.'03',$yes.'-'.'04',$yes.'-'.'05',$yes.'-'.'06']; } elseif($month == '01') { $where = [($yes-1).'-'.'07',($yes-1).'-'.'08',($yes-1).'-'.'09',($yes-1).'-'.'10',($yes-1).'-'.'11',($yes-1).'-'.'12']; } } elseif($group_config['time'] == 3) { if ($month == '01') { $where = [($yes-1).'-'.'01',($yes-1).'-'.'02',($yes-1).'-'.'03',($yes-1).'-'.'04',($yes-1).'-'.'05',($yes-1).'-'.'06', ($yes-1).'-'.'07',($yes-1).'-'.'08',($yes-1).'-'.'09',($yes-1).'-'.'10',($yes-1).'-'.'11',($yes-1).'-'.'12']; } } else { $where = [date("Y-m",strtotime("last month",strtotime($value['pay_time'])))]; } echo "{$value['pay_time']}:{$value['real_name']}发放\n"; $save['status'] = 1; $save['remark'] = '自动发放'; if ($where) { $map['pay_time'] = ['in',$where]; $map['admin_id'] = $value['admin_id']; SM("market_altogether","tab_") ->where($map) ->save($save); } } echo date("Y-m-d H:i:s")."----------------------市场结算管理计算----------------------\n"; } //离职定时器 public function timingleaveMarketMember() { $instance = BaseFactory::getInstance(); $leavePercentageInstance = $instance->factoryClass("LeavePercentage"); $leavePercentageInstance->leaveTiming(); } public function setbusinessAffairsAward() { echo date("Y-m-d H:i:s")."----------------------商务奖金计算----------------------\n"; if (!$_REQUEST['time']) { $time = time(); } else { $time = strtotime($_REQUEST['time']); $time = strtotime(date('Y-m',strtotime(date('Y',$time).'-'.(date('m',$time)+1).'-01'))); } list($becomeTimeList,$becomeTimeCount) = $this->getAffairList(date('Y-m',strtotime(date('Y',$time).'-'.(date('m',$time)-1).'-01'))); $time1 = date('Y-m',strtotime(date('Y',$time).'-'.(date('m',$time)-1).'-01')); $time2 = date('Y-m',strtotime(date('Y',$time).'-'.(date('m',$time)-2).'-01')); $time3 = date('Y-m',strtotime(date('Y',$time).'-'.(date('m',$time)-3).'-01')); $lasttime = [$time2,$time3]; $tempoparyData = M("spend","tab_") ->field("tab_spend.*,from_unixtime(payed_time,'%Y-%m') time,from_unixtime(payed_time,'%Y') year,from_unixtime(payed_time,'%m') month,relation_game_id,relation_game_name,game_belong_id,game_belong_name") ->join("left join tab_game on tab_game.id=tab_spend.game_id") ->where(['tab_spend.pay_status'=>1,'game_belong_id'=>['neq',0],'pay_way' => ['egt', 0]]) ->select(false); $lastdata = M()->table("({$tempoparyData}) a") ->field("*,sum(pay_amount) pay_amount") ->where(['time'=>['in',$lasttime]]) ->group("time,relation_game_id,game_belong_id") ->select(); $handleData = []; foreach ($lastdata as $key => $value) { $handleData[$value['time'].$value['game_belong_id'].$value['relation_game_id']] = $value; } $data = M()->table("({$tempoparyData}) a") ->field("sum(pay_amount) pay_amount,time,year,month,relation_game_id,relation_game_name,game_belong_id,game_belong_name") ->where(['time'=>$time1]) ->group("time,relation_game_id,game_belong_id") ->select(); $sum_amount = M()->table("({$tempoparyData}) a") ->field("sum(pay_amount) pay_amount") ->where(['time'=>$time1]) ->find()['pay_amount']; //判断是不是初次 $is_hav = M("business_affairs_award_pool","tab_")->where(['time'=>$time2])->find(); $month_bonus_pool = 0; $quarter_bonus_pool = 0; foreach($data as $key => $value) { $month_bonus_pool += $this->businessAffairRatio($value['pay_amount']); $quarter_bonus_pool = $this->businessAffairRatio($value['pay_amount']); if ($is_hav) { for($i = (($value['month']%3)?(($value['month']%3)-1):2); $i > 0; $i--) { $date = date("Y-m",strtotime($value['year'].'-'.(($value['month']-$i)>0?($value['month']-$i):($value['month']-$i+12)))); dump($date); $quarter_bonus_pool += $this->businessAffairRatio($handleData[$date.$value['game_belong_id'].$value['relation_game_id']]['pay_amount']); } } } foreach ($data as $key => $value){ echo "{$value['time']},{$value['game_belong_name']},{$value['pay_amount']}\n"; $value['month_bonus_pool'] = $month_bonus_pool; $value['quarter_bonus_pool'] = $quarter_bonus_pool; unset($value['year']); unset($value['month']); $value['quarter_award'] = $value['quarter_bonus_pool']*0.25*($becomeTimeList[$value['game_belong_id']]/$becomeTimeCount); $is_assistant = M("ucenter_member") ->field("sys_ucenter_member.id admin_id,become_time") ->join("left join sys_auth_group_access access on sys_ucenter_member.id = access.uid") ->join("left join sys_auth_group auth on access.group_id=auth.id") ->where(['title' => ['like', '%助理%'],'sys_ucenter_member.id'=>$becomeTimeList[$value['game_belong_id']]]) ->select(); if (!$is_assistant) { $value['month_award'] = ($value['pay_amount']/$sum_amount)*$value['month_bonus_pool']*0.7*(($becomeTimeList[$value['game_belong_id']]?$becomeTimeList[$value['game_belong_id']]:0)/$becomeTimeCount); } else { $value['month_award'] = ($value['pay_amount']/$sum_amount)*$value['month_bonus_pool']*0.05*(($becomeTimeList[$value['game_belong_id']]?$becomeTimeList[$value['game_belong_id']]:0)/$becomeTimeCount); } $value['month_award'] = round($value['month_award'],2); $value['quarter_award'] = round($value['quarter_award'],2); if (!$becomeTimeCount) { $value['month_award'] = 0; } $value['person_award'] = $value['quarter_award'] + $value['month_award']; $hav_value = M("business_affairs_award_pool","tab_") ->where([ 'time'=>$value['time'], 'relation_game_id'=>$value['relation_game_id'], 'game_belong_id'=>$value['game_belong_id'] ]) ->find(); if ($hav_value) { M("business_affairs_award_pool","tab_") ->where(['time'=>$value['time'], 'relation_game_id'=>$value['relation_game_id'], 'game_belong_id'=>$value['game_belong_id']]) ->save($value); } else { M("business_affairs_award_pool","tab_")->add($value); } } echo date("Y-m-d H:i:s")."----------------------商务奖金计算----------------------\n"; } //获取转正月数列表 private function getAffairList($now) { $all = 0; $affairList = M("ucenter_member") ->field("sys_ucenter_member.id admin_id,become_time") ->join("left join sys_auth_group_access access on sys_ucenter_member.id = access.uid") ->join("left join sys_auth_group auth on access.group_id=auth.id") ->where(['title' => ['like', '%商务%']]) ->select(); $return = []; foreach($affairList as $key => $value) { if ($value['become_time']) { $become_time = date("Y-m",$value['become_time']); } else { $become_time = $now; } $return[$value['admin_id']] = 0; if ($now > $become_time && $value['become_time']) { $return[$value['admin_id']] = $this->diffDate($become_time,$now); } $all += $return[$value['admin_id']]; } return [$return,$all]; } function diffDate($date1,$date2) { $datetime1 = new \DateTime($date1); $datetime2 = new \DateTime($date2); $interval = $datetime1->diff($datetime2); $time = $interval->format('%m'); return $time; } // private function businessAffairRatio($amount = 0) { if (!$amount) { return 0; } $returnAmount = 0; if (!$this->affairRatioList) { $this->affairRatioList = M("business_affairs_award","tab_")->where("1=1")->group("start_amount")->select(); } foreach ($this->affairRatioList as $key => $value) { $start_amount = $value['start_amount']; $end_amount = $value['end_amount']; $ratio = $value['ratio']; if ($amount > $start_amount&&($amount<=$end_amount||floor($end_amount)=='0')) { $returnAmount += ($amount-$start_amount)*($ratio/100); } elseif($amount > $start_amount &&($amount>$end_amount&&floor($end_amount)!='0')) { $returnAmount += ($end_amount-$start_amount)*($ratio/100); } } return $returnAmount; } }