123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394 |
- <?php
- // +—————————————————————————————————————————————————————————————————————
- // | Created by Yunbao
- // +—————————————————————————————————————————————————————————————————————
- // | Copyright (c) 2013~2022 http://www.yunbaokj.com All rights reserved.
- // +—————————————————————————————————————————————————————————————————————
- // | Author: https://gitee.com/yunbaokeji
- // +—————————————————————————————————————————————————————————————————————
- // | Date: 2022-02-17
- // +—————————————————————————————————————————————————————————————————————
- class Model_User extends PhalApi_Model_NotORM {
- /* 用户全部信息 */
- public function getBaseInfo($uid) {
- $info=DI()->notorm->user
- ->select("id,user_nicename,avatar,avatar_thumb,sex,signature,coin,votes,consumption,votestotal,province,city,birthday,location")
- ->where('id=? and user_type="2"',$uid)
- ->fetchOne();
- if($info){
- $info['avatar']=get_upload_path($info['avatar']);
- $info['avatar_thumb']=get_upload_path($info['avatar_thumb']);
- $info['level']=getLevel($info['consumption']);
- $info['level_anchor']=getLevelAnchor($info['votestotal']);
- $info['lives']=getLives($uid);
-
-
-
-
- if($info['birthday']){
- $info['birthday']=date('Y-m-d',$info['birthday']);
- }else{
- $info['birthday']='';
- }
- }
-
- return $info;
- }
-
- /* 判断昵称是否重复 */
- public function checkName($uid,$name){
- $isexist=DI()->notorm->user
- ->select('id')
- ->where('id!=? and user_nicename=?',$uid,$name)
- ->fetchOne();
- if($isexist){
- return 0;
- }else{
- return 1;
- }
- }
-
- /* 修改信息 */
- public function userUpdate($uid,$fields){
- /* 清除缓存 */
- delCache("userinfo_".$uid);
-
- if(!$fields){
- return false;
- }
- return DI()->notorm->user
- ->where('id=?',$uid)
- ->update($fields);
- }
- /* 修改密码 */
- public function updatePass($uid,$oldpass,$pass){
- $userinfo=DI()->notorm->user
- ->select("user_pass")
- ->where('id=?',$uid)
- ->fetchOne();
- $oldpass=setPass($oldpass);
- if($userinfo['user_pass']!=$oldpass){
- return 1003;
- }
- $newpass=setPass($pass);
- return DI()->notorm->user
- ->where('id=?',$uid)
- ->update( array( "user_pass"=>$newpass ) );
- }
-
- /* 我的钻石 */
- public function getBalance($uid){
- if($uid<0){
- return array(
- 'coin'=>0,
- 'score'=>0
- );
- }
- return DI()->notorm->user
- ->select("coin,score")
- ->where('id=?',$uid)
- ->fetchOne();
- }
-
- /* 充值规则 */
- public function getChargeRules(){
- $rules= DI()->notorm->charge_rules
- ->select('id,coin,money,give')
- ->order('list_order asc')
- ->fetchAll();
- return $rules;
- }
-
- /* 我的收益 */
- public function getProfit($uid){
- $info= DI()->notorm->user
- ->select("votes,votestotal")
- ->where('id=?',$uid)
- ->fetchOne();
- $config=getConfigPri();
-
- //提现比例
- $cash_rate=$config['cash_rate'];
- $cash_start=$config['cash_start'];
- $cash_end=$config['cash_end'];
- $cash_max_times=$config['cash_max_times'];
- $cash_take=$config['cash_take'];
- //剩余票数
- $votes=$info['votes'];
-
- if(!$cash_rate){
- $total='0';
- }else{
- //总可提现数
- $total=(string)(floor($votes/$cash_rate)*(100-$cash_take)/100);
- }
- if($cash_max_times){
- $tips='每月'.$cash_start.'-'.$cash_end.'号可进行提现申请,每月只可提现'.$cash_max_times.'次';
- }else{
- $tips='每月'.$cash_start.'-'.$cash_end.'号可进行提现申请';
- }
-
- $rs=array(
- "votes"=>$votes,
- "votestotal"=>$info['votestotal'],
- "total"=>$total,
- "cash_rate"=>$cash_rate,
- "cash_take"=>$cash_take,
- "tips"=>$tips,
- );
- return $rs;
- }
- /* 提现 */
- public function setCash($data){
-
- $nowtime=time();
-
- $uid=$data['uid'];
- $accountid=$data['accountid'];
- $cashvote=$data['cashvote'];
-
- $config=getConfigPri();
- $cash_start=$config['cash_start'];
- $cash_end=$config['cash_end'];
- $cash_max_times=$config['cash_max_times'];
-
- $day=(int)date("d",$nowtime);
-
- if($day < $cash_start || $day > $cash_end){
- return 1005;
- }
-
- //本月第一天
- $month=date('Y-m-d',strtotime(date("Ym",$nowtime).'01'));
- $month_start=strtotime(date("Ym",$nowtime).'01');
- //本月最后一天
- $month_end=strtotime("{$month} +1 month");
-
- if($cash_max_times){
- $isexist=DI()->notorm->cash_record
- ->where('uid=? and addtime > ? and addtime < ?',$uid,$month_start,$month_end)
- ->count();
- if($isexist >= $cash_max_times){
- return 1006;
- }
- }
-
- $isrz=DI()->notorm->user_auth
- ->select("status")
- ->where('uid=?',$uid)
- ->fetchOne();
- if(!$isrz || $isrz['status']!=1){
- return 1003;
- }
-
- /* 钱包信息 */
- $accountinfo=DI()->notorm->cash_account
- ->select("*")
- ->where('id=? and uid=?',$accountid,$uid)
- ->fetchOne();
- if(!$accountinfo){
- return 1007;
- }
-
- //提现比例
- $cash_rate=$config['cash_rate'];
-
- /*提现抽成比例*/
- $cash_take=$config['cash_take'];
-
- /* 最低额度 */
- $cash_min=$config['cash_min'];
-
- //提现钱数
- $money=floor($cashvote/$cash_rate);
-
- if($money < $cash_min){
- return 1004;
- }
-
- $cashvotes=$money*$cash_rate;
-
-
- $ifok=DI()->notorm->user
- ->where('id = ? and votes>=?', $uid,$cashvotes)
- ->update(array('votes' => new NotORM_Literal("votes - {$cashvotes}")) );
- if(!$ifok){
- return 1001;
- }
-
- //平台抽成后最终的钱数
- $money_take=$money*(1-$cash_take*0.01);
- $money=number_format($money_take,2,".","");
-
- $data=array(
- "uid"=>$uid,
- "money"=>$money,
- "votes"=>$cashvotes,
- "orderno"=>$uid.'_'.$nowtime.rand(100,999),
- "status"=>0,
- "addtime"=>$nowtime,
- "uptime"=>$nowtime,
- "type"=>$accountinfo['type'],
- "account_bank"=>$accountinfo['account_bank'],
- "account"=>$accountinfo['account'],
- "name"=>$accountinfo['name'],
- );
-
- $rs=DI()->notorm->cash_record->insert($data);
- if(!$rs){
- return 1002;
- }
- return $rs;
- }
-
-
- /* 直播记录 */
- public function getLiverecord($touid,$p){
- if($p<1){
- $p=1;
- }
- $pnum=50;
- $start=($p-1)*$pnum;
- $record=DI()->notorm->live_record
- ->select("id,uid,nums,starttime,endtime,title,city")
- ->where('uid=?',$touid)
- ->order("id desc")
- ->limit($start,$pnum)
- ->fetchAll();
- foreach($record as $k=>$v){
- $record[$k]['datestarttime']=date("Y.m.d",$v['starttime']);
- $record[$k]['dateendtime']=date("Y.m.d",$v['endtime']);
- $cha=$v['endtime']-$v['starttime'];
- $record[$k]['length']=getSeconds($cha);
- }
- return $record;
- }
-
- /* 个人主页 */
- public function getUserHome($uid,$touid){
- $info=getUserInfo($touid);
- $user_status=$info['user_status'];
- /* 直播状态 */
- $islive='0';
- $isexist=DI()->notorm->live
- ->select('uid')
- ->where('uid=? and islive=1',$touid)
- ->fetchOne();
- if($isexist){
- $islive='1';
- }
- $info['islive']=$islive;
- /* 直播数 */
- $livenums=DI()->notorm->live_record
- ->where('uid=?',$touid)
- ->count();
-
- $info['livenums']=$livenums;
- /* 直播记录 */
- $record=array();
- $record=DI()->notorm->live_record
- ->select("id,uid,nums,starttime,endtime,title,city")
- ->where('uid=?',$touid)
- ->order("id desc")
- ->limit(0,50)
- ->fetchAll();
- foreach($record as $k=>$v){
- $record[$k]['datestarttime']=date("Y.m.d",$v['starttime']);
- $record[$k]['dateendtime']=date("Y.m.d",$v['endtime']);
- $cha=$v['endtime']-$v['starttime'];
- $record[$k]['length']=getSeconds($cha);
- }
- $info['liverecord']=$record;
- return $info;
- }
-
-
- /* 获取关于我们列表 */
- public function getPerSetting(){
- $rs=array();
-
- $list=DI()->notorm->portal_post
- ->select("id,post_title")
- ->where("type='2'")
- ->order('list_order asc')
- ->fetchAll();
- foreach($list as $k=>$v){
-
- $rs[]=array('id'=>'0','name'=>$v['post_title'],'thumb'=>'' ,'href'=>get_upload_path("/portal/page/index?id={$v['id']}"));
- }
-
- return $rs;
- }
-
- /* 提现账号列表 */
- public function getUserAccountList($uid){
-
- $list=DI()->notorm->cash_account
- ->select("*")
- ->where('uid=?',$uid)
- ->order("addtime desc")
- ->fetchAll();
-
- return $list;
- }
- /* 账号信息 */
- public function getUserAccount($where){
-
- $list=DI()->notorm->cash_account
- ->select("*")
- ->where($where)
- ->order("addtime desc")
- ->fetchAll();
-
- return $list;
- }
- /* 设置提账号 */
- public function setUserAccount($data){
-
- $rs=DI()->notorm->cash_account
- ->insert($data);
-
- return $rs;
- }
- /* 删除提账号 */
- public function delUserAccount($data){
-
- $rs=DI()->notorm->cash_account
- ->where($data)
- ->delete();
-
- return $rs;
- }
-
- //获取认证信息
- public function getAuthInfo($uid){
- $info=DI()->notorm->user_auth
- ->where("uid=? and status=1",$uid)
- ->select("real_name,cer_no")
- ->fetchOne();
- return $info;
- }
-
- }
|