cf-platform/Application/App/Model/PointRecordModel.class.php

215 lines
5.1 KiB
PHP

<?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;
}
}
}