isAjax()) { $param = get_params(); $where = array(); if (!empty($param['keywords'])) { $where[] = ['id|title|desc', 'like', '%' . $param['keywords'] . '%']; } $rows = empty($param['limit']) ? get_config('app.page_size') : $param['limit']; $group = AdminGroup::where($where) ->order('create_time asc') ->paginate($rows, false, ['query' => $param]); return table_assign(0, '', $group); } else { return view(); } } //添加&编辑 public function add() { $param = get_params(); if (request()->isAjax()) { $ruleData = isset($param['rule']) ? $param['rule'] : 0; $param['rules'] = implode(',', $ruleData); if (!empty($param['id']) && $param['id'] > 0) { try { validate(GroupCheck::class)->scene('edit')->check($param); } catch (ValidateException $e) { // 验证失败 输出错误信息 return to_assign(1, $e->getError()); } //为了系统安全id为1的系统所有者管理组不允许修改 if ($param['id'] == 1) { return to_assign(1, '为了系统安全,该管理组不允许修改'); } Db::name('AdminGroup')->where(['id' => $param['id']])->strict(false)->field(true)->update($param); add_log('edit', $param['id'], $param); } else { try { validate(GroupCheck::class)->scene('add')->check($param); } catch (ValidateException $e) { // 验证失败 输出错误信息 return to_assign(1, $e->getError()); } $gid = Db::name('AdminGroup')->strict(false)->field(true)->insertGetId($param); add_log('add', $gid, $param); } //清除菜单\权限缓存 clear_cache('adminMenu'); return to_assign(); } else { $id = isset($param['id']) ? $param['id'] : 0; $rule = get_admin_rule(); if ($id > 0) { $rules = get_admin_group_info($id); $role_rule = create_tree_list(0, $rule, $rules); $role = Db::name('AdminGroup')->where(['id' => $id])->find(); View::assign('role', $role); } else { $role_rule = create_tree_list(0, $rule, []); } View::assign('role_rule', $role_rule); View::assign('id', $id); return view(); } } //删除 public function delete() { $id = get_params("id"); if ($id == 1) { return to_assign(1, "该组是系统所有者,无法删除"); } if (Db::name('AdminGroup')->delete($id) !== false) { add_log('delete', $id, []); return to_assign(0, "删除角色成功"); } else { return to_assign(1, "删除失败"); } } }