- 機台日誌:對齊 Luxury UI 規範,實作整合式佈局與分頁組件。 - 多語系:完成機台日誌繁、英、日三語系翻譯與動態處理。 - UI 規範:更新 SKILL.md 定義「標準列表 Bible」。 - 後端:完善 TenantScoped 隔離邏輯,修復儀表板死循環與 User Model 缺失。 - IoT:擴展機台、會員 Model 並建立交易、商品、狀態等核心表結構。 - 基礎設施:設置台北時區與 Docker 環境變數同步。
40 lines
1016 B
PHP
40 lines
1016 B
PHP
<?php
|
|
|
|
namespace App\Http\Middleware;
|
|
|
|
use Closure;
|
|
use Illuminate\Http\Request;
|
|
use App\Models\Machine\Machine;
|
|
use Symfony\Component\HttpFoundation\Response;
|
|
|
|
class IotAuth
|
|
{
|
|
/**
|
|
* Handle an incoming request.
|
|
*/
|
|
public function handle(Request $request, Closure $next): Response
|
|
{
|
|
$token = $request->bearerToken();
|
|
|
|
// Phase 1: 暫時也接受 Request Body 中的 key 欄位 (相容模式)
|
|
if (!$token) {
|
|
$token = $request->input('key');
|
|
}
|
|
|
|
if (!$token) {
|
|
return response()->json(['success' => false, 'message' => 'Unauthorized: Missing Token'], 401);
|
|
}
|
|
|
|
$machine = Machine::where('api_token', $token)->first();
|
|
|
|
if (!$machine) {
|
|
return response()->json(['success' => false, 'message' => 'Unauthorized: Invalid Token'], 401);
|
|
}
|
|
|
|
// 將機台物件注入 Request 供後端使用
|
|
$request->merge(['machine' => $machine]);
|
|
|
|
return $next($request);
|
|
}
|
|
}
|