import { Response } from "express"; import { AdminService } from "../services/adminService"; import { logger } from "../utils/logger"; import { ApiResponse, AuthenticatedRequest } from "../types/auth"; /** * 관리자 메뉴 목록 조회 */ export async function getAdminMenus( req: AuthenticatedRequest, res: Response ): Promise { try { logger.info("=== 관리자 메뉴 목록 조회 시작 ==="); // 현재 로그인한 사용자의 회사 코드와 로케일 가져오기 const userCompanyCode = req.user?.companyCode || "ILSHIN"; const userLang = (req.query.userLang as string) || "ko"; logger.info(`사용자 회사 코드: ${userCompanyCode}`); logger.info(`사용자 로케일: ${userLang}`); const paramMap = { userCompanyCode, userLang, SYSTEM_NAME: "PLM", }; const menuList = await AdminService.getAdminMenuList(paramMap); logger.info(`관리자 메뉴 조회 결과: ${menuList.length}개`); if (menuList.length > 0) { logger.info("첫 번째 메뉴:", menuList[0]); } const response: ApiResponse = { success: true, message: "관리자 메뉴 목록 조회 성공", data: menuList, }; res.status(200).json(response); } catch (error) { logger.error("관리자 메뉴 목록 조회 중 오류 발생:", error); const response: ApiResponse = { success: false, message: "관리자 메뉴 목록 조회 중 오류가 발생했습니다.", error: { code: "ADMIN_MENU_LIST_ERROR", details: error instanceof Error ? error.message : "Unknown error", }, }; res.status(500).json(response); } } /** * 사용자 메뉴 목록 조회 */ export async function getUserMenus( req: AuthenticatedRequest, res: Response ): Promise { try { logger.info("=== 사용자 메뉴 목록 조회 시작 ==="); // 현재 로그인한 사용자의 회사 코드와 로케일 가져오기 const userCompanyCode = req.user?.companyCode || "ILSHIN"; const userLang = (req.query.userLang as string) || "ko"; logger.info(`사용자 회사 코드: ${userCompanyCode}`); logger.info(`사용자 로케일: ${userLang}`); const paramMap = { userCompanyCode, userLang, SYSTEM_NAME: "PLM", }; const menuList = await AdminService.getUserMenuList(paramMap); logger.info(`사용자 메뉴 조회 결과: ${menuList.length}개`); if (menuList.length > 0) { logger.info("첫 번째 메뉴:", menuList[0]); } const response: ApiResponse = { success: true, message: "사용자 메뉴 목록 조회 성공", data: menuList, }; res.status(200).json(response); } catch (error) { logger.error("사용자 메뉴 목록 조회 중 오류 발생:", error); const response: ApiResponse = { success: false, message: "사용자 메뉴 목록 조회 중 오류가 발생했습니다.", error: { code: "USER_MENU_LIST_ERROR", details: error instanceof Error ? error.message : "Unknown error", }, }; res.status(500).json(response); } } /** * 메뉴 정보 조회 */ export async function getMenuInfo( req: AuthenticatedRequest, res: Response ): Promise { try { const { menuId } = req.params; logger.info(`=== 메뉴 정보 조회 시작 - menuId: ${menuId} ===`); const menuInfo = await AdminService.getMenuInfo(menuId); if (!menuInfo) { const response: ApiResponse = { success: false, message: "메뉴를 찾을 수 없습니다.", error: { code: "MENU_NOT_FOUND", details: `Menu ID: ${menuId}`, }, }; res.status(404).json(response); return; } const response: ApiResponse = { success: true, message: "메뉴 정보 조회 성공", data: menuInfo, }; res.status(200).json(response); } catch (error) { logger.error("메뉴 정보 조회 중 오류 발생:", error); const response: ApiResponse = { success: false, message: "메뉴 정보 조회 중 오류가 발생했습니다.", error: { code: "MENU_INFO_ERROR", details: error instanceof Error ? error.message : "Unknown error", }, }; res.status(500).json(response); } }