Files
chatroom/app/Http/Middleware/LevelRequired.php
lkddi ea06328885 功能:字体颜色持久化、等级体系升级至99级、钓鱼小游戏、补充系统参数
- 字体颜色:s_color 改为 varchar,发消息时保存颜色,进入聊天室自动恢复
- 等级体系:maxlevel 15→99,superlevel 16→100,99级经验阶梯(幂次曲线)
- 管理权限等级按比例调整:禁言50、踢人60、设公告60、封号80、封IP90
- 钓鱼小游戏:FishingController(抛竿扣金币+收竿随机结果+广播)
- 补充6个缺失的 sysparam 参数 + 4个钓鱼参数
- 用户列表点击用户名后自动聚焦输入框
- Pint 格式化
2026-02-26 21:10:34 +08:00

53 lines
1.5 KiB
PHP
Raw Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
<?php
/**
* 文件功能:用户等级权限验证中间件
* 支持传入固定数字等级 或 'super' 关键字(动态读取 sysparam 的 superlevel
*
* @author ChatRoom Laravel
*
* @version 1.0.0
*/
namespace App\Http\Middleware;
use App\Models\Sysparam;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Symfony\Component\HttpFoundation\Response;
class LevelRequired
{
/**
* 校验当前登录用户的等级是否大于或等于要求等级。
* 当 $level 为 'super' 时,动态从 sysparam 表读取 superlevel 值。
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
* @param string $level 要求的最低等级(数字 或 'super'
*/
public function handle(Request $request, Closure $next, string $level = 'super'): Response
{
if (! Auth::check()) {
return redirect()->route('home');
}
// 动态解析等级要求:'super' → 从 sysparam 读取,数字 → 直接使用
$requiredLevel = ($level === 'super')
? (int) Sysparam::getValue('superlevel', '100')
: (int) $level;
$user = Auth::user();
if ($user->user_level < $requiredLevel) {
if ($request->expectsJson()) {
return response()->json(['message' => '权限不足', 'status' => 'error'], 403);
}
abort(403, '权限不足,无法执行此操作。');
}
return $next($request);
}
}