using Microsoft.AspNetCore.Mvc; using System.Net; using System.Net.Http.Headers; using Microsoft.Extensions.Hosting.Internal; using Microsoft.AspNetCore.Http.Extensions; using IStation.Untity; using Furion.DynamicApiController; using System.ComponentModel.DataAnnotations; using Mapster; using Microsoft.AspNetCore.Http; using Furion.DependencyInjection; using Microsoft.AspNetCore.Authorization; using Furion.DataEncryption; using Furion.FriendlyException; namespace IStation.Application { /// /// Report /// [AllowAnonymous] [Route("DataFile/Report ")] [ApiDescriptionSettings("DataFile", Name = "报表", Order = 999)] public class Eta_Day_Report_Controller : IDynamicApiController, ITransient { private readonly Service.EtaMultiRealRecord _service = new Service.EtaMultiRealRecord(); /// /// 泵站能效日报表 /// [Route("StationEtaDayReport@V1.0")] [HttpPost] public string StationEtaDayReport([FromQuery][Required] Day_DataFileTestInput input) { var station = new Service.Station().GetByID(input.CorpID, input.ObjectID); if (station == null) { throw Oops.Oh(ErrorCodes.D001, $"泵站不存在!!"); } var pumpPipeLineList = new Service.PipeLine().GetByBelongTypeAndBelongID(input.CorpID, input.ObjectType, input.ObjectID)?.FindAll(x => x.Catalog == IStation.Product.Catalog_JiBeng); if (pumpPipeLineList == null) { throw Oops.Oh(ErrorCodes.D001, $"机泵不存在!"); } var etaSumSingleDayRecordList = new List(); var etaSumSingleService = new Service.EtaSumSingleRecord(); foreach (var pipeLineitem in pumpPipeLineList) { var etaSumSingleRecord = etaSumSingleService.GetDayByObjectOfDay(pipeLineitem.CorpID, IStation.ObjectType.PipeLine, pipeLineitem.ID, input.DateTime); etaSumSingleDayRecordList.Add(etaSumSingleRecord); } if (etaSumSingleDayRecordList == null || etaSumSingleDayRecordList.Count < 1) { throw Oops.Oh(ErrorCodes.D001, $"能效数据不存在!-日期:[{input.DateTime}]"); } var pdf = new Eta_Day_ReportPdf(); var ReportPath = Path.Combine(ConfigHelper.DataPath, Settings.DataFile.PdfFolder); if (!Directory.Exists(ReportPath)) Directory.CreateDirectory(ReportPath); var EtaPathName = "Eta-Day"; var EtaPath = Path.Combine(ReportPath, EtaPathName); if (!Directory.Exists(EtaPath)) Directory.CreateDirectory(EtaPath); var dateTimePathName = input.DateTime.ToString("yyyy-MM"); var pdfPath= Path.Combine(EtaPath, dateTimePathName); if (!Directory.Exists(pdfPath)) Directory.CreateDirectory(pdfPath); var etaPdfFileName = $"Station_Eta_{station.ID}_{input.DateTime.ToString("MM-dd")}.pdf"; var etaPdfFilePath = Path.Combine(pdfPath, etaPdfFileName); if (File.Exists(etaPdfFilePath)) File.Delete(etaPdfFilePath); if (!pdf.Create4Stream(station, pumpPipeLineList, etaSumSingleDayRecordList, input.DateTime, etaPdfFilePath)) { throw Oops.Oh(ErrorCodes.D002, $"[{etaPdfFileName}]文件生成失败!"); } var turePath = Path.Combine("/" + Settings.DataFile.PdfFolder, EtaPathName, dateTimePathName, etaPdfFileName); turePath = turePath.Replace("\\", "/"); return turePath; } } }