mirror of
https://github.com/bs-community/blessing-skin-server.git
synced 2025-01-12 13:44:41 +08:00
336 lines
10 KiB
PHP
336 lines
10 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers;
|
|
|
|
use View;
|
|
use Utils;
|
|
use App\Models\User;
|
|
use App\Models\Player;
|
|
use App\Models\Texture;
|
|
use Illuminate\Http\Request;
|
|
use App\Services\PluginManager;
|
|
use App\Exceptions\PrettyPageException;
|
|
use App\Services\Repositories\UserRepository;
|
|
|
|
class AdminController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
return view('admin.index');
|
|
}
|
|
|
|
public function customize()
|
|
{
|
|
return view('admin.customize');
|
|
}
|
|
|
|
public function score()
|
|
{
|
|
return view('admin.score');
|
|
}
|
|
|
|
public function options()
|
|
{
|
|
return view('admin.options');
|
|
}
|
|
|
|
/**
|
|
* 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);
|
|
break;
|
|
|
|
case 'disable':
|
|
$plugins->disable($id);
|
|
break;
|
|
|
|
case 'delete':
|
|
if ($request->isMethod('post')) {
|
|
$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);
|
|
}
|
|
}
|
|
|
|
}
|