parent
97a08f8b49
commit
19e28487a8
@ -0,0 +1,183 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Sdk\Model;
|
||||||
|
use Think\Model;
|
||||||
|
|
||||||
|
|
||||||
|
class PayLimitConfModel extends Model {
|
||||||
|
|
||||||
|
const PAY_TYPE_ALIPAY = "alipay";
|
||||||
|
const PAY_TYPE_WXPAY = "wxpay";
|
||||||
|
const PAY_TYPE_YEEPAY = "yeepay";
|
||||||
|
const PAY_TYPE_SQPAY = "sqpay";
|
||||||
|
|
||||||
|
protected $_validate = array(
|
||||||
|
);
|
||||||
|
|
||||||
|
/* 自动完成规则 */
|
||||||
|
protected $_auto = array(
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 构造函数
|
||||||
|
* @param string $name 模型名称
|
||||||
|
* @param string $tablePrefix 表前缀
|
||||||
|
* @param mixed $connection 数据库连接信息
|
||||||
|
*/
|
||||||
|
public function __construct($name = '', $tablePrefix = '', $connection = '') {
|
||||||
|
/* 设置默认的表前缀 */
|
||||||
|
$this->tablePrefix ='tab_';
|
||||||
|
/* 执行构造方法 */
|
||||||
|
parent::__construct($name, $tablePrefix, $connection);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 累加充值金额
|
||||||
|
public function sum($userId, $price, $payType) {
|
||||||
|
|
||||||
|
$now = date("His");
|
||||||
|
$nowDate = date('Ymd');
|
||||||
|
// 找出所有匹配的规则 时间范围满足的所有总流水限额
|
||||||
|
$limits = $this->where(array(
|
||||||
|
'start_time' => array('egt', $now),
|
||||||
|
'end_time' => array('lt', $now),
|
||||||
|
'pay_type' => $payType
|
||||||
|
))->select();
|
||||||
|
|
||||||
|
foreach ($limits as $k => $v) {
|
||||||
|
$this->updateClearTime($v, $userId); // 清零 时间、限额
|
||||||
|
if ($v['limit_type'] == 'all_total' // 总流水
|
||||||
|
|| ($v['limit_type'] == 'user_total' && $v['user_id'] == $userId) // 单玩家总流水
|
||||||
|
) {
|
||||||
|
$this->where(array(
|
||||||
|
'id' => $v['id']
|
||||||
|
))->save(array(
|
||||||
|
'now_value' => $v['now_value'] + $price,
|
||||||
|
'update_time' => time(),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($v['limit_type'] == 'user_one' && $v['user_id'] == $userId) { // 单玩家单笔
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($v['limit_type'] == 'user_total' && $v['user_id'] == $userId) { // 单玩家总流水
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检查限额 如果超出返回false
|
||||||
|
public function check($userId, $price, $payType) {
|
||||||
|
$now = date("His");
|
||||||
|
$nowDate = date('Ymd');
|
||||||
|
// 找出所有匹配的规则 时间范围满足的所有总流水限额
|
||||||
|
$limits = $this->where(array(
|
||||||
|
'start_time' => array('egt', $now),
|
||||||
|
'end_time' => array('lt', $now),
|
||||||
|
'pay_type' => $payType
|
||||||
|
))->select();
|
||||||
|
|
||||||
|
foreach ($limits as $k => $v) {
|
||||||
|
$this->updateClearTIme($v, $userId);
|
||||||
|
if ($v['limit_type'] == 'all_total') { // 总流水
|
||||||
|
// 每日 每周 每月
|
||||||
|
if ($v['limit_time_type'] == "day" || $v['limit_time_type'] == "week" || $v['limit_time_type'] == "month") {
|
||||||
|
if ($v['now_value'] + $price > $v['limit_value']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 固定日期
|
||||||
|
if ($v['limit_time_type'] == 'fix') {
|
||||||
|
if ($v['fix_date'] == $nowDate) {
|
||||||
|
if ($v['now_value'] + $price > $v['limit_value']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($v['limit_type'] == 'user_one' && $v['user_id'] == $userId) { // 单玩家单笔
|
||||||
|
// 每日 每周 每月
|
||||||
|
if ($v['limit_time_type'] == "day" || $v['limit_time_type'] == "week" || $v['limit_time_type'] == "month") {
|
||||||
|
if ($price > $v['limit_value']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 固定日期
|
||||||
|
if ($v['limit_time_type'] == 'fix') {
|
||||||
|
if ($v['fix_date'] == $nowDate) {
|
||||||
|
if ($price > $v['limit_value']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($v['limit_type'] == 'user_total' && $v['user_id'] == $userId) { // 单玩家总流水
|
||||||
|
// 每日 每周 每月
|
||||||
|
if ($v['limit_time_type'] == "day" || $v['limit_time_type'] == "week" || $v['limit_time_type'] == "month") {
|
||||||
|
if ($v['now_value'] + $price > $v['limit_value']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// 固定日期
|
||||||
|
if ($v['limit_time_type'] == 'fix') {
|
||||||
|
if ($v['fix_date'] == $nowDate) {
|
||||||
|
if ($v['now_value'] + $price > $v['limit_value']) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 更新清零时间
|
||||||
|
private function updateClearTIme($conf, $userId) {
|
||||||
|
if (!$conf) return;
|
||||||
|
$data = array();
|
||||||
|
|
||||||
|
$startTime = substr($conf['start_time'], 0, 2) * 3600;
|
||||||
|
$startTime += substr($conf['start_time'], 2, 2) * 60;
|
||||||
|
$startTime += substr($conf['start_time'], 4, 2);
|
||||||
|
|
||||||
|
$isClear = false;
|
||||||
|
if ($conf['limit_time_type'] == 'day') {
|
||||||
|
$startTime += strtotime(date('Ymd'));
|
||||||
|
// 清零时间小于开始时间 需要清零
|
||||||
|
if ($conf['clear_time'] < $startTime) {
|
||||||
|
$isClear = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($conf['limit_time_type'] == 'week') {
|
||||||
|
$week_now = date("w")-1;
|
||||||
|
$week_start= strtotime("-{$week_now} days",time());
|
||||||
|
$startTime += $week_start;
|
||||||
|
// 清零时间小于开始时间 需要清零
|
||||||
|
if ($conf['clear_time'] < $startTime) {
|
||||||
|
$isClear = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($conf['limit_time_type'] == 'month') {
|
||||||
|
$startTime += strtotime(date('Ym'));
|
||||||
|
// 清零时间小于开始时间 需要清零
|
||||||
|
if ($conf['clear_time'] < $startTime) {
|
||||||
|
$isClear = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($isClear) {
|
||||||
|
$this->where(array(
|
||||||
|
'id' => $conf['id']
|
||||||
|
))->save(array(
|
||||||
|
'now_value' => 0,
|
||||||
|
'clear_time' => time(),
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Sdk\Model;
|
||||||
|
use Think\Model;
|
||||||
|
|
||||||
|
|
||||||
|
class ValueDetailLogModel extends Model {
|
||||||
|
|
||||||
|
const BALANCE = "balance"; // 余额明细 平台币
|
||||||
|
const BANDBI = "bangbi"; // 绑币明细
|
||||||
|
|
||||||
|
protected $_validate = array(
|
||||||
|
);
|
||||||
|
|
||||||
|
/* 自动完成规则 */
|
||||||
|
protected $_auto = array(
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 构造函数
|
||||||
|
* @param string $name 模型名称
|
||||||
|
* @param string $tablePrefix 表前缀
|
||||||
|
* @param mixed $connection 数据库连接信息
|
||||||
|
*/
|
||||||
|
public function __construct($name = '', $tablePrefix = '', $connection = '') {
|
||||||
|
/* 设置默认的表前缀 */
|
||||||
|
$this->tablePrefix ='tab_';
|
||||||
|
/* 执行构造方法 */
|
||||||
|
parent::__construct($name, $tablePrefix, $connection);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 新增数值变动记录
|
||||||
|
public function add($uid, $before, $value, $after, $type, $remark='', $payType=1) {
|
||||||
|
$this->add(array(
|
||||||
|
'user_id' => $uid,
|
||||||
|
'before_value' => $before,
|
||||||
|
'value' => $value,
|
||||||
|
'after_value' => $after,
|
||||||
|
'create_time' => time(),
|
||||||
|
'type' => $type,
|
||||||
|
'remark' => $remark,
|
||||||
|
'pay_type' => $payType
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue