사용자 모달 기능: - 사용자 정보 모달 팝업 (조회/삭제/수정) - 권한 요약 정보 (Web/API 권한 카운트) - 2x2 그리드 레이아웃 (테넌트, 역할, 부서, 권한) - 테이블 행 클릭으로 모달 열기 - 권한 관리 링크 클릭 시 해당 사용자 자동 선택 컨텍스트 메뉴 확장: - permission-analyze 페이지 사용자 이름에 컨텍스트 메뉴 - user-permissions 페이지 사용자 버튼에 컨텍스트 메뉴 - 사용자 모달 내 테넌트 칩에 컨텍스트 메뉴 - 헤더 테넌트 배지에 컨텍스트 메뉴 - 테넌트 메뉴에 "이 테넌트로 전환" 기능 추가
219 lines
6.1 KiB
PHP
219 lines
6.1 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Api\Admin;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Http\Requests\StoreUserRequest;
|
|
use App\Http\Requests\UpdateUserRequest;
|
|
use App\Services\UserService;
|
|
use Illuminate\Http\JsonResponse;
|
|
use Illuminate\Http\Request;
|
|
|
|
class UserController extends Controller
|
|
{
|
|
public function __construct(
|
|
private readonly UserService $userService
|
|
) {}
|
|
|
|
/**
|
|
* 사용자 목록 조회
|
|
*/
|
|
public function index(Request $request): JsonResponse
|
|
{
|
|
$users = $this->userService->getUsers(
|
|
$request->all(),
|
|
$request->integer('per_page', 10)
|
|
);
|
|
|
|
// HTMX 요청인 경우 HTML 반환
|
|
if ($request->header('HX-Request')) {
|
|
$html = view('users.partials.table', compact('users'))->render();
|
|
|
|
return response()->json(['html' => $html]);
|
|
}
|
|
|
|
// 일반 API 요청인 경우 JSON 반환
|
|
return response()->json([
|
|
'success' => true,
|
|
'data' => $users->items(),
|
|
'meta' => [
|
|
'current_page' => $users->currentPage(),
|
|
'last_page' => $users->lastPage(),
|
|
'per_page' => $users->perPage(),
|
|
'total' => $users->total(),
|
|
],
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 사용자 상세 조회
|
|
*/
|
|
public function show(int $id): JsonResponse
|
|
{
|
|
$user = $this->userService->getUserById($id);
|
|
|
|
if (! $user) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자를 찾을 수 없습니다.',
|
|
], 404);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'data' => $user,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 사용자 생성
|
|
*/
|
|
public function store(StoreUserRequest $request): JsonResponse
|
|
{
|
|
try {
|
|
$user = $this->userService->createUser($request->validated());
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 생성되었습니다.',
|
|
'data' => $user,
|
|
'redirect' => route('users.index'),
|
|
], 201);
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자 생성에 실패했습니다: '.$e->getMessage(),
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 사용자 수정
|
|
*/
|
|
public function update(UpdateUserRequest $request, int $id): JsonResponse
|
|
{
|
|
try {
|
|
$result = $this->userService->updateUser($id, $request->validated());
|
|
|
|
if (! $result) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자를 찾을 수 없습니다.',
|
|
], 404);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 수정되었습니다.',
|
|
'redirect' => route('users.index'),
|
|
]);
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자 수정에 실패했습니다: '.$e->getMessage(),
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 사용자 삭제
|
|
*/
|
|
public function destroy(int $id): JsonResponse
|
|
{
|
|
try {
|
|
$result = $this->userService->deleteUser($id);
|
|
|
|
if (! $result) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자를 찾을 수 없습니다.',
|
|
], 404);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 삭제되었습니다.',
|
|
]);
|
|
} catch (\Exception $e) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자 삭제에 실패했습니다: '.$e->getMessage(),
|
|
], 500);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 사용자 복원
|
|
*/
|
|
public function restore(Request $request, int $id): JsonResponse
|
|
{
|
|
$this->userService->restoreUser($id);
|
|
|
|
// HTMX 요청 시 테이블 새로고침 트리거
|
|
if ($request->header('HX-Request')) {
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 복원되었습니다.',
|
|
'action' => 'refresh',
|
|
]);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 복원되었습니다.',
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 사용자 모달 정보 조회
|
|
*/
|
|
public function modal(Request $request, int $id): JsonResponse
|
|
{
|
|
$user = $this->userService->getUserForModal($id);
|
|
|
|
if (! $user) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '사용자를 찾을 수 없습니다.',
|
|
], 404);
|
|
}
|
|
|
|
$html = view('users.partials.modal-info', compact('user'))->render();
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'html' => $html,
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* 사용자 영구 삭제 (슈퍼관리자 전용)
|
|
*/
|
|
public function forceDestroy(Request $request, int $id): JsonResponse
|
|
{
|
|
// 슈퍼관리자 권한 체크
|
|
if (! auth()->user()?->is_super_admin) {
|
|
return response()->json([
|
|
'success' => false,
|
|
'message' => '권한이 없습니다.',
|
|
], 403);
|
|
}
|
|
|
|
$this->userService->forceDeleteUser($id);
|
|
|
|
// HTMX 요청 시 테이블 새로고침 트리거
|
|
if ($request->header('HX-Request')) {
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 영구 삭제되었습니다.',
|
|
'action' => 'refresh',
|
|
]);
|
|
}
|
|
|
|
return response()->json([
|
|
'success' => true,
|
|
'message' => '사용자가 영구 삭제되었습니다.',
|
|
]);
|
|
}
|
|
}
|