194 lines
4.8 KiB
PHP
194 lines
4.8 KiB
PHP
<?php
|
|
declare (strict_types = 1);
|
|
|
|
namespace app\manager\model;
|
|
|
|
use think\admin\extend\DataExtend;
|
|
use think\Model;
|
|
|
|
/**
|
|
* 会员模型
|
|
*/
|
|
class Member extends Model
|
|
{
|
|
/**
|
|
* 数据表名称
|
|
* @var string
|
|
*/
|
|
protected $name = 'members';
|
|
|
|
/**
|
|
* 自动写入时间戳
|
|
* @var bool
|
|
*/
|
|
protected $autoWriteTimestamp = true;
|
|
|
|
/**
|
|
* 时间字段输出格式
|
|
* @var string
|
|
*/
|
|
protected $dateFormat = 'Y-m-d H:i:s';
|
|
|
|
/**
|
|
* 创建时间字段
|
|
* @var string
|
|
*/
|
|
protected $createTime = 'create_time';
|
|
|
|
/**
|
|
* 更新时间字段
|
|
* @var string
|
|
*/
|
|
protected $updateTime = 'update_time';
|
|
|
|
/**
|
|
* 追加属性
|
|
* @var array
|
|
*/
|
|
protected $append = [
|
|
'status_text'
|
|
];
|
|
|
|
/**
|
|
* 字段类型
|
|
* @var array
|
|
*/
|
|
protected $type = [
|
|
'id' => 'integer',
|
|
'status' => 'integer',
|
|
'usage_limit' => 'integer',
|
|
'used_count' => 'integer',
|
|
'points' => 'integer',
|
|
'level' => 'integer',
|
|
'balance' => 'float',
|
|
'expire_time' => 'datetime',
|
|
'last_login_time' => 'datetime',
|
|
'create_time' => 'datetime',
|
|
'update_time' => 'datetime'
|
|
];
|
|
|
|
/**
|
|
* 状态获取器
|
|
*/
|
|
public function getStatusTextAttr($value, $data)
|
|
{
|
|
return $data['status'] == 1 ? '正常' : '禁用';
|
|
}
|
|
|
|
/**
|
|
* 获取分页列表
|
|
* @param array $map 查询条件
|
|
* @param string $sort 排序规则
|
|
* @return \think\db\Query
|
|
*/
|
|
public static function mQuery($map = [], $sort = 'id desc')
|
|
{
|
|
$query = static::where($map);
|
|
// 会员搜索器
|
|
$query->withSearch(['username', 'nickname', 'mobile', 'email', 'status', 'order_id'], [
|
|
'username' => function ($query, $value) {
|
|
$query->whereLike('username|nickname', "%{$value}%");
|
|
},
|
|
'nickname' => function ($query, $value) {
|
|
$query->whereLike('nickname', "%{$value}%");
|
|
},
|
|
'mobile' => function ($query, $value) {
|
|
$query->whereLike('mobile', "%{$value}%");
|
|
},
|
|
'email' => function ($query, $value) {
|
|
$query->whereLike('email', "%{$value}%");
|
|
},
|
|
'order_id' => function ($query, $value) {
|
|
$query->whereLike('order_id', "%{$value}%");
|
|
},
|
|
'status' => function ($query, $value) {
|
|
$query->where(['status' => $value]);
|
|
}
|
|
]);
|
|
return $query->order($sort);
|
|
}
|
|
|
|
/**
|
|
* 表单处理
|
|
* @param string $template 模板名称
|
|
* @param array $data 表单数据
|
|
* @param bool $isUpdate 是否更新
|
|
* @return array|mixed
|
|
*/
|
|
public static function mForm($template = '', $data = [], $isUpdate = false)
|
|
{
|
|
if (request()->isPost()) {
|
|
$data = request()->post();
|
|
// 密码处理
|
|
if (isset($data['password']) && empty($data['password'])) {
|
|
unset($data['password']);
|
|
} elseif (isset($data['password'])) {
|
|
$data['password'] = password_hash($data['password'], PASSWORD_DEFAULT);
|
|
}
|
|
// 保存数据
|
|
if (isset($data['id']) && $data['id'] > 0) {
|
|
return static::update($data) !== false;
|
|
} else {
|
|
return static::create($data) !== false;
|
|
}
|
|
}
|
|
return $template;
|
|
}
|
|
|
|
/**
|
|
* 修改状态
|
|
* @return bool
|
|
*/
|
|
public static function mSave()
|
|
{
|
|
$data = input('post.');
|
|
return static::update($data) !== false;
|
|
}
|
|
|
|
/**
|
|
* 删除记录
|
|
* @return bool
|
|
*/
|
|
public static function mDelete()
|
|
{
|
|
$id = input('post.id');
|
|
return static::destroy($id) !== false;
|
|
}
|
|
|
|
/**
|
|
* 检查会员是否有效
|
|
* @return array
|
|
*/
|
|
public function isValid()
|
|
{
|
|
// 检查状态
|
|
if (!$this->status) {
|
|
return ['valid' => false, 'reason' => '账号已被禁用'];
|
|
}
|
|
|
|
// 检查有效期
|
|
if ($this->expire_time && $this->expire_time < date('Y-m-d H:i:s')) {
|
|
return ['valid' => false, 'reason' => '账号已过期'];
|
|
}
|
|
|
|
// 检查使用次数
|
|
if ($this->usage_limit > 0 && $this->used_count >= $this->usage_limit) {
|
|
return ['valid' => false, 'reason' => '使用次数已达上限'];
|
|
}
|
|
|
|
return ['valid' => true, 'reason' => ''];
|
|
}
|
|
|
|
/**
|
|
* 更新登录信息
|
|
* @param string $ip
|
|
* @return bool
|
|
*/
|
|
public function updateLoginInfo($ip = '')
|
|
{
|
|
$this->last_login_time = date('Y-m-d H:i:s');
|
|
$this->last_login_ip = $ip ?: request()->ip();
|
|
$this->used_count += 1;
|
|
return $this->save();
|
|
}
|
|
}
|