import { Controller, Post, Put, Delete, Route, Security, Tags, Body, Path, Request, SuccessResponse, Response, Get, } from "tsoa"; import { AppDataSource } from "../database/data-source"; import HttpSuccess from "../interfaces/http-success"; import HttpStatusCode from "../interfaces/http-status"; import HttpError from "../interfaces/http-error"; import { CreateEducationLevel, EducationLevel } from "../entities/EducationLevel"; import { Not } from "typeorm"; @Route("api/v1/org/educationLevel") @Tags("EducationLevel") @Security("bearerAuth") @Response( HttpStatusCode.INTERNAL_SERVER_ERROR, "เกิดข้อผิดพลาด ไม่สามารถแสดงรายการได้ กรุณาลองใหม่ในภายหลัง", ) @SuccessResponse(HttpStatusCode.OK, "สำเร็จ") export class EducationLevelController extends Controller { private educationLevelRepository = AppDataSource.getRepository(EducationLevel); /** * API สร้างระดับการศึกษา * * @summary ORG_061 - สร้างระดับการศึกษา (ADMIN) #65 * */ @Post() async createEducationLevel( @Body() requestBody: CreateEducationLevel, @Request() request: { user: Record }, ) { const checkName = await this.educationLevelRepository.findOne({ where: { name: requestBody.name }, }); if (checkName) { throw new HttpError(HttpStatusCode.NOT_FOUND, "ชื่อนี้มีอยู่ในระบบแล้ว"); } try { const educationLevel = Object.assign(new EducationLevel(), requestBody); educationLevel.createdUserId = request.user.sub; educationLevel.createdFullName = request.user.name; educationLevel.lastUpdateUserId = request.user.sub; educationLevel.lastUpdateFullName = request.user.name; await this.educationLevelRepository.save(educationLevel); return new HttpSuccess(); } catch (error) { return error; } } /** * API แก้ไขระดับการศึกษา * * @summary ORG_061 - แก้ไขระดับการศึกษา (ADMIN) #65 * * @param {string} id Id ระดับการศึกษา */ @Put("{id}") async updateEducationLevel( @Path() id: string, @Body() requestBody: CreateEducationLevel, @Request() request: { user: Record }, ) { const educationLevel = await this.educationLevelRepository.findOne({ where: { id: id } }); if (!educationLevel) { throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูลไอดีนี้ : " + id); } const checkName = await this.educationLevelRepository.findOne({ where: { id:Not(id),name: requestBody.name }, }); if (checkName) { throw new HttpError(HttpStatusCode.NOT_FOUND, "ชื่อนี้มีอยู่ในระบบแล้ว"); } try { educationLevel.lastUpdateUserId = request.user.sub; educationLevel.lastUpdateFullName = request.user.name; this.educationLevelRepository.merge(educationLevel, requestBody); await this.educationLevelRepository.save(educationLevel); return new HttpSuccess(); } catch (error) { return error; } } /** * API ลบระดับการศึกษา * * @summary ORG_061 - ลบระดับการศึกษา (ADMIN) #65 * * @param {string} id Id ระดับการศึกษา */ @Delete("{id}") async deleteEducationLevel(@Path() id: string) { const delEducationLevel = await this.educationLevelRepository.findOne({ where: { id }, }); if (!delEducationLevel) { throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูลตำแหน่งตามไอดีนี้ : " + id); } try { await this.educationLevelRepository.delete({ id: id }); return new HttpSuccess(); } catch (error) { return error; } } /** * API รายละเอียดรายการระดับการศึกษา * * @summary ORG_061 - รายละเอียดรายการระดับการศึกษา (ADMIN) #65 * * @param {string} id Id ระดับการศึกษา */ @Get("{id}") async detailEducationLevel(@Path() id: string) { const educationLevel = await this.educationLevelRepository.findOne({ where: { id }, select: ["id", "name" ,"rank"], }); if (!educationLevel) { throw new HttpError(HttpStatusCode.NOT_FOUND, "ไม่พบข้อมูล"); } try { return new HttpSuccess(educationLevel); } catch (error) { return error; } } /** * API รายการระดับการศึกษา * * @summary ORG_061 - รายการระดับการศึกษา (ADMIN) #65 * */ @Get() async listEducationLevel() { const educationLevel = await this.educationLevelRepository.find({ select: ["id", "name" , "createdAt" , "lastUpdatedAt" , "createdFullName" , "lastUpdateFullName"], order:{ createdAt:"ASC" } }); if (!educationLevel) { return new HttpSuccess([]); } try { return new HttpSuccess(educationLevel); } catch (error) { return error; } } }