using AsbCloudApp.Data; using AsbCloudApp.Services; using AsbCloudWebApi.SignalR; using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.SignalR; using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Threading.Tasks; namespace AsbCloudWebApi.Controllers { /// /// Контроллер отчетов по буровым скважинам /// [Route("api/report")] [ApiController] public class ReportController : ControllerBase { private readonly IReportService reportService; private readonly IWellService wellService; private readonly IHubContext reportsHubContext; public ReportController(IReportService reportService, IWellService wellService, IHubContext reportsHubContext) { this.reportService = reportService; this.wellService = wellService; this.reportsHubContext = reportsHubContext; } private void HandleReportProgressAsync(float progress, string operation, int id) => Task.Run(() => { reportsHubContext.Clients.Group($"Report_{id}").SendAsync( nameof(IReportHubClient.GetReportProgress), new { Progress = progress, Operation = operation, ReportName = "" } ); }); private void HandleReportNameAsync(string reportName, int groupId) => Task.Run(() => { reportsHubContext.Clients.All.SendAsync( nameof(IReportHubClient.GetReportProgress), new { Progress = 100, Operation = "Отчет успешно создан", ReportName = reportName } ); }); /// /// Создает отчет по скважине с указанными параметрами /// /// id скважины /// шаг интервала /// формат отчета (0-PDF, 1-LAS) /// дата начала интервала /// дата окончания интервала /// id фоновой задачи формирования отчета [HttpPost] [Route("{wellId}/report")] [ProducesResponseType(typeof(int), (int)System.Net.HttpStatusCode.OK)] public IActionResult CreateReport(int wellId, int stepSeconds, int format, DateTime begin = default, DateTime end = default) { int? idCompany = User.GetCompanyId(); if (idCompany is null) return Forbid(); if (!wellService.IsCompanyOwnsWell((int)idCompany, wellId)) return Forbid(); var id = reportService.CreateReport(wellId, stepSeconds, format, begin, end, HandleReportProgressAsync, HandleReportNameAsync); return Ok(id); } /// /// Возвращает файл-отчет с диска на сервере /// /// id скважины /// имя запрашиваемого файла (отчета) /// файл с отчетом [HttpGet] [Route("{wellId}/{reportName}")] [ProducesResponseType(typeof(PhysicalFileResult), (int)System.Net.HttpStatusCode.OK)] public IActionResult GetReport([FromRoute] int wellId, string reportName) { try { int? idCompany = User.GetCompanyId(); if (idCompany is null) return Forbid(); if (!wellService.IsCompanyOwnsWell((int)idCompany, wellId)) return Forbid(); // TODO: словарь content typoв var relativePath = Path.Combine(reportService.RootPath, $"{wellId}", reportName); return PhysicalFile(Path.GetFullPath(relativePath), "application/pdf", reportName); } catch (FileNotFoundException ex) { return NotFound($"Файл не найден. Текст ошибки: {ex.Message}"); } } /// /// Возвращает имена отчетов, хранящихся на диске, /// которые подходят под указанные параметры /// /// id скважины /// шаг интервала /// формат отчета (0-PDF, 1-LAS) /// дата начала интервала /// дата окончания интервала /// Список имен существующих отчетов (отчетов) [HttpGet] [Route("{wellId}/suitableReports")] [ProducesResponseType(typeof(IEnumerable), (int)System.Net.HttpStatusCode.OK)] public IActionResult GetSuitableReportsNames(int wellId, int stepSeconds, int format, DateTime begin = default, DateTime end = default) { var suitableReportsNames = reportService.GetSuitableReports(wellId, begin, end, stepSeconds, format); if (suitableReportsNames is null || !suitableReportsNames.Any()) return NoContent(); return Ok(suitableReportsNames); } /// /// Возвращает прогнозируемое количество страниц будущего отчета /// /// id скважины /// дата начала интервала /// дата окончания интервала /// шаг интервала /// формат отчета (0-PDF, 1-LAS) /// прогнозируемое кол-во страниц отчета [HttpGet] [Route("{wellId}/reportSize")] [ProducesResponseType(typeof(string), (int)System.Net.HttpStatusCode.OK)] public IActionResult GetReportSize(int wellId, int stepSeconds, int format, DateTime begin = default, DateTime end = default) { int? idCompany = User.GetCompanyId(); if (idCompany is null) return Forbid(); if (!wellService.IsCompanyOwnsWell((int)idCompany, wellId)) return Forbid(); int reportSize = reportService.GetReportPagesCount(wellId, begin, end, stepSeconds, format); return Ok(reportSize); } /// /// Возвращает даты самого старого и самого свежего отчетов в БД /// /// id скважины /// Даты самого старого и самого свежего отчетов в БД [HttpGet] [Route("{wellId}/reportsDatesRange")] [ProducesResponseType(typeof(DatesRangeDto), (int)System.Net.HttpStatusCode.OK)] public IActionResult GetReportsDateRange(int wellId) { int? idCompany = User.GetCompanyId(); if (idCompany is null) return Forbid(); if (!wellService.IsCompanyOwnsWell((int)idCompany, wellId)) return Forbid(); DatesRangeDto wellReportsDatesRange = reportService.GetReportsDatesRange(wellId); return Ok(wellReportsDatesRange); } } }