346 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			346 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | ||
| /**
 | ||
|  * @copyright Copyright (c) 2023-2024 美天智能科技
 | ||
|  * @author 李志强
 | ||
|  * @link http://www.meteteme.com
 | ||
|  */
 | ||
| 
 | ||
| declare(strict_types=1);
 | ||
| 
 | ||
| namespace app\admin\controller;
 | ||
| 
 | ||
| use app\base\BaseController;
 | ||
| use app\model\Admin as AdminList;
 | ||
| use app\admin\validate\AdminCheck;
 | ||
| use avatars\MDAvatars;
 | ||
| use Overtrue\Pinyin\Pinyin;
 | ||
| use think\exception\ValidateException;
 | ||
| use think\facade\Db;
 | ||
| use think\facade\View;
 | ||
| 
 | ||
| class User extends BaseController
 | ||
| {
 | ||
|     public function index()
 | ||
|     {
 | ||
|         if (request()->isAjax()) {
 | ||
|             $param = get_params();
 | ||
|             $where = array();
 | ||
|             if (!empty($param['keywords'])) {
 | ||
|                 $where[] = ['id|username|name|nickname|mobile|desc', 'like', '%' . $param['keywords'] . '%'];
 | ||
|             }
 | ||
|             $where[] = ['status', '<', 2];
 | ||
|             if (isset($param['status']) && $param['status'] != '') {
 | ||
|                 $where[] = ['status', '=', $param['status']];
 | ||
|             }
 | ||
|             if (!empty($param['type'])) {
 | ||
|                 $where[] = ['type', '=', $param['type']];
 | ||
|             }
 | ||
|             if (!empty($param['did'])) {
 | ||
|                 $department_array = get_department_son($param['did']);
 | ||
|                 $where[] = ['did', 'in', $department_array];
 | ||
|             }
 | ||
|             $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
 | ||
|             $admin = AdminList::where($where)
 | ||
|                 ->order('id desc')
 | ||
|                 ->paginate($rows, false, ['query' => $param])
 | ||
|                 ->each(function ($item, $key) {
 | ||
|                     $item->department = Db::name('Department')->where(['id' => $item->did])->value('title');
 | ||
|                     $item->position = Db::name('Position')->where(['id' => $item->position_id])->value('title');
 | ||
|                     $item->entry_time = empty($item->entry_time) ? '-' : date('Y-m-d', $item->entry_time);
 | ||
|                     $item->last_login_time = empty($item->last_login_time) ? '-' : date('Y-m-d H:i', $item->last_login_time);
 | ||
|                     $item->last_login_ip = empty($item->last_login_ip) ? '-' : $item->last_login_ip;
 | ||
|                 });
 | ||
|             return table_assign(0, '', $admin);
 | ||
|         } else {
 | ||
|             return view();
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //添加
 | ||
|     public function add()
 | ||
|     {
 | ||
|         $param = get_params();
 | ||
|         if (request()->isPost()) {
 | ||
|             $param['entry_time'] = strtotime($param['entry_time']);
 | ||
|             $param['nickname'] = $param['name'];
 | ||
|             $pinyin = new Pinyin();
 | ||
|             $username = $pinyin->name($param['name'], PINYIN_UMLAUT_V);
 | ||
|             $param['username'] = implode('', $username);
 | ||
|             if (!empty($param['id']) && $param['id'] > 0) {
 | ||
|                 $count = Db::name('Admin')->where([['username', 'like', $param['username'] . '%'], ['id', '<>', $param['id']]])->count();
 | ||
|                 if ($count > 0) {
 | ||
|                     $param['username'] = implode('', $username) . $count;
 | ||
|                 }
 | ||
|                 try {
 | ||
|                     validate(AdminCheck::class)->scene('edit')->check($param);
 | ||
|                 } catch (ValidateException $e) {
 | ||
|                     // 验证失败 输出错误信息
 | ||
|                     return to_assign(1, $e->getError());
 | ||
|                 }
 | ||
|                 // 启动事务
 | ||
|                 Db::startTrans();
 | ||
|                 try {
 | ||
|                     Db::name('Admin')->where(['id' => $param['id']])->strict(false)->field(true)->update($param);
 | ||
|                     if (!isset($param['thumb']) || $param['thumb'] == '') {
 | ||
|                         $char = mb_substr($param['name'], 0, 1, 'utf-8');
 | ||
|                         Db::name('Admin')->where('id', $param['id'])->update(['thumb' => $this->to_avatars($char)]);
 | ||
|                     }
 | ||
|                     add_log('edit', $param['id'], $param);
 | ||
|                     //清除菜单\权限缓存
 | ||
|                     clear_cache('adminMenu');
 | ||
|                     // 提交事务
 | ||
|                     Db::commit();
 | ||
|                 } catch (\Exception $e) {
 | ||
|                     // 回滚事务
 | ||
|                     Db::rollback();
 | ||
|                     return to_assign(1, '提交失败:' . $e->getMessage());
 | ||
|                 }
 | ||
|             } else {
 | ||
|                 $count = Db::name('Admin')->where([['username', 'like', $param['username'] . '%']])->count();
 | ||
|                 if ($count > 0) {
 | ||
|                     $param['username'] = implode('', $username) . $count;
 | ||
|                 }
 | ||
|                 try {
 | ||
|                     validate(AdminCheck::class)->scene('add')->check($param);
 | ||
|                 } catch (ValidateException $e) {
 | ||
|                     // 验证失败 输出错误信息
 | ||
|                     return to_assign(1, $e->getError());
 | ||
|                 }
 | ||
|                 $param['salt'] = set_salt(20);
 | ||
|                 $param['pwd'] = set_password($param['reg_pwd'], $param['salt']);
 | ||
|                 // 启动事务
 | ||
|                 Db::startTrans();
 | ||
|                 try {
 | ||
|                     $uid = Db::name('Admin')->strict(false)->field(true)->insertGetId($param);
 | ||
|                     if (!isset($param['thumb']) || $param['thumb'] == '') {
 | ||
|                         $char = mb_substr($param['name'], 0, 1, 'utf-8');
 | ||
|                         Db::name('Admin')->where('id', $uid)->update(['thumb' => $this->to_avatars($char)]);
 | ||
|                     }
 | ||
|                     add_log('add', $uid, $param);
 | ||
|                     // 提交事务
 | ||
|                     Db::commit();
 | ||
|                 } catch (\Exception $e) {
 | ||
|                     // 回滚事务
 | ||
|                     Db::rollback();
 | ||
|                     return to_assign(1, '提交失败:' . $e->getMessage());
 | ||
|                 }
 | ||
|             }
 | ||
|             return to_assign();
 | ||
|         } else {
 | ||
|             $id = isset($param['id']) ? $param['id'] : 0;
 | ||
|             $department = set_recursion(get_department());
 | ||
|             $position = Db::name('Position')->where('status', '>=', 0)->order('create_time asc')->select();
 | ||
|             if ($id > 0) {
 | ||
|                 $detail = get_admin($id);
 | ||
|                 View::assign('detail', $detail);
 | ||
|             } else {
 | ||
|                 //初始化密码
 | ||
|                 $reg_pwd = set_salt(6);
 | ||
|                 View::assign('reg_pwd', $reg_pwd);
 | ||
|             }
 | ||
|             View::assign('department', $department);
 | ||
|             View::assign('position', $position);
 | ||
|             View::assign('id', $id);
 | ||
|             return view();
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //生成头像
 | ||
|     public function to_avatars($char)
 | ||
|     {
 | ||
|         $defaultData = array(
 | ||
|             'A',
 | ||
|             'B',
 | ||
|             'C',
 | ||
|             'D',
 | ||
|             'E',
 | ||
|             'F',
 | ||
|             'G',
 | ||
|             'H',
 | ||
|             'I',
 | ||
|             'J',
 | ||
|             'K',
 | ||
|             'L',
 | ||
|             'M',
 | ||
|             'N',
 | ||
|             'O',
 | ||
|             'P',
 | ||
|             'Q',
 | ||
|             'R',
 | ||
|             'S',
 | ||
|             'T',
 | ||
|             'U',
 | ||
|             'V',
 | ||
|             'W',
 | ||
|             'S',
 | ||
|             'Y',
 | ||
|             'Z',
 | ||
|             '0',
 | ||
|             '1',
 | ||
|             '2',
 | ||
|             '3',
 | ||
|             '4',
 | ||
|             '5',
 | ||
|             '6',
 | ||
|             '7',
 | ||
|             '8',
 | ||
|             '9',
 | ||
|             '零',
 | ||
|             '壹',
 | ||
|             '贰',
 | ||
|             '叁',
 | ||
|             '肆',
 | ||
|             '伍',
 | ||
|             '陆',
 | ||
|             '柒',
 | ||
|             '捌',
 | ||
|             '玖',
 | ||
|             '拾',
 | ||
|             '一',
 | ||
|             '二',
 | ||
|             '三',
 | ||
|             '四',
 | ||
|             '五',
 | ||
|             '六',
 | ||
|             '七',
 | ||
|             '八',
 | ||
|             '九',
 | ||
|             '十'
 | ||
|         );
 | ||
|         if (isset($char)) {
 | ||
|             $Char = $char;
 | ||
|         } else {
 | ||
|             $Char = $defaultData[mt_rand(0, count($defaultData) - 1)];
 | ||
|         }
 | ||
|         $OutputSize = min(512, empty($_GET['size']) ? 36 : intval($_GET['size']));
 | ||
| 
 | ||
|         $Avatar = new MDAvatars($Char, 256, 1);
 | ||
|         $avatar_name = '/avatars/avatar_256_' . set_salt(10) . time() . '.png';
 | ||
|         $path = get_config('filesystem.disks.public.url') . $avatar_name;
 | ||
|         $res = $Avatar->Save('.' . $path, 256);
 | ||
|         $Avatar->Free();
 | ||
|         return $path;
 | ||
|     }
 | ||
| 
 | ||
|     //查看
 | ||
|     public function view()
 | ||
|     {
 | ||
|         $id = get_params('id');
 | ||
|         $detail = get_admin($id);
 | ||
|         //查询所有菜单和权限节点
 | ||
|         $menu = Db::name('AdminRule')->where(['menu' => 1])->order('sort asc,id asc')->select()->toArray();
 | ||
|         $rule = Db::name('AdminRule')->order('sort asc,id asc')->select()->toArray();
 | ||
| 
 | ||
|         //查询用户拥有的查单和节点
 | ||
|         $user_groups = Db::name('PositionGroup')
 | ||
|             ->alias('a')
 | ||
|             ->join("AdminGroup g", "a.group_id=g.id", 'LEFT')
 | ||
|             ->where([['a.pid', '=', $detail["position_id"]], ['g.status', '=', 1]])
 | ||
|             ->select()
 | ||
|             ->toArray();
 | ||
|         $groups = $user_groups ?: [];
 | ||
| 
 | ||
|         $rules = [];
 | ||
|         foreach ($groups as $g) {
 | ||
|             $rules = array_merge($rules, explode(',', trim($g['rules'], ',')));
 | ||
|         }
 | ||
|         $rules = array_unique($rules);
 | ||
| 
 | ||
|         //数据嵌套
 | ||
|         $role_rule = create_tree_list(0, $rule, $rules);
 | ||
| 
 | ||
|         View::assign('role_rule', $role_rule);
 | ||
|         View::assign('detail', $detail);
 | ||
|         add_log('view', get_params('id'));
 | ||
|         return view();
 | ||
|     }
 | ||
| 
 | ||
|     //禁用,恢复
 | ||
|     public function set()
 | ||
|     {
 | ||
|         if (request()->isPost()) {
 | ||
|             $type = get_params("type");
 | ||
|             $ids = get_params("ids");
 | ||
|             $idArray = explode(',', $ids);
 | ||
|             $list = [];
 | ||
|             foreach ($idArray as $key => $val) {
 | ||
|                 if ($val == 1) {
 | ||
|                     continue;
 | ||
|                 }
 | ||
|                 $list[] = [
 | ||
|                     'status' => $type,
 | ||
|                     'id' => $val,
 | ||
|                     'update_time' => time(),
 | ||
|                 ];
 | ||
|             }
 | ||
|             foreach ($list as $key => $v) {
 | ||
|                 if (Db::name('Admin')->update($v) !== false) {
 | ||
|                     if ($type == 0) {
 | ||
|                         add_log('disable', $v['id']);
 | ||
|                     } else if ($type == 1) {
 | ||
|                         add_log('recover', $v['id']);
 | ||
|                     }
 | ||
|                 }
 | ||
|             }
 | ||
|             return to_assign(0, '操作成功');
 | ||
|         } else {
 | ||
|             return to_assign(1, "错误的请求");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //重置密码
 | ||
|     public function reset()
 | ||
|     {
 | ||
|         if (request()->isPost()) {
 | ||
|             $id = get_params("id");
 | ||
|             if ($id == 1) {
 | ||
|                 return to_assign(1, '该账号是超级管理员,不允许重置');
 | ||
|             }
 | ||
|             $new_pwd = set_salt(6);
 | ||
|             $salt = set_salt(20);
 | ||
|             $data = [
 | ||
|                 'reg_pwd' => $new_pwd,
 | ||
|                 'salt' => $salt,
 | ||
|                 'pwd' => set_password($new_pwd, $salt),
 | ||
|                 'id' => $id,
 | ||
|                 'update_time' => time(),
 | ||
|             ];
 | ||
|             if (Db::name('Admin')->update($data) !== false) {
 | ||
|                 add_log('reset', $id);
 | ||
|                 return to_assign(0, '操作成功');
 | ||
|             } else {
 | ||
|                 return to_assign(1, '操作失败');
 | ||
|             }
 | ||
|         } else {
 | ||
|             return to_assign(1, "错误的请求");
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
|     //获取员工数据
 | ||
|     public function getuserinfo() {
 | ||
|         try {
 | ||
|             // 查询数据
 | ||
|             $list = Db::name('Admin')
 | ||
|                 ->field('id, nickname') // 选择所需字段
 | ||
|                 ->where('status', 1) // 增加条件,status 值为 1
 | ||
|                 ->order('id desc') // 按 id 倒序排序
 | ||
|                 ->select(); // 获取数据
 | ||
| 
 | ||
|             // 返回成功响应
 | ||
|             return json([
 | ||
|                 'code' => 1, // 成功状态码
 | ||
|                 'msg' => '获取成功', // 提示信息
 | ||
|                 'data' => $list // 数据展示
 | ||
|             ]);
 | ||
|         } catch (\Exception $e) {
 | ||
|             // 捕获异常并返回错误信息
 | ||
|             return json([
 | ||
|                 'code' => 0, // 失败状态码
 | ||
|                 'msg' => '获取失败: ' . $e->getMessage(), // 错误信息
 | ||
|                 'data' => [] // 空数据
 | ||
|             ]);
 | ||
|         }
 | ||
|     }
 | ||
| 
 | ||
| 
 | ||
| } |