160 lines
4.3 KiB
TypeScript
160 lines
4.3 KiB
TypeScript
|
|
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<void> {
|
||
|
|
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<any[]> = {
|
||
|
|
success: true,
|
||
|
|
message: "관리자 메뉴 목록 조회 성공",
|
||
|
|
data: menuList,
|
||
|
|
};
|
||
|
|
|
||
|
|
res.status(200).json(response);
|
||
|
|
} catch (error) {
|
||
|
|
logger.error("관리자 메뉴 목록 조회 중 오류 발생:", error);
|
||
|
|
|
||
|
|
const response: ApiResponse<null> = {
|
||
|
|
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<void> {
|
||
|
|
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<any[]> = {
|
||
|
|
success: true,
|
||
|
|
message: "사용자 메뉴 목록 조회 성공",
|
||
|
|
data: menuList,
|
||
|
|
};
|
||
|
|
|
||
|
|
res.status(200).json(response);
|
||
|
|
} catch (error) {
|
||
|
|
logger.error("사용자 메뉴 목록 조회 중 오류 발생:", error);
|
||
|
|
|
||
|
|
const response: ApiResponse<null> = {
|
||
|
|
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<void> {
|
||
|
|
try {
|
||
|
|
const { menuId } = req.params;
|
||
|
|
logger.info(`=== 메뉴 정보 조회 시작 - menuId: ${menuId} ===`);
|
||
|
|
|
||
|
|
const menuInfo = await AdminService.getMenuInfo(menuId);
|
||
|
|
|
||
|
|
if (!menuInfo) {
|
||
|
|
const response: ApiResponse<null> = {
|
||
|
|
success: false,
|
||
|
|
message: "메뉴를 찾을 수 없습니다.",
|
||
|
|
error: {
|
||
|
|
code: "MENU_NOT_FOUND",
|
||
|
|
details: `Menu ID: ${menuId}`,
|
||
|
|
},
|
||
|
|
};
|
||
|
|
res.status(404).json(response);
|
||
|
|
return;
|
||
|
|
}
|
||
|
|
|
||
|
|
const response: ApiResponse<any> = {
|
||
|
|
success: true,
|
||
|
|
message: "메뉴 정보 조회 성공",
|
||
|
|
data: menuInfo,
|
||
|
|
};
|
||
|
|
|
||
|
|
res.status(200).json(response);
|
||
|
|
} catch (error) {
|
||
|
|
logger.error("메뉴 정보 조회 중 오류 발생:", error);
|
||
|
|
|
||
|
|
const response: ApiResponse<null> = {
|
||
|
|
success: false,
|
||
|
|
message: "메뉴 정보 조회 중 오류가 발생했습니다.",
|
||
|
|
error: {
|
||
|
|
code: "MENU_INFO_ERROR",
|
||
|
|
details: error instanceof Error ? error.message : "Unknown error",
|
||
|
|
},
|
||
|
|
};
|
||
|
|
|
||
|
|
res.status(500).json(response);
|
||
|
|
}
|
||
|
|
}
|