using System.Net.Http.Headers; using BMA.EHR.Organization.Service.Extensions; using BMA.EHR.Profile.Service.Controllers; using BMA.EHR.Recruit.Service.Services; using BMA.EHR.Report.Service.Data; using BMA.EHR.Report.Service.Responses; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; using Newtonsoft.Json; using Swashbuckle.AspNetCore.Annotations; using Telerik.Reporting; using Telerik.Reporting.Processing; namespace BMA.EHR.Report.Service.Controllers { [Route("api/v{version:apiVersion}/report/recruit")] [ApiVersion("1.0")] [ApiController] [Produces("application/json")] [Authorize] [SwaggerTag("รายงานข้อมูลการสอบแข่งขัน")] public class RecruitReportController : BaseController { #region " Fields " private readonly ApplicationDbContext _context; private readonly IWebHostEnvironment _hostingEnvironment; private readonly IConfiguration _configuration; private readonly string space = "ㅤ"; private readonly RecruitService _recruitService; private readonly IHttpContextAccessor _httpContextAccessor; #endregion #region " Constructor and Destructor " public RecruitReportController(ApplicationDbContext context, IWebHostEnvironment hostingEnvironment, IConfiguration configuration, IHttpContextAccessor httpContextAccessor, RecruitService recruitService) { this._context = context; this._hostingEnvironment = hostingEnvironment; this._configuration = configuration; this._recruitService = recruitService; this._httpContextAccessor = httpContextAccessor; } private string? token => _httpContextAccessor.HttpContext.Request.Headers["Authorization"]; #endregion #region " Methods " /// /// แสดงหนังสือรับรอง /// /// รหัสรอบการสอบ /// เลขประจำตัวผู้สมัครสอบ /// ชนิดของรายงาน /// /// เมื่อแสดงรายงานสำเร็จ /// ค่าตัวแปรที่ส่งมาไม่ถูกต้อง /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("certificate/{type:int}/{id:length(36)}/{examId}")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status400BadRequest)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> GetCertificateReportAsync(Guid id, string examId, int type) { try { var name = ""; var position = ""; var apiUrl = $"{_configuration["API"]}/org/find/head/officer"; using (var client = new HttpClient()) { client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", token.Replace("Bearer ", "")); client.DefaultRequestHeaders.Add("api_key", _configuration["API_KEY"]); var _req = new HttpRequestMessage(HttpMethod.Get, apiUrl); var _res = await client.SendAsync(_req); var _result = await _res.Content.ReadAsStringAsync(); if (_res.IsSuccessStatusCode) { var org = JsonConvert.DeserializeObject(_result); name = org.result.rootId == null ? "" : org.result.rootId; position = org.result.rootId == null ? "" : org.result.rootId; } } var data = await _context.Recruits.AsQueryable() .Include(x => x.RecruitImport) .Where(x => x.RecruitImport.Id == id) .Where(x => x.ExamId == examId) .Join(_context.RecruitScores.AsQueryable() .Include(x => x.ScoreImport), rc => new { rc.RecruitImport.Year, rc.ExamId }, sc => new { sc.ScoreImport.Year, sc.ExamId }, (p, sr) => new { ExamID = p.ExamId, p.CitizenId, Order = p.RecruitImport.Order, Year = p.RecruitImport.Year.ToThaiYear(), FullName = $"{p.Prefix}{p.FirstName} {p.LastName}", ExamResult = sr == null ? "" : sr.ExamStatus, EndDate = p.RecruitImport.RegisterEndDate == null ? "-" : p.RecruitImport.RegisterEndDate.Value.ToThaiFullDate3(), AuthName = name, AuthPosition = position }) .FirstOrDefaultAsync(); var rptFile = Path.Combine(_hostingEnvironment.ContentRootPath, "Report", "Recruit", $"rptCertificate{type}.trdp"); ReportPackager reportPackager = new ReportPackager(); Telerik.Reporting.Report report = null; using (var sourceStream = System.IO.File.OpenRead(rptFile)) { report = (Telerik.Reporting.Report)reportPackager.UnpackageDocument(sourceStream); } report.DataSource = data; System.Collections.Hashtable deviceInfo = new System.Collections.Hashtable(); InstanceReportSource instanceReportSource = new InstanceReportSource() { ReportDocument = report }; ReportProcessor reportProcessor = new ReportProcessor(_configuration); RenderingResult result = reportProcessor.RenderReport("PDF", instanceReportSource, deviceInfo); var content = result.DocumentBytes; return File(content, "application/pdf", $"หนังสือรับรอง_{data.CitizenId}_{data.FullName}.pdf"); } catch (Exception ex) { return Error(ex, "เกิดข้อผิดพลาดในการแสดงรายงาน"); } } /// /// แสดงเอกสารผลสอบ /// /// รหัสรอบการสอบ /// เลขประจำตัวผู้สมัครสอบ /// /// เมื่อแสดงรายงานสำเร็จ /// ค่าตัวแปรที่ส่งมาไม่ถูกต้อง /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("score/{id:length(36)}/{examId}")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status400BadRequest)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> GetScoreReportAsync(Guid id, string examId) { try { var data = await _context.Recruits.AsQueryable() .Include(x => x.RecruitImport) .Include(x => x.Documents) .ThenInclude(x => x.DocumentFile) .Where(x => x.RecruitImport.Id == id) .Where(x => x.ExamId == examId) .Join(_context.RecruitScores.AsQueryable() .Include(x => x.ScoreImport), rc => new { rc.RecruitImport.Year, rc.ExamId }, sc => new { sc.ScoreImport.Year, sc.ExamId }, (p, sr) => new { ExamId = p.ExamId, CitizenId = p.CitizenId, p.Prefix, FullName = $"{p.Prefix}{p.FirstName} {p.LastName}", DateOfBirth = p.DateOfBirth.ToThaiShortDate(), Gender = p.Gendor, Degree = p.Educations.First().Degree, Major = p.Educations.First().Major, ExamResult = sr == null ? "" : sr.ExamStatus, University = p.Educations.First().University, PositionName = p.PositionName, ExamName = $"{p.RecruitImport.Name} ครั้งที่ {p.RecruitImport.Order}/{p.RecruitImport.Year.ToThaiYear()}", Number = sr == null ? "" : sr.Number, ExamCount = _recruitService.GetExamCount(p.CitizenId), ScoreExpire = p.RecruitImport.AnnouncementDate == null ? "" : p.RecruitImport.AnnouncementDate.Value.AddYears(2).ToThaiShortDate(), FullA = sr == null ? 0.0 : sr.FullA, SumA = sr == null ? 0.0 : sr.SumA, //FullB = sr == null ? 0.0 : sr.FullB, //SumB = sr == null ? 0.0 : sr.SumB, FullC = sr == null ? 0.0 : sr.FullC, SumC = sr == null ? 0.0 : sr.SumC, }) .FirstOrDefaultAsync(); var rptFile = Path.Combine(_hostingEnvironment.ContentRootPath, "Report", "Recruit", $"rptExamResult.trdp"); ReportPackager reportPackager = new ReportPackager(); Telerik.Reporting.Report report = null; using (var sourceStream = System.IO.File.OpenRead(rptFile)) { report = (Telerik.Reporting.Report)reportPackager.UnpackageDocument(sourceStream); } report.DataSource = data; System.Collections.Hashtable deviceInfo = new System.Collections.Hashtable(); InstanceReportSource instanceReportSource = new InstanceReportSource() { ReportDocument = report }; ReportProcessor reportProcessor = new ReportProcessor(_configuration); RenderingResult result = reportProcessor.RenderReport("PDF", instanceReportSource, deviceInfo); var content = result.DocumentBytes; return File(content, "application/pdf", $"ผลคะแนนสอบ_{data.CitizenId}_{data.FullName}.pdf"); } catch (Exception ex) { return Error(ex, "เกิดข้อผิดพลาดในการแสดงรายงาน"); } } [HttpGet("candidate/{id:length(36)}")] [AllowAnonymous] public async Task> GetCandidateListReportAsync(Guid id) { try { var data = await _context.Recruits.AsQueryable() .Include(x => x.RecruitImport) .Include(x => x.Documents) .ThenInclude(x => x.DocumentFile) .Where(x => x.RecruitImport.Id == id) .OrderBy(x => x.ExamId) .Select(p => new { ExamId = p.ExamId != null ? p.ExamId.ToThaiNumber() : string.Empty, FullName = $"{p.Prefix}{p.FirstName} {p.LastName}", PositionName = p.PositionName, ExamName = $"ครั้งที่ {(p.RecruitImport != null ? p.RecruitImport.Order.ToString().ToThaiNumber() : "")}/{(p.RecruitImport != null ? p.RecruitImport.Year.ToThaiYear().ToString().ToThaiNumber() : "")}", }).ToListAsync(); if (data.Count == 0) return Error("ไม่พบข้อมูลในระบบ"); //var rptFile = Path.Combine(_hostingEnvironment.ContentRootPath, "Report", "Recruit", $"rptCandidateList.trdp"); //ReportPackager reportPackager = new ReportPackager(); //Telerik.Reporting.Report report = null; //using (var sourceStream = System.IO.File.OpenRead(rptFile)) //{ // report = (Telerik.Reporting.Report)reportPackager.UnpackageDocument(sourceStream); //} ////report.DataSource = data; //report.ReportParameters["ExamName"].Value = data[0].ExamName.ToThaiNumber(); //var tbl = (Telerik.Reporting.Table)report.Items["detailSection1"].Items["table1"]; //tbl.DataSource = data; //System.Collections.Hashtable deviceInfo = new System.Collections.Hashtable(); //InstanceReportSource instanceReportSource = new InstanceReportSource() //{ // ReportDocument = report //}; //ReportProcessor reportProcessor = new ReportProcessor(_configuration); //RenderingResult result = reportProcessor.RenderReport("PDF", instanceReportSource, deviceInfo); //var content = result.DocumentBytes; //return File(content, "application/pdf", $"รายชื่อผู้มีสิทธิ์สอบ_{data.First().ExamName}.pdf"); var examName = data[0].ExamName; var _data = new { template = "rptCandidateList", reportName = $"รายชื่อผู้มีสิทธิ์สอบ_{data.First().ExamName}", data = new { examName = examName, data = data } }; return Success(_data); } catch (Exception ex) { return Error(ex); } } /// /// แสดงรายชื่อแบ่งตามตำแหน่ง (สอบแข่งขัน) /// /// รหัสรอบการสอบ /// /// เมื่อแสดงรายงานสำเร็จ /// ค่าตัวแปรที่ส่งมาไม่ถูกต้อง /// ไม่ได้ Login เข้าระบบ /// เมื่อเกิดข้อผิดพลาดในการทำงาน [HttpGet("candidate-new/{id:length(36)}")] [AllowAnonymous] public async Task> GetCandidateNewListReportAsync(Guid id) { try { var data = await _context.Recruits.AsQueryable() .Include(x => x.RecruitImport) .Include(x => x.Payments) .Include(x => x.Documents) .ThenInclude(x => x.DocumentFile) .Where(x => x.RecruitImport.Id == id) .OrderBy(x => x.ExamId) .Select(p => new { FullName = $"{p.Prefix}{p.FirstName} {p.LastName}", PositionName = p.PositionName, Remark = p.Remark != null ? p.Remark.ToThaiNumber() : "", RefNo1 = p.Payments.Select(x => x.RefNo1).FirstOrDefault() != null ? p.Payments.Select(x => x.RefNo1).FirstOrDefault().ToThaiNumber() : "", ExamName = $"ครั้งที่ {(p.RecruitImport != null ? p.RecruitImport.Order.ToString().ToThaiNumber() : "")}/{(p.RecruitImport != null ? p.RecruitImport.Year.ToThaiYear().ToString().ToThaiNumber() : "")}", }).ToListAsync(); if (data.Count == 0) return Error("ไม่พบข้อมูลในระบบ"); var examName = data[0].ExamName; var groupData = data .GroupBy(x => x.PositionName) .Select(g => new { PositionName = $"ตำแหน่ง {g.Key}", Total = $"จำนวน {g.Count().ToString().ToThaiNumber()} ราย", Persons = g.Select((x, index) => new { No = (index + 1).ToString().ToThaiNumber(), RefNo1 = x.RefNo1, FullName = x.FullName, Remark = x.Remark }).ToList() }) .ToList(); var _data = new { template = "rptCandidateList-New", reportName = $"รายชื่อแบ่งตามตำแหน่ง(สอบแข่งขัน)", data = new { examName = examName, data = groupData } }; return Success(_data); } catch (Exception ex) { return Error(ex); } } [HttpGet("pass/{id:length(36)}")] [AllowAnonymous] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status400BadRequest)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status500InternalServerError)] public async Task> GetPassExamListReportAsync(Guid id) { try { var data = await _context.Recruits.AsQueryable() .Include(x => x.RecruitImport) .ThenInclude(x => x.ScoreImport) .Include(x => x.Documents) .ThenInclude(x => x.DocumentFile) .Join(_context.RecruitScores.AsQueryable() .Include(x => x.ScoreImport) .Where(x => x.ScoreImport.RecruitImportId == id) .Where(x => x.ExamStatus == "ผ่าน"), rc => new { id = rc.RecruitImport.Id, examId = rc.ExamId }, sc => new { id = sc.ScoreImport.RecruitImportId, examId = sc.ExamId }, (p, sr) => new { Id = p.RecruitImport.Id, ExamId = p.ExamId != null ? p.ExamId.ToThaiNumber() : string.Empty, //CitizenId = p.CitizenId, //p.Prefix, FullName = $"{p.Prefix}{p.FirstName} {p.LastName}", //DateOfBirth = p.DateOfBirth == null ? "" : p.DateOfBirth.ToThaiShortDate(), //Gender = p.Gendor, //Degree = p.Educations.FirstOrDefault() == null ? "" : p.Educations.FirstOrDefault().Degree, //Major = p.Educations.FirstOrDefault() == null ? "" : p.Educations.FirstOrDefault().Major, ExamResult = sr == null ? "" : sr.ExamStatus, //University = p.Educations.FirstOrDefault() == null ? "" : p.Educations.FirstOrDefault().University, //PositionName = p.PositionName, ExamName = p.RecruitImport.Order == null ? "" : $"{p.RecruitImport.Name} ครั้งที่ {p.RecruitImport.Order.ToString().ToThaiNumber()}/{p.RecruitImport.Year.ToThaiYear().ToString().ToThaiNumber()}", Number = sr.Number == null ? "๐" : sr.Number, //ExamCount = _recruitService.GetExamCount(p.CitizenId), //ScoreExpire = p.RecruitImport.AnnouncementDate == null ? "" : p.RecruitImport.AnnouncementDate.Value.AddYears(2).ToThaiShortDate(), //FullA = sr.FullA == null ? 0.0 : sr.FullA, //SumA = sr.SumA == null ? 0.0 : sr.SumA, //FullB = sr.FullB == null ? 0.0 : sr.FullB, //SumB = sr.SumB == null ? 0.0 : sr.SumB, //FullC = sr.FullC == null ? 0.0 : sr.FullC, //SumC = sr.SumC == null ? 0.0 : sr.SumC, SumScore = sr == null ? "๐" : (((sr.SumA > 0 ? sr.SumA : 0) + /*sr.SumB +*/ (sr.SumC > 0 ? sr.SumC : 0)).ToString()).ToThaiNumber(), }) .OrderBy(x => x.Number) .Where(x => x.Id == id) .Where(x => x.ExamResult == "ผ่าน") .ToListAsync(); if (data.Count == 0) return Error("ไม่พบข้อมูลในระบบ"); var data_ = data.Select(x => new { x.ExamName, Number = x.Number.ToThaiNumber(), x.ExamId, x.FullName, x.SumScore }).ToList(); //var rptFile = Path.Combine(_hostingEnvironment.ContentRootPath, "Report", "Recruit", $"rptPassExamList.trdp"); //ReportPackager reportPackager = new ReportPackager(); //Telerik.Reporting.Report report = null; //using (var sourceStream = System.IO.File.OpenRead(rptFile)) //{ // report = (Telerik.Reporting.Report)reportPackager.UnpackageDocument(sourceStream); //} ////report.DataSource = data; //report.ReportParameters["ExamName"].Value = data_[0].ExamName.ToThaiNumber(); //var tbl = (Telerik.Reporting.Table)report.Items["detailSection1"].Items["table1"]; //tbl.DataSource = data_; //System.Collections.Hashtable deviceInfo = new System.Collections.Hashtable(); //InstanceReportSource instanceReportSource = new InstanceReportSource() //{ // ReportDocument = report //}; //ReportProcessor reportProcessor = new ReportProcessor(_configuration); //RenderingResult result = reportProcessor.RenderReport("PDF", instanceReportSource, deviceInfo); //var content = result.DocumentBytes; //return File(content, "application/pdf", $"รายชื่อผู้สอบแข่งขันได้_{data.First().ExamName}.pdf"); var examName = data[0].ExamName; var _data = new { template = "rptPassExamList", reportName = $"รายชื่อผู้สอบแข่งขันได้_{data.First().ExamName}", data = new { examName = examName, data = data_ } }; return Success(_data); } catch (Exception ex) { return Error(ex, "เกิดข้อผิดพลาดในการแสดงรายงาน"); } } #endregion } }