96 lines
2.5 KiB
PHP
96 lines
2.5 KiB
PHP
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | saiadmin [ saiadmin快速开发框架 ]
|
|
// +----------------------------------------------------------------------
|
|
// | Author: sai <1430792918@qq.com>
|
|
// +----------------------------------------------------------------------
|
|
namespace plugin\saiadmin\app\model\system;
|
|
|
|
use plugin\saiadmin\basic\think\BaseModel;
|
|
|
|
/**
|
|
* 用户信息模型
|
|
*
|
|
* sa_system_user 用户表
|
|
*
|
|
* @property $id
|
|
* @property $username 登录账号
|
|
* @property $password 加密密码
|
|
* @property $realname 真实姓名
|
|
* @property $gender 性别
|
|
* @property $avatar 头像
|
|
* @property $email 邮箱
|
|
* @property $phone 手机号
|
|
* @property $signed 个性签名
|
|
* @property $dashboard 工作台
|
|
* @property $dept_id 主归属部门
|
|
* @property $is_super 是否超级管理员: 1是
|
|
* @property $status 状态: 1启用, 2禁用
|
|
* @property $remark 备注
|
|
* @property $login_time 最后登录时间
|
|
* @property $login_ip 最后登录IP
|
|
* @property $created_by 创建者
|
|
* @property $updated_by 更新者
|
|
* @property $create_time 创建时间
|
|
* @property $update_time 修改时间
|
|
*/
|
|
class SystemUser extends BaseModel
|
|
{
|
|
|
|
/**
|
|
* 数据表主键
|
|
* @var string
|
|
*/
|
|
protected $pk = 'id';
|
|
|
|
/**
|
|
* 数据表完整名称
|
|
* @var string
|
|
*/
|
|
protected $table = 'sa_system_user';
|
|
|
|
public function searchKeywordAttr($query, $value)
|
|
{
|
|
if ($value) {
|
|
$query->where('username|realname|phone', 'like', '%' . $value . '%');
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 权限范围 - 过滤部门用户
|
|
*/
|
|
public function scopeAuth($query, $value)
|
|
{
|
|
if (!empty($value)) {
|
|
$deptIds = [$value['id']];
|
|
$deptLevel = $value['level'] . $value['id'] . ',';
|
|
$dept_ids = SystemDept::whereLike('level', $deptLevel . '%')->column('id');
|
|
$deptIds = array_merge($deptIds, $dept_ids);
|
|
$query->whereIn('dept_id', $deptIds);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 通过中间表关联角色
|
|
*/
|
|
public function roles()
|
|
{
|
|
return $this->belongsToMany(SystemRole::class, SystemUserRole::class, 'role_id', 'user_id');
|
|
}
|
|
|
|
/**
|
|
* 通过中间表关联岗位
|
|
*/
|
|
public function posts()
|
|
{
|
|
return $this->belongsToMany(SystemPost::class, SystemUserPost::class, 'post_id', 'user_id');
|
|
}
|
|
|
|
/**
|
|
* 通过中间表关联部门
|
|
*/
|
|
public function depts()
|
|
{
|
|
return $this->belongsTo(SystemDept::class, 'dept_id', 'id');
|
|
}
|
|
} |