215 lines
5.1 KiB
PHTML
215 lines
5.1 KiB
PHTML
5 years ago
|
<?php
|
||
|
/**
|
||
|
* Created by PhpStorm.
|
||
|
* User: xmy 280564871@qq.com
|
||
|
* Date: 2017/4/5
|
||
|
* Time: 13:37
|
||
|
*/
|
||
|
|
||
|
namespace App\Model;
|
||
|
|
||
|
use App\Logic\UserLogic;
|
||
|
|
||
|
class PointRecordModel extends BaseModel{
|
||
|
|
||
|
const HAVE_GET = -1;//已领取
|
||
|
const ADD_POINT = 1; //增加积分
|
||
|
|
||
|
|
||
|
/**
|
||
|
* 增加积分
|
||
|
* @param $type_key
|
||
|
* @param $user_id //邀请人id
|
||
|
* @param [type] $[be_invited_id] [<被邀请人id>]
|
||
|
* @return bool
|
||
|
* author: xmy 280564871@qq.com
|
||
|
*/
|
||
|
public function addPointByType($type_key,$user_id,$be_invited_id=0,$invited_game_id=0){
|
||
|
$type = $this->getPointType($type_key);
|
||
|
if(!$type){
|
||
|
return false;
|
||
|
}
|
||
|
$times = $type['time_of_day'];
|
||
|
$map['type_id'] = $type['id'];
|
||
|
$map['user_id'] = $user_id;
|
||
|
$today = strtotime(date("Y-m-d"));
|
||
|
$map['create_time'] = ['between',[$today,$today+86400-1]];
|
||
|
$num = $this->where($map)->count();
|
||
|
if($num >= $times && $times != 0){//判断是否超过当日领取次数
|
||
|
$this->error = "当日已到达最大领取次数";
|
||
|
return false;
|
||
|
}else{
|
||
|
$this->startTrans();
|
||
|
$user_logic = new UserLogic();
|
||
|
$user_result = $user_logic->operationPoint($user_id,$type['point'],self::ADD_POINT);
|
||
|
$data['user_id'] = $user_id;
|
||
|
$data['type_id'] = $type['id'];
|
||
|
$data['point'] = $type['point'];
|
||
|
$data['create_time'] = time();
|
||
|
$data['be_invited_id'] = $be_invited_id;
|
||
|
$data['invited_game_id'] = $invited_game_id;
|
||
|
$data['type'] = 1;
|
||
|
$record_result = $this->add($data);
|
||
|
if($user_result !== false && $record_result !== false){
|
||
|
$this->commit();
|
||
|
return true;
|
||
|
}else{
|
||
|
$this->rollback();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* 用户签到
|
||
|
* @param $user_id
|
||
|
* @return bool
|
||
|
* author: xmy 280564871@qq.com
|
||
|
*/
|
||
|
public function addPointBySignIn($user_id){
|
||
|
$type = $this->getPointType("sign_in");
|
||
|
if(!$type){
|
||
|
return false;
|
||
|
}
|
||
|
$base_point = $type['point'];
|
||
|
$increase_point = $type['time_of_day'];
|
||
|
$record = $this->getSignInInfo($user_id,$type['id']);
|
||
|
//计算间隔时间
|
||
|
$today = strtotime(date("Y-m-d"));
|
||
|
$time = strtotime(date("Y-m-d",$record['create_time']));
|
||
|
$day = ($today-$time)/86400;
|
||
|
if($day == 0){
|
||
|
$this->error = "今日已签过";
|
||
|
return false;
|
||
|
}elseif($day == 1){//昨日积分 + 递增积分
|
||
|
$add_point = $record['point'] + $increase_point;
|
||
|
//超过7天 重新计算
|
||
|
if ($record['day'] >= 7) {
|
||
|
$add_point = $base_point;
|
||
|
$sign_day = 1;
|
||
|
}else{
|
||
|
$sign_day = $record['day'] + 1;
|
||
|
}
|
||
|
$data['point'] = $add_point;
|
||
|
}else{//基础积分
|
||
|
$data['point'] = $base_point;
|
||
|
$sign_day = 1;
|
||
|
}
|
||
|
$data['user_id'] = $user_id;
|
||
|
$data['type_id'] = $type['id'];
|
||
|
$data['create_time'] = time();
|
||
|
$data['day'] = $sign_day;
|
||
|
$data['type'] = 1;
|
||
|
$this->startTrans();
|
||
|
$record_result = $this->add($data);
|
||
|
$user_result = D("User","Logic")->operationPoint($user_id,$data['point'],self::ADD_POINT);
|
||
|
if($user_result !== false && $record_result !== false){
|
||
|
$this->commit();
|
||
|
return $sign_day;
|
||
|
}else{
|
||
|
$this->rollback();
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* 获取用户签到信息
|
||
|
* @param $user_id
|
||
|
* @param $type_id
|
||
|
* @return bool|int
|
||
|
* author: xmy 280564871@qq.com
|
||
|
*/
|
||
|
public function getSignInInfo($user_id,$type_id){
|
||
|
$map['type_id'] = $type_id;
|
||
|
$map['user_id'] = $user_id;
|
||
|
$record = $this->where($map)->order("create_time desc")->find();
|
||
|
return $record;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* 获取积分方式
|
||
|
* @param $key
|
||
|
* @return bool|mixed
|
||
|
* author: xmy 280564871@qq.com
|
||
|
*/
|
||
|
public function getPointType($key){
|
||
|
$map['key'] = $key;
|
||
|
$map['status'] = 1;
|
||
|
$type = M("point_type","tab_")->where($map)->find();
|
||
|
if(empty($type)){
|
||
|
$this->error = "此奖励不存在或被禁用";
|
||
|
return false;
|
||
|
}
|
||
|
return $type;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* 积分获取记录
|
||
|
* @param string $map
|
||
|
* @param string $order
|
||
|
* @param int $p
|
||
|
* @return mixed
|
||
|
* author: xmy 280564871@qq.com
|
||
|
*/
|
||
|
public function getUserAchieveRecord($map="",$order="create_time desc",$p=1){
|
||
|
$page = intval($p);
|
||
|
$page = $page ? $page : 1; //默认显示第一页数据
|
||
|
$row = 10;
|
||
|
$data = $this
|
||
|
->table("tab_point_record as pr")
|
||
|
->field("pr.point,pr.create_time,pt.name")
|
||
|
->where($map)
|
||
|
->join("tab_user u on u.id=pr.user_id")
|
||
|
->join("tab_point_type pt on pr.type_id = pt.id")
|
||
|
->order($order)
|
||
|
->page($page,$row)
|
||
|
->select();
|
||
|
return $data;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* 充值获得积分
|
||
|
* @param $user_id
|
||
|
* @param $pay_amount
|
||
|
* @return bool
|
||
|
* author: xmy 280564871@qq.com
|
||
|
*/
|
||
|
public function rechargeAwardPoint($user_id,$pay_amount){
|
||
|
$user = M("user","tab_")->find($user_id);
|
||
|
if(empty($user_id)){
|
||
|
return true;
|
||
|
}
|
||
|
//奖励用户积分
|
||
|
$point_type = $this->getPointType("recharge_spend");
|
||
|
$point = intval($point_type['point'] * $pay_amount);
|
||
|
|
||
|
$this->startTrans();
|
||
|
|
||
|
if($point > 0){
|
||
|
$user['point'] += $point;
|
||
|
|
||
|
//积分记录
|
||
|
$data['user_id'] = $user_id;
|
||
|
$data['type_id'] = $point_type['id'];
|
||
|
$data['point'] = $point;
|
||
|
$data['create_time'] = time();
|
||
|
$data['type'] = 1;
|
||
|
$point_result = M("point_record","tab_")->add($data);//积分记录存储
|
||
|
}
|
||
|
$user_result = M("user","tab_")->save($user);//被邀请人积分存储
|
||
|
|
||
|
if($point_result === false || $user_result === false){
|
||
|
$this->rollback();
|
||
|
return false;
|
||
|
}else{
|
||
|
$this->commit();
|
||
|
return true;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
}
|