text('site_name', '站点标题'); $form->text('site_description', '站点描述'); $form->text('site_url', '站点地址(URL)')->hint('以 http(s):// 开头,不要以 / 结尾'); $form->checkbox('user_can_register', '开放注册', '任何人都可以注册'); $form->text('regs_per_ip', '每个 IP 限制注册数'); $form->group('max_upload_file_size', '最大允许上传大小', function($group) { // main textbox $group->text('max_upload_file_size'); $group->addon('KB'); })->hint('PHP 限制:'.ini_get('post_max_size').',定义在 php.ini 中。'); $form->checkbox('allow_chinese_playername', '角色名', '允许中文角色名'); $form->select('api_type', '首选 JSON API', function($options) { $options->add('0', 'CustomSkinLoader API'); $options->add('1', 'UniversalSkinAPI'); }); $form->checkbox('auto_del_invalid_texture', '失效材质', '自动删除失效材质')->hint('自动从皮肤库中删除文件不存在的材质记录'); $form->textarea('comment_script', '评论代码', function($textarea) { $textarea->setRows(6); $textarea->setDescription('评论代码内可使用占位符,{tid} 将会被自动替换为材质的 id,{name} 会被替换为材质名称,{url} 会被替换为当前页面地址。'); }); })->handle(function() { if (substr($_POST['site_url'], -1) == "/") $_POST['site_url'] = substr($_POST['site_url'], 0, -1); }); $cache = Option::form('cache', '缓存相关配置', function($form) { $form->checkbox('auto_detect_asset_url', '资源地址', '自动判断资源文件地址')->hint('根据当前 URL 自动加载资源文件。如果出现 CDN 回源问题请关闭'); $form->checkbox('return_200_when_notfound', 'HTTP 响应码', '请求不存在的角色时返回 200 而不是 404'); $form->text('cache_expire_time', '缓存失效时间')->hint('秒数,86400 = 一天,31536000 = 一年'); })->hint('如果启用了 CDN 缓存请适当修改这些配置')->handle(); return view('admin.options')->with('forms', compact('general', 'cache')); } /** * Handle Upload Checking & Downloading * * @param Request $request * @return void */ public function update(Request $request) { if ($request->action == "check") { $updater = new \Updater(\App::version()); if ($updater->newVersionAvailable()) { return json([ 'new_version_available' => true, 'latest_version' => $updater->latest_version ]); } else { return json([ 'new_version_available' => false, 'latest_version' => $updater->current_version ]); } } elseif ($request->action == "download") { return view('admin.download'); } else { return view('admin.update'); } } public function plugins(Request $request, PluginManager $plugins) { if ($request->has('action') && $request->has('id')) { $id = $request->get('id'); if ($plugins->getPlugins()->has($id)) { $plugin = $plugins->getPlugin($id); switch ($request->get('action')) { case 'enable': $plugins->enable($id); return redirect('admin/plugins'); break; case 'disable': $plugins->disable($id); return redirect('admin/plugins'); break; case 'delete': if ($request->isMethod('post')) { event(new Events\PluginWasDeleted($plugin)); $plugins->uninstall($id); return json('插件已被成功删除', 0); } break; case 'config': if ($plugin->isEnabled() && $plugin->hasConfigView()) { return View::file($plugin->getViewPath('config')); } else { abort(404); } break; default: # code... break; } } } $data = [ 'installed' => $plugins->getPlugins(), 'enabled' => $plugins->getEnabledPlugins() ]; // dd($data); return view('admin.plugins', $data); } /** * Show Manage Page of Users. * * @param Request $request * @return \Illuminate\Http\Response */ public function users(Request $request) { $page = $request->input('page', 1); $filter = $request->input('filter', ''); $q = $request->input('q', ''); if ($filter == "") { $users = User::orderBy('uid'); } elseif ($filter == "email") { $users = User::like('email', $q)->orderBy('uid'); } elseif ($filter == "nickname") { $users = User::like('nickname', $q)->orderBy('uid'); } $total_pages = ceil($users->count() / 30); $users = $users->skip(($page - 1) * 30)->take(30)->get(); return view('admin.users')->with('users', $users) ->with('filter', $filter) ->with('q', $q) ->with('page', $page) ->with('total_pages', $total_pages); } /** * Show Manage Page of Players. * * @param Request $request * @return \Illuminate\Http\Response */ public function players(Request $request) { $page = $request->input('page', 1); $filter = $request->input('filter', ''); $q = $request->input('q', ''); if ($filter == "") { $players = Player::orderBy('uid'); } elseif ($filter == "player_name") { $players = Player::like('player_name', $q)->orderBy('uid'); } elseif ($filter == "uid") { $players = Player::where('uid', $q)->orderBy('uid'); } $total_pages = ceil($players->count() / 30); $players = $players->skip(($page - 1) * 30)->take(30)->get(); return view('admin.players')->with('players', $players) ->with('filter', $filter) ->with('q', $q) ->with('page', $page) ->with('total_pages', $total_pages); } /** * Handle ajax request from /admin/users * * @param Request $request * @return void */ public function userAjaxHandler(Request $request, UserRepository $users) { $action = $request->input('action'); if ($action == "color") { $this->validate($request, [ 'color_scheme' => 'required' ]); $color_scheme = str_replace('_', '-', $request->input('color_scheme')); \Option::set('color_scheme', $color_scheme); return json('修改配色成功', 0); } $user = $users->get($request->input('uid')); // current user $cur_user = $users->get(session('uid')); if (!$user) return json('用户不存在', 1); if ($action == "email") { $this->validate($request, [ 'email' => 'required|email' ]); if ($user->setEmail($request->input('email'))) return json('邮箱修改成功', 0); } elseif ($action == "nickname") { $this->validate($request, [ 'nickname' => 'required|nickname' ]); if ($user->setNickName($request->input('nickname'))) return json('昵称已成功设置为 '.$request->input('nickname'), 0); } elseif ($action == "password") { $this->validate($request, [ 'password' => 'required|min:8|max:16' ]); if ($user->changePasswd($request->input('password'))) return json('密码修改成功', 0); } elseif ($action == "score") { $this->validate($request, [ 'score' => 'required|integer' ]); if ($user->setScore($request->input('score'))) return json('积分修改成功', 0); } elseif ($action == "ban") { if ($user->getPermission() == User::ADMIN) { if ($cur_user->getPermission() != User::SUPER_ADMIN) return json('非超级管理员无法封禁普通管理员'); } elseif ($user->getPermission() == User::SUPER_ADMIN) { return json('超级管理员无法被封禁'); } $permission = $user->getPermission() == User::BANNED ? User::NORMAL : User::BANNED; if ($user->setPermission($permission)) { return json([ 'errno' => 0, 'msg' => '账号已被' . ($permission == User::BANNED ? '封禁' : '解封'), 'permission' => $user->getPermission() ]); } } elseif ($action == "admin") { if ($cur_user->getPermission() != User::SUPER_ADMIN) return json('非超级管理员无法进行此操作'); if ($user->getPermission() == User::SUPER_ADMIN) return json('超级管理员无法被解除'); $permission = $user->getPermission() == User::ADMIN ? User::NORMAL : User::ADMIN; if ($user->setPermission($permission)) { return json([ 'errno' => 0, 'msg' => '账号已被' . ($permission == User::ADMIN ? '设为' : '解除') . '管理员', 'permission' => $user->getPermission() ]); } } elseif ($action == "delete") { if ($user->delete()) return json('账号已被成功删除', 0); } else { return json('非法参数', 1); } } /** * Handle ajax request from /admin/players */ public function playerAjaxHandler(Request $request, UserRepository $users) { $action = isset($_GET['action']) ? $_GET['action'] : ""; $player = Player::find($request->input('pid')); if (!$player) abort(404, trans('general.unexistent-player')); if ($action == "preference") { $this->validate($request, [ 'preference' => 'required|preference' ]); if ($player->setPreference($request->input('preference'))) return json('角色 '.$player->player_name.' 的优先模型已更改至 '.$request->input('preference'), 0); } elseif ($action == "texture") { $this->validate($request, [ 'model' => 'required|model', 'tid' => 'required|integer' ]); if (!Texture::find($request->tid)) return json("材质 tid.{$request->tid} 不存在", 1); if ($player->setTexture(['tid_'.$request->model => $request->tid])) return json("角色 {$player->player_name} 的材质修改成功", 0); } elseif ($action == "owner") { $this->validate($request, [ 'pid' => 'required|integer', 'uid' => 'required|integer' ]); $user = $users->get($request->input('uid')); if (!$user) return json('不存在的用户', 1); if ($player->setOwner($request->input('uid'))) return json("角色 $player->player_name 已成功让渡至 ".$user->getNickName(), 0); } elseif ($action == "delete") { if ($player->delete()) return json('角色已被成功删除', 0); } else { return json('非法参数', 1); } } }