Files
star-erp/app/Modules/Core/Controllers/Auth/LoginController.php

81 lines
2.4 KiB
PHP
Raw Normal View History

2026-01-07 14:44:01 +08:00
<?php
namespace App\Modules\Core\Controllers\Auth;
2026-01-07 14:44:01 +08:00
use App\Http\Controllers\Controller;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Inertia\Inertia;
use Illuminate\Validation\ValidationException;
use Illuminate\Support\Facades\Cookie;
2026-01-07 14:44:01 +08:00
class LoginController extends Controller
{
/**
* Display the login view.
*/
public function show()
{
$centralDomains = config('tenancy.central_domains', []);
// [Hack] Demo 環境特殊規則
$demoPort = config('tenancy.demo_tenant_port');
if ((!$demoPort || request()->getPort() != $demoPort) && in_array(request()->getHost(), $centralDomains)) {
return Inertia::render('Landlord/Auth/Login');
}
2026-01-07 14:44:01 +08:00
return Inertia::render('Auth/Login');
}
/**
* Handle an incoming authentication request.
*/
public function store(Request $request)
{
$request->validate([
'username' => ['required', 'string'],
'password' => ['required', 'string'],
], [
'username.required' => '請輸入帳號',
'password.required' => '請輸入密碼',
]);
$credentials = $request->only('username', 'password');
if (Auth::attempt($credentials, $request->boolean('remember'))) {
$request->session()->regenerate();
$centralDomains = config('tenancy.central_domains', []);
// [Hack] Demo 環境特殊規則
$demoPort = config('tenancy.demo_tenant_port');
if ((!$demoPort || $request->getPort() != $demoPort) && in_array($request->getHost(), $centralDomains)) {
return Inertia::location(route('landlord.dashboard'));
}
return Inertia::location(route('dashboard'));
2026-01-07 14:44:01 +08:00
}
throw ValidationException::withMessages([
'username' => '帳號或密碼錯誤。',
]);
}
/**
* Destroy an authenticated session.
*/
public function destroy(Request $request)
{
Auth::guard('web')->logout();
$request->session()->invalidate();
$request->session()->regenerateToken();
// 強制清除 Session Cookie (對付 HTTPS/Proxy 環境下的殘留問題)
$sessionCookieName = config('session.cookie');
Cookie::queue(Cookie::forget($sessionCookieName));
2026-01-07 14:44:01 +08:00
return redirect('/');
}
}