apeblog/app/admin/model/Admin.php

129 lines
4.2 KiB
PHP

<?php
namespace app\admin\model;
use app\common\constant\Data;
use app\common\model\BaseModel;
use think\db\exception\DataNotFoundException;
use think\db\exception\DbException;
use think\db\exception\ModelNotFoundException;
use think\facade\Session;
/**
* 管理员管理
* Class Admin
* @package app\admin\model
*/
class Admin extends BaseModel
{
/**
* 登录
* @param string $username
* @param string $pwd
* @return bool
* @throws DataNotFoundException
* @throws DbException
* @throws ModelNotFoundException
*/
public static function login(string $username, string $pwd): bool
{
$info = (new Admin)->where("username|tel", "=", $username)->find();
if (empty($info)) return self::setErrorInfo("登录账号不存在");
if ($info['password'] != md5(md5($pwd))) return self::setErrorInfo("密码不正确!");
if ($info['status'] != 1) return self::setErrorInfo("账号已被冻结!");
self::setLoginInfo($info);
return true;
}
/**
* 设置登录信息
* @param $info
* @return bool
*/
public static function setLoginInfo($info): bool
{
unset($info->password);//去除密码字段
$info->role_auth = AdminRole::getAuth($info['role_id'] ?? 0);//提前缓存auth字段避免频繁查询
Session::set(Data::SESSION_KEY_ADMIN_ID, $info['id']);
Session::set(Data::SESSION_KEY_ADMIN_INFO, $info->toArray());
event("AdminLog", [$info->toArray(), "admin", "login", "login"]);
return true;
}
/**
* 退出登录
*/
public static function clearLoginInfo(): bool
{
Session::delete(Data::SESSION_KEY_ADMIN_ID);
Session::delete(Data::SESSION_KEY_ADMIN_INFO);
Session::clear();
return true;
}
/**
* 列表
* @param array $where
* @return array
* @throws DataNotFoundException
* @throws DbException
* @throws ModelNotFoundException
*/
public static function systemPage(array $where): array
{
$model = new self;
if ($where['username'] != '') $model = $model->where("username|id|nickname", "like", "%$where[username]%");
if ($where['start_time'] != '') $model = $model->where("create_time", ">", strtotime($where['start_time'] . " 00:00:00"));
if ($where['end_time'] != '') $model = $model->where("create_time", "<", strtotime($where['end_time'] . " 23:59:59"));
if ($where['tel'] != '') $model = $model->where("tel|mail", "like", "%$where[tel]%");
if ($where['status'] != '') $model = $model->where("status", $where['status']);
if ($where['role_id'] != '') $model = $model->where("role_id", $where['role_id']);
$count = self::count();
if ($where['page'] && $where['limit']) $model = $model->page((int)$where['page'], (int)$where['limit']);
$data = $model->select()->each(function ($item) {
unset($item['password']);
// 用户信息
$info = self::getAdminInfoById((int)$item['create_user']);
$item['create_user'] = $info ? $info['nickname'] : $item['create_user'];
$item['role_id'] = AdminRole::getAuthNameById((int)$item['role_id']);
});
$data = $data ? $data->toArray() : [];
return compact("data", "count");
}
/**
* 获取账号信息
* @param int $id
* @param string $field
* @return array
* @throws DataNotFoundException
* @throws DbException
* @throws ModelNotFoundException
*/
public static function getAdminInfoById(int $id, string $field = '*'): array
{
$model = new self;
$model = $model->where("id", $id);
$model = $model->field($field);
$info = $model->find();
unset($info->password);
return $info ? $info->toArray() : [];
}
/**
* 人员列表
* @return array
* @throws DataNotFoundException
* @throws DbException
* @throws ModelNotFoundException
*/
public static function lst()
{
$model = new self;
$model = $model->where("status", 1);
$model = $model->field("id,realname");
$data = $model->select();
return $data ? $data->toArray() : [];
}
}