Admin.php 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2021 勾股工作室
  4. * @license https://opensource.org/licenses/Apache-2.0
  5. * @link https://www.gougucms.com
  6. */
  7. declare (strict_types = 1);
  8. namespace app\admin\controller;
  9. use app\admin\BaseController;
  10. use app\admin\model\Admin as AdminList;
  11. use app\admin\validate\AdminCheck;
  12. use avatars\MDAvatars;
  13. use think\exception\ValidateException;
  14. use think\facade\Db;
  15. use think\facade\View;
  16. use think\facade\Session;
  17. use think\App;
  18. use think\facade\Cache;
  19. use app\admin\controller\Role;
  20. use app\admin\model\Department as DepartmentModel;
  21. class Admin extends BaseController
  22. {
  23. public function __construct(App $app)
  24. {
  25. parent::__construct($app);
  26. $this->Role = new Role($this->app);
  27. $this->Department = new DepartmentModel();
  28. }
  29. public function index()
  30. {
  31. if (request()->isAjax()) {
  32. // 获取单位名称
  33. $session_admin = get_config('app.session_admin');
  34. $id = Session::get($session_admin)['id'];
  35. $unit_name = Db::name('admin')->where('id', $id)->value('unit_name');
  36. $admin_permission = Db::name('admin')->where('id', $id)->value('permission');
  37. // halt($unit_name);
  38. $param = get_params();
  39. $where = array();
  40. if (!empty($param['keywords'])) {
  41. $where[] = ['nickname', 'like', '%'.$param['keywords'].'%'];
  42. $where[] = ['username', 'like', '%'.$param['keywords'].'%'];
  43. $where[] = ['mobile', 'like', '%'.$param['keywords'].'%'];
  44. $where[] = ['nickname', '=', $param['keywords']];
  45. $where[] = ['username', '=', $param['keywords']];
  46. $where[] = ['mobile', '=', $param['keywords']];
  47. }
  48. // halt($where);
  49. $permission = array();
  50. if($admin_permission == 0){
  51. $permission[] = ['unit_name', '=', $unit_name];
  52. }
  53. $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
  54. // halt($where,$admin_permission);
  55. $admin = AdminList::whereOr($where)->with('Department')
  56. ->where($permission)
  57. ->where('status', '>=', 0)
  58. ->order('create_time asc')
  59. ->paginate($rows, false, ['query' => $param])
  60. ->each(function ($item, $key) {
  61. $groupId = Db::name('AdminGroupAccess')->where(['uid' => $item->id])->column('group_id');
  62. $groupName = Db::name('AdminGroup')->where('id', 'in', $groupId)->column('title');
  63. $item->groupName = implode(',', $groupName);
  64. $item->last_login_time = empty($item->last_login_time) ? '-' : date('Y-m-d H:i', $item->last_login_time);
  65. })->toArray();
  66. // dump($admin);
  67. if(get_login_admin('user_type') !== -1){
  68. $admin_ = $admin['data'];
  69. unset($admin['data'][count($admin['data']) - 1]); //移除超级管理
  70. }
  71. return table_assign(0, '', $admin);
  72. } else {
  73. View::assign('user_type', get_login_admin('user_type'));
  74. return view();
  75. }
  76. }
  77. //添加
  78. public function add()
  79. {
  80. if (request()->isAjax()) {
  81. $param = get_params();
  82. // halt($param);
  83. if (!empty($param['id']) && $param['id'] > 0) { //对已存在账号的编辑
  84. try {
  85. validate(AdminCheck::class)->scene('edit')->check($param);
  86. } catch (ValidateException $e) {
  87. // 验证失败 输出错误信息
  88. return to_assign(1, $e->getError());
  89. }
  90. // halt($param['edit_pwd'],validate(AdminCheck::class)->scene('edit')->check($param));
  91. if (!empty($param['edit_pwd'])) {
  92. //重置密码
  93. if (empty($param['edit_pwd_confirm']) or $param['edit_pwd_confirm'] !== $param['edit_pwd']) {
  94. return to_assign(1, '两次密码不一致');
  95. }
  96. $param['salt'] = set_salt(20);
  97. $param['pwd'] = set_password($param['edit_pwd'], $param['salt']);
  98. }
  99. // halt($param['id'],validate(AdminCheck::class)->scene('edit')->check($param));
  100. // halt($param);
  101. // 启动事务
  102. Db::startTrans();
  103. try {
  104. // halt($param);
  105. $param['last_password_change'] = time();
  106. Db::name('Admin')->where(['id' => $param['id']])->strict(false)->field(true)->update($param); //更新密码
  107. Db::name('AdminGroupAccess')->where(['uid' => $param['id']])->delete(); //先删除权限组
  108. foreach ($param['group_id'] as $k => $v) {
  109. //为了系统安全,只有系统所有者才可创建id为1的管理员分组
  110. if ($v == 1 and get_login_admin('id') !== 1) {
  111. throw new ValidateException("你没有权限创建系统所有者", 1);
  112. }
  113. $data[$k] = [
  114. 'uid' => $param['id'],
  115. 'group_id' => $v,
  116. ];
  117. $param['admin_group_id'] = $v;
  118. }
  119. Db::name('AdminGroupAccess')->strict(false)->field(true)->insertAll($data); //再新增权限组
  120. if (!isset($param['thumb']) || $param['thumb'] == '') {
  121. $char = mb_substr($param['nickname'], 0, 1, 'utf-8');
  122. Db::name('Admin')->where('id', $param['id'])->update(['thumb' => $this->to_avatars($char)]);
  123. }
  124. //
  125. if($param['is_principal'] == 1){
  126. // $res = Db::name('Department')->where('id', $param['did'])->value('leader_id');
  127. // halt($res);
  128. $res = Db::name('Department')->where('id', $param['did'])->update(['leader_id' => $param['id']]);
  129. // $this->Department->where('id', $param['did'])->force()->save(['leader_id' => $param['id']]);
  130. // halt($res);
  131. }
  132. // 获取单位名称
  133. $unit_name = self::get_unitName($param['id']);
  134. $data = [
  135. 'unit_name' => $unit_name,
  136. 'user_type' => Db::name('Department')->where('id', $unit_name)->value('type'),
  137. 'admin_group_id' => $param['admin_group_id'],
  138. ];
  139. // unset($data['group_id']);
  140. // halt($data);
  141. $res = Db::name('admin')->where('id', $param['id'])->data($data)->update();
  142. // halt($res);
  143. add_log('edit', $param['id'], $param);
  144. //清除菜单\权限缓存
  145. clear_cache('adminMenu');
  146. clear_cache('adminRules');
  147. // 提交事务
  148. Db::commit();
  149. } catch (\Exception $e) {
  150. // 回滚事务
  151. Db::rollback();
  152. return to_assign(1, '提交失败:' . $e->getMessage());
  153. }
  154. } else { //新增账号
  155. // halt($param);
  156. try {
  157. validate(AdminCheck::class)->scene('add')->check($param);
  158. } catch (ValidateException $e) {
  159. // 验证失败 输出错误信息
  160. return to_assign(1, $e->getError());
  161. }
  162. $param['salt'] = set_salt(20);
  163. $param['pwd'] = set_password($param['pwd'], $param['salt']);
  164. $param['last_password_change'] = time();
  165. // 启动事务
  166. Db::startTrans();
  167. try {
  168. foreach ($param['group_id'] as $k => $v) {
  169. $param['admin_group_id'] = $v;
  170. }
  171. // halt($param);
  172. $uid = Db::name('Admin')->strict(false)->field(true)->insertGetId($param);
  173. unset($param['admin_group_id']);
  174. if($param['is_principal'] == 1){
  175. Db::name('department')->where('id', $param['did'])->data(['leader_id' => $uid])->update();
  176. }
  177. // halt($uid);
  178. foreach ($param['group_id'] as $k => $v) {
  179. //为了系统安全,只有系统所有者才可创建id为1的管理员分组
  180. if ($v == 1 and get_login_admin('id') !== 1) {
  181. throw new ValidateException("你没有权限创建系统所有者", 1);
  182. }
  183. $data[$k] = [
  184. 'uid' => $uid,
  185. 'group_id' => $v,
  186. ];
  187. }
  188. Db::name('AdminGroupAccess')->strict(false)->field(true)->insertAll($data);
  189. if (!isset($param['thumb']) || $param['thumb'] == '') {
  190. $char = mb_substr($param['nickname'], 0, 1, 'utf-8');
  191. Db::name('Admin')->where('id', $uid)->update(['thumb' => $this->to_avatars($char)]);
  192. }
  193. // 获取单位名称
  194. $unit_name = self::get_unitName($uid);
  195. $data = [
  196. 'unit_name' => $unit_name,
  197. 'user_type' => Db::name('Department')->where('id', $unit_name)->value('type'),
  198. ];
  199. // halt($data);
  200. Db::name('admin')->where('id', $uid)->data($data)->update();
  201. add_log('add', $uid, $param);
  202. // 提交事务
  203. Db::commit();
  204. } catch (\Exception $e) {
  205. // 回滚事务
  206. Db::rollback();
  207. return to_assign(1, '提交失败:' . $e->getMessage());
  208. }
  209. }
  210. return to_assign(0,"操作成功");
  211. }else{
  212. $id = empty(get_params('id')) ? 0 : get_params('id');
  213. // dump($id);
  214. $permission = Db::name('admin')->where('id', get_login_admin('id'))->value('permission');
  215. $unit_name = Db::name('admin')->where('id', get_login_admin('id'))->value('unit_name');
  216. $group_id = Db::name('AdminGroupAccess')->where('uid', get_login_admin('id'))->value('group_id');
  217. $where_d = array();
  218. $where_p = array();
  219. $where_g = array();
  220. if($permission == 0){
  221. $where_d[] = ['unit_name', '=', $unit_name];
  222. $where_p[] = ['did', '=', $unit_name];
  223. $where_g[] = [
  224. ['unit_name', '=', $unit_name],
  225. ];
  226. }
  227. $department = Db::name('Department')
  228. ->where('status', '>=', 0)
  229. ->where($where_d)
  230. ->select()
  231. ->toArray();
  232. // dump($department);
  233. $department = set_recursion($department);
  234. // dump($department);
  235. $position = Db::name('Position')
  236. ->where('status', '>=', 0)
  237. ->where($where_p)
  238. ->order('create_time asc')
  239. ->select()
  240. ->toArray();
  241. foreach($position as $key => $value){
  242. $dep = Db::name('Department')->where('id', $value['did'])->value('title');
  243. $position[$key]['did_title'] = $dep;
  244. }
  245. $group = Db::name('AdminGroup')
  246. ->where($where_g)
  247. ->select()->toarray();
  248. if($permission == 1){
  249. $group = Db::name('AdminGroup')
  250. ->where('unit_name', '=', $unit_name)
  251. ->select()->toarray();
  252. // dump($group);
  253. }
  254. $group_mine = Db::name('AdminGroup')->where('id', $group_id)->select()->toArray();
  255. // dump($permission);
  256. if(get_login_admin('user_type') == -1){
  257. unset($group[0]); //移除超管权限组
  258. }
  259. $group = array_merge($group_mine, $group);
  260. if ($id > 0) {
  261. $admin = get_admin(get_params('id'));
  262. // dump($admin);
  263. // $did = get_login_admin('did');
  264. $leader_id = Db::name('Department')->where('id', $admin['did'])->value('leader_id');
  265. // dump($leader_id);
  266. if($leader_id == $id){
  267. $is_principal = 1;
  268. }else{
  269. $is_principal = 0;
  270. }
  271. View::assign('is_principal', $is_principal);
  272. View::assign('admin', $admin);
  273. }
  274. // dump($group);
  275. // dump($department);
  276. View::assign('permission', $permission);
  277. View::assign('department', $department);
  278. View::assign('position', $position);
  279. View::assign('group', $group);
  280. View::assign('id', $id);
  281. return view();
  282. }
  283. }
  284. public function to_avatars($char)
  285. {
  286. $defaultData = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N',
  287. 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'S', 'Y', 'Z',
  288. '0', '1', '2', '3', '4', '5', '6', '7', '8', '9',
  289. '零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖', '拾',
  290. '一', '二', '三', '四', '五', '六', '七', '八', '九', '十');
  291. if (isset($char)) {
  292. $Char = $char;
  293. } else {
  294. $Char = $defaultData[mt_rand(0, count($defaultData) - 1)];
  295. }
  296. $OutputSize = min(512, empty($_GET['size']) ? 36 : intval($_GET['size']));
  297. $Avatar = new MDAvatars($Char, 256, 1);
  298. $avatar_name = '/avatars/avatar_256_' . set_salt(10) . time() . '.png';
  299. $path = get_config('filesystem.disks.public.url') . $avatar_name;
  300. $res = $Avatar->Save('.' . $path, 256);
  301. $Avatar->Free();
  302. /*
  303. if ($res) {
  304. //写入到附件表
  305. $data = [];
  306. $data['filepath'] = $path;
  307. $data['name'] = $Char;
  308. $data['mimetype'] = 'image/png';
  309. $data['fileext'] = 'png';
  310. $data['filesize'] = 0;
  311. $data['filename'] = $avatar_name;
  312. $data['sha1'] = '';
  313. $data['md5'] = '';
  314. $data['module'] = \think\facade\App::initialize()->http->getName();
  315. $data['action'] = app('request')->action();
  316. $data['uploadip'] = app('request')->ip();
  317. $data['create_time'] = time();
  318. $data['user_id'] = get_login_admin('id') ? get_login_admin('id') : 0;
  319. if ($data['module'] = 'admin') {
  320. //通过后台上传的文件直接审核通过
  321. $data['status'] = 1;
  322. $data['admin_id'] = $data['user_id'];
  323. $data['audit_time'] = time();
  324. }
  325. $data['use'] = 'avatar'; //附件用处
  326. $fid = Db::name('file')->insertGetId($data);
  327. return $fid;
  328. }
  329. */
  330. return $path;
  331. }
  332. //查看
  333. public function view()
  334. {
  335. $id = get_params('id');
  336. $rule = get_admin_rule();
  337. $user_groups = Db::name('AdminGroupAccess')
  338. ->alias('a')
  339. ->join("AdminGroup g", "a.group_id=g.id", 'LEFT')
  340. ->where("a.uid='{$id}' and g.status='1'")
  341. ->select()
  342. ->toArray();
  343. $groups = $user_groups ?: [];
  344. $rules = [];
  345. foreach ($groups as $g) {
  346. $rules = array_merge($rules, explode(',', trim($g['rules'], ',')));
  347. }
  348. $rules = array_unique($rules);
  349. $role_rule = create_tree_list(0, $rule, $rules);
  350. $role_rule = $this->Role->remove_checked_false($role_rule);
  351. $department = get_department();
  352. // dump($department);
  353. $position = Db::name('Position')->where('status', '>=', 0)->order('create_time asc')->select();
  354. View::assign('department', $department);
  355. View::assign('position', $position);
  356. View::assign('role_rule', $role_rule);
  357. View::assign('admin', get_admin($id));
  358. add_log('view', get_params('id'));
  359. return view('', ['admin' => get_admin(get_params('id'))]);
  360. }
  361. //删除
  362. public function delete()
  363. {
  364. $id = get_params("id");
  365. if($id == 1){
  366. return to_assign(0, "超级管理员,不能删除");
  367. }
  368. $data['status'] = '-1';
  369. $data['id'] = $id;
  370. $data['update_time'] = time();
  371. if (Db::name('Admin')->update($data) !== false) {
  372. add_log('delete', $id);
  373. return to_assign(0, "删除管理员成功");
  374. } else {
  375. return to_assign(1, "删除失败");
  376. }
  377. }
  378. //管理员操作日志
  379. public function log()
  380. {
  381. if (request()->isAjax()) {
  382. $param = get_params();
  383. $where = array();
  384. if (!empty($param['keywords'])) {
  385. $where[] = ['nickname|rule_menu|param_id', 'like', '%' . $param['keywords'] . '%'];
  386. }
  387. if (!empty($param['title_cate'])) {
  388. $where['title'] = $param['title_cate'];
  389. }
  390. if (!empty($param['rule_menu'])) {
  391. $where['rule_menu'] = $param['rule_menu'];
  392. }
  393. $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit'];
  394. $content = DB::name('AdminLog')
  395. ->field("id,uid,nickname,title,content,rule_menu,ip,param_id,param,FROM_UNIXTIME(create_time,'%Y-%m-%d %H:%i:%s') create_time")
  396. ->order('create_time desc')
  397. ->where($where)
  398. ->paginate($rows, false, ['query' => $param]);
  399. $content->toArray();
  400. foreach ($content as $k => $v) {
  401. $data = $v;
  402. $param_array = json_decode($v['param'], true);
  403. if(is_array($param_array)){
  404. $param_value = '';
  405. foreach ($param_array as $key => $value) {
  406. if (is_array($value)) {
  407. $value = implode(',', $value);
  408. }
  409. $param_value .= $key . ':' . $value . '&nbsp;&nbsp;|&nbsp;&nbsp;';
  410. }
  411. $data['param'] = $param_value;
  412. }
  413. else{
  414. $data['param'] = $param_array;
  415. }
  416. $content->offsetSet($k, $data);
  417. }
  418. return table_assign(0, '', $content);
  419. } else {
  420. return view();
  421. }
  422. }
  423. public function get_unitName($id){
  424. $did = Db::name('Admin')->where('id', $id)->value('did');
  425. $pid = $did;
  426. while($pid != 0){
  427. $value = Db::name('department')->where('id', $pid)->column('id,pid,title')[0];
  428. $id = $value['id'];
  429. $pid = $value['pid'];
  430. $title = $value['title'];
  431. }
  432. // halt($value);
  433. return $id;
  434. }
  435. }