dggmyyc/application/common/model/User.php

125 lines
3.6 KiB
PHP
Executable File

<?php
/**
* 用户模型
*/
namespace app\common\model;
use think\model\concern\SoftDelete;
use think\db;
class User extends Model
{
use SoftDelete;
public $softDelete = true;
protected $name = 'user';
protected $autoWriteTimestamp = true;
//可搜索字段
protected $searchField = ['username', 'mobile', 'nickname',];
//是否启用用户体验收益资格
public function getExperienceTextAttr($value, $data)
{
return self::EXPERIENCE_TEXT[$data['is_experience']];
}
//是否启用获取器
public function getStatusTextAttr($value, $data)
{
return self::BOOLEAN_TEXT[$data['status']];
}
//用户等级
public function getUserLevelIdTextAttr($value, $data)
{
return self::LEVL_TEXT[$data['user_level_id']];
}
//关联用户等级
public function userLevel()
{
return $this->belongsTo(UserLevel::class);
}
public static function getUserInfo($userId)
{
$user = self::field('id,sn,nickname,avatar,mobile')->findOrEmpty($userId)->toArray();
if (empty($user)) {
return '系统';
}
return $user;
}
/**
* 填写邀请码
* @param $code
* @param $my_id
* @return bool|string
*/
public static function code($code, $my_id)
{
$my_leader = Db::name('user')
->field(['id', 'first_leader', 'second_leader', 'ancestor_relation'])
->where(['distribution_code' => $code])
->find();
//更新我的第一上级、第二上级、关系链
$my_leader_id = $my_leader['id'];
$my_first_leader = $my_leader['first_leader'];
$my_leader['ancestor_relation'] = boolval($my_leader['ancestor_relation']) ? $my_leader['ancestor_relation'] : '';
$my_ancestor_relation = trim("{$my_leader_id},{$my_leader['ancestor_relation']}", ',');
$user = User::findOrEmpty($my_id);
// 旧关系链
if (!empty($user->ancestor_relation)) {
$old_ancestor_relation = $user->id . ',' .$user->ancestor_relation;
} else {
$old_ancestor_relation = $user->id;
}
$data = [
'first_leader' => $my_leader_id,
'second_leader' => $my_first_leader,
'ancestor_relation' => $my_ancestor_relation,
];
Db::name('user')
->where(['id' => $my_id])
->update($data);
//更新我向下一级的第二上级
$data = [
'second_leader' => $my_leader_id,
];
Db::name('user')
->where(['first_leader' => $my_id])
->update($data);
//更新与我相关的所有关系链
Db::name('user')
->where("find_in_set({$my_id},ancestor_relation)")
->exp('ancestor_relation', "replace(ancestor_relation,'{$old_ancestor_relation}','" . trim("{$my_id},{$my_ancestor_relation}", ',') . "')")
->update();
}
//用户登录
public static function login($param)
{
$username = $param['username'];
$password = $param['password'];
$user = self::get(['username' => $username]);
if (!$user) {
exception('用户不存在');
}
if (!password_verify($password, $user->password)) {
exception('密码错误');
}
if ((int)$user->status !== 1) {
exception('用户被冻结');
}
return $user;
}
}