using BMA.EHR.Recurit.Exam.Service.Core; using BMA.EHR.Recurit.Exam.Service.Models; using BMA.EHR.Recurit.Exam.Service.Request; using BMA.EHR.Recurit.Exam.Service.Response; using BMA.EHR.Recurit.Exam.Service.Services; using BMA.EHR.Recurit.Exam.Service.Request; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using Swashbuckle.AspNetCore.Annotations; using Newtonsoft.Json.Linq; using Newtonsoft.Json; namespace BMA.EHR.Recurit.Exam.Service.Controllers { [Route("api/v{version:apiVersion}/cms")] [ApiVersion("1.0")] [ApiController] [Produces("application/json")] [Authorize] [SwaggerTag("จัดการข้อมูลหน้าเว็บสมัครสอบ เพื่อนำไปใช้งานในระบบ")] public class CMSCandidateController : BaseController { #region " Fields " private readonly CMSCandidateService _cmsCandidateService; private readonly PermissionRepository _permission; #endregion #region " Constructor and Destructor " public CMSCandidateController(CMSCandidateService cmsCandidateService, PermissionRepository permission) { _cmsCandidateService = cmsCandidateService; _permission = permission; } #endregion #region " Methods " /// /// แสดงข้อมูลรายละเอียดหน้าเว็บสมัครสอบ /// /// /// เมื่อทำการอ่านแสดงข้อมูลรายละเอียดหน้าเว็บสมัครสอบสำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> GetsAsync() { try { var getPermission = await _permission.GetPermissionAPIAsync("LIST", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } var items = await _cmsCandidateService.GetsAsync(); return Success(items); } catch (Exception ex) { return Error(ex); } } /// /// อัพเดทข้อมูล รายละเอียดหน้าเว็บ ผู้สมัคร /// /// รายละเอียดหน้าเว็บ /// /// เมื่อทำการอัพเดทข้อมูล รายละเอียดหน้าเว็บ ผู้สมัคร สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpPost("detail")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> UpdateDetailAsync(RequestCMSAbout detail) { try { var getPermission = await _permission.GetPermissionAPIAsync("CREATE", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } await _cmsCandidateService.UpdateDetailAsync(detail); return Success(); } catch (Exception ex) { return Error(ex); } } /// /// อัพเดทข้อมูล ข้อมูลเกี่ยวกับเรา ผู้สมัคร /// /// ข้อมูลเกี่ยวกับเรา /// /// เมื่อทำการอัพเดทข้อมูล ข้อมูลเกี่ยวกับเรา ผู้สมัคร สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpPost("about")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> UpdateAboutAsync(RequestCMSAbout about) { try { var getPermission = await _permission.GetPermissionAPIAsync("CREATE", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } await _cmsCandidateService.UpdateAboutAsync(about); return Success(); } catch (Exception ex) { return Error(ex); } } /// /// อัพเดทข้อมูล โลโก้เว็บไซย์ ผู้สมัคร /// /// โลโก้เว็บไซย์ /// /// เมื่อทำการอัพเดทข้อมูล โลโก้เว็บไซย์ ผู้สมัคร สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpPost("logo"), DisableRequestSizeLimit] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> UpdateLogoAsync() { try { var getPermission = await _permission.GetPermissionAPIAsync("CREATE", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } if (Request.Form.Files == null || Request.Form.Files.Count == 0) { return Error(GlobalMessages.NoFileToUpload); } var file = Request.Form.Files[0]; await _cmsCandidateService.UpdateLogoAsync(file); return Success(); } catch (Exception ex) { return Error(ex); } } /// /// อัพเดทข้อมูล Banner ผู้สมัคร /// /// Banner /// /// เมื่อทำการอัพเดทข้อมูล Banner ผู้สมัคร สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpPost("banner"), DisableRequestSizeLimit] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> UpdateBannerAsync() { try { var getPermission = await _permission.GetPermissionAPIAsync("CREATE", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } if (Request.Form.Files == null || Request.Form.Files.Count == 0) { return Error(GlobalMessages.NoFileToUpload); } var file = Request.Form.Files[0]; await _cmsCandidateService.UpdateBannerAsync(file); return Success(); } catch (Exception ex) { return Error(ex); } } /// /// อัพเดทข้อมูล Agency ผู้สมัคร /// /// Agency /// /// เมื่อทำการอัพเดทข้อมูล Agency ผู้สมัคร สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpPost("agency")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> UpdateAgencyAsync(List agency) { try { var getPermission = await _permission.GetPermissionAPIAsync("CREATE", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } await _cmsCandidateService.UpdateAgencyAsync(agency); return Success(); } catch (Exception ex) { return Error(ex); } } /// /// อัพเดทข้อมูล Government ผู้สมัคร /// /// Government /// /// เมื่อทำการอัพเดทข้อมูล Government ผู้สมัคร สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpPost("government")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> UpdateGovernmentAsync(List government) { try { var getPermission = await _permission.GetPermissionAPIAsync("CREATE", "SYS_EXAM_WEBSITE"); var jsonData = JsonConvert.DeserializeObject(getPermission); if (jsonData["status"]?.ToString() != "200") { return Error(jsonData["message"]?.ToString(), StatusCodes.Status403Forbidden); } await _cmsCandidateService.UpdateGovernmentAsync(government); return Success(); } catch (Exception ex) { return Error(ex); } } /// /// ข้อมูล home page cms /// /// /// เมื่อทำการข้อมูล home page cms สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("home")] [AllowAnonymous] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task GetHomePageAsync() { // try // { var item = await _cmsCandidateService.GetHomePageAsync(); return item; // } // catch (Exception ex) // { // return null; // } } /// /// ข้อมูล content home page /// /// /// เมื่อทำการข้อมูล content home page สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("content/home")] [AllowAnonymous] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task GetHomePageContentAsync() { // try // { var item = await _cmsCandidateService.GetHomePageContentAsync(); return item; // } // catch (Exception ex) // { // return null; // } } /// /// ข้อมูล content about page /// /// /// เมื่อทำการข้อมูล content about page สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("content/about")] [AllowAnonymous] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task GetAboutPageContentAsync() { // try // { var item = await _cmsCandidateService.GetAboutPageContentAsync(); return item; // } // catch (Exception ex) // { // return null; // } } /// /// List ข้อมูลรอบสมัครสอบ /// /// /// เมื่อทำการ List ข้อมูลรอบสมัครสอบ สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("qualifying")] [AllowAnonymous] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> GetsCMSExamsAsync(int limit = 0) { // try // { var items = await _cmsCandidateService.GetsCMSExamsAsync(limit); return items; // } // catch (Exception ex) // { // return null; // } } /// /// Get ข้อมูลรอบสมัครสอบ /// /// รหัสรอบสมัคร /// /// เมื่อทำการ Get ข้อมูลรอบสมัครสอบ สำเร็จ /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("qualifying/{examId:length(36)}")] [AllowAnonymous] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task GetCMSExamsAsync(string examId) { // try // { var item = await _cmsCandidateService.GetCMSExamsAsync(examId); return item; // } // catch (Exception ex) // { // return null; // } } #endregion } }