Lae/app/Http/Controllers/Admin/ModuleController.php

218 lines
6.4 KiB
PHP

<?php
namespace App\Http\Controllers\Admin;
use App\Http\Controllers\Controller;
use App\Models\Host;
use App\Models\Module;
use App\Models\ModuleAllow;
use Illuminate\Http\RedirectResponse;
use Illuminate\Http\Request;
use Illuminate\Support\Str;
use Illuminate\View\View;
class ModuleController extends Controller
{
/**
* Display a listing of the resource.
*
* @param Module $module
* @return View
*/
public function index(Module $module): View
{
$modules = $module->paginate(50);
return view('admin.modules.index', compact('modules'));
}
/**
* Show the form for creating a new resource.
*
* @return View
*/
public function create(): View
{
return view('admin.modules.create');
}
/**
* Store a newly created resource in storage.
*
* @param Request $request
* @return RedirectResponse
*/
public function store(Request $request): RedirectResponse
{
$request->validate($this->rules());
$api_token = Str::random(60);
$module = new Module();
$module->id = $request->input('id');
$module->name = $request->input('name');
$module->api_token = $api_token;
$module->url = $request->input('url');
$module->ip_port = $request->input('ip_port');
$module->status = $request->input('status');
$module->wecom_key = $request->input('wecom_key');
$module->save();
return redirect()->route('admin.modules.edit', $module)->with('success', '模块创建成功。');
}
private function rules(): array
{
return [
'id' => 'required|string|max:255',
'name' => 'required|string|max:255',
'url' => 'required|url',
'ip_port' => 'nullable|string|max:255',
'status' => 'required|string|in:up,down,maintenance',
'balance' => 'nullable|numeric',
'wecom_key' => 'nullable|string|max:255',
];
}
/**
* Display the specified resource.
*
* @param Module $module
* @return View
*/
public function show(Module $module): View
{
$years = $module->calculate();
$hosts = (new Host)->where('module_id', $module->id)->with('user')->latest()->paginate(50);
return view('admin.modules.show', compact('module', 'years', 'hosts'));
}
/**
* Show the form for editing the specified resource.
*
* @param Module $module
* @return View
*/
public function edit(Module $module): View
{
$module = $module->makeVisible(['wecom_key', 'api_token']);
return view('admin.modules.edit', compact('module'));
}
/**
* Update the specified resource in storage.
*
* @param Request $request
* @param Module $module
* @return RedirectResponse
*/
public function update(Request $request, Module $module): RedirectResponse
{
$request->validate($this->rules());
$module->id = $request->input('id');
$module->name = $request->input('name');
$module->url = $request->input('url');
$module->ip_port = $request->input('ip_port');
$module->status = $request->input('status');
$module->wecom_key = $request->input('wecom_key');
if (! $request->filled('api_token')) {
$module->api_token = Str::random(60);
} else {
$module->api_token = $request->input('api_token');
}
$module->save();
$text = '模块更新成功';
if ($request->filled('balance')) {
// 判断有无差异
if ($module->balance != $request->input('balance')) {
// bc 获取差异
$diff = bcsub($request->input('balance'), $module->balance, 4);
// 充值或者扣费
if ($diff > 0) {
$description = '管理员 '.auth('admin')->user()->name.' 充值 '.$diff.' 元';
$module->charge($diff, 'console', $description);
} else {
$description = '管理员 '.auth('admin')->user()->name.' 扣除 '.abs($diff).' 元';
$module->reduce(abs($diff), $description);
}
}
}
if ($request->input('reset_api_token')) {
$text .= ', API Token 为 '.$module->api_token.'。';
} else {
$text .= '。';
}
return redirect()->route('admin.modules.edit', $module->id)->with('success', $text);
}
/**
* Remove the specified resource from storage.
*
* @param Module $module
* @return RedirectResponse
*/
public function destroy(Module $module): RedirectResponse
{
$module->delete();
return redirect()->route('admin.modules.index')->with('success', '模块已删除。');
}
public function allows(Module $module): View
{
$allows = (new ModuleAllow)->where('module_id', $module->id)->with('allowed_module')->paginate(50);
$modules = (new Module)->where('id', '!=', $module->id)->get();
return view('admin.modules.allows', compact('module', 'allows', 'modules'));
}
public function allows_store(Request $request, Module $module): RedirectResponse
{
$request->validate([
'allowed_module_id' => 'required|string|max:255|exists:modules,id',
]);
(new ModuleAllow)->where('module_id', $module->id)->where('allowed_module_id', $request->input('allow_module_id'))->firstOrCreate([
'module_id' => $module->id,
'allowed_module_id' => $request->get('allowed_module_id'),
]);
return back()->with('success', '已信任该模块。');
}
// fast login
public function allows_destroy(Module $module, ModuleAllow $allow): RedirectResponse
{
$allow->delete();
return redirect()->route('admin.modules.allows', $module)->with('success', '取消信任完成。');
}
public function fast_login(Module $module): View|RedirectResponse
{
$resp = $module->baseRequest('post', 'fast-login');
if ($resp['success']) {
$resp = $resp['json'];
return view('admin.modules.login', compact('module', 'resp'));
} else {
return redirect()->route('admin.modules.show', $module)->with('error', '快速登录失败,可能是模块不支持。');
}
}
}