Files
sam-manage/app/Http/Middleware/EnsurePasswordChanged.php
pro ac9c156257 fix:비밀번호 변경 미들웨어 AJAX 요청 처리 개선
- AJAX/API 요청 시 JSON 응답 반환 (403)
- 리다이렉트 대신 에러 메시지와 redirect URL 제공

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-31 12:42:42 +09:00

49 lines
1.6 KiB
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class EnsurePasswordChanged
{
/**
* 비밀번호 변경이 필요한 사용자를 프로필 페이지로 리다이렉트
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
$user = $request->user();
// 로그인한 사용자가 비밀번호 변경이 필요한 경우
if ($user && $user->must_change_password) {
// 프로필 관련 라우트는 허용 (무한 리다이렉트 방지)
if ($request->routeIs('profile.*')) {
return $next($request);
}
// 로그아웃 라우트는 허용
if ($request->routeIs('logout')) {
return $next($request);
}
// AJAX/API 요청은 JSON 응답 반환
if ($request->expectsJson() || $request->ajax()) {
return response()->json([
'ok' => false,
'error' => '보안을 위해 비밀번호를 먼저 변경해주세요.',
'redirect' => route('profile.index'),
], 403);
}
// 그 외 모든 요청은 프로필 페이지로 리다이렉트
return redirect()->route('profile.index')
->with('warning', '보안을 위해 비밀번호를 변경해주세요.');
}
return $next($request);
}
}