using AsbCloudApp.Data; using AsbCloudApp.Data.DetectedOperation; using AsbCloudApp.Requests; using AsbCloudApp.Services; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; using System.Collections.Generic; using System.ComponentModel.DataAnnotations; using System.Linq; using System.Threading; using System.Threading.Tasks; namespace AsbCloudWebApi.Controllers.SAUB { /// /// Операции определенные по телеметрии САУБ /// [Route("api/[controller]")] [ApiController] [Authorize] public class DetectedOperationController : ControllerBase { private readonly IDetectedOperationService detectedOperationService; private readonly IWellService wellService; public DetectedOperationController(IDetectedOperationService detectedOperationService, IWellService wellService) { this.detectedOperationService = detectedOperationService; this.wellService = wellService; } /// /// получить справочник операций. Отличается от операций заводимых вручную. /// При задании id скважины вернет только те операции, которые определились в телеметрии этой скважины. /// /// [опционально] id скважины /// /// [HttpGet("categories")] [ProducesResponseType(typeof(IEnumerable), (int)System.Net.HttpStatusCode.OK)] public async Task GetCategoriesAsync([FromQuery] int? idWell, CancellationToken token = default) { var result = await detectedOperationService.GetCategoriesAsync(idWell, token); return Ok(result); } /// /// Получить фильтрованный список операций по телеметрии САУБ /// /// /// /// [HttpGet] [ProducesResponseType(typeof(DetectedOperationListDto), (int)System.Net.HttpStatusCode.OK)] public async Task GetAsync( [FromQuery] DetectedOperationRequest request, CancellationToken token = default) { if (!await UserHasAccesToWellAsync(request.IdWell, token)) return Forbid(); var result = await detectedOperationService.GetAsync(request, token); return Ok(result); } /// /// Получить статистику по фильтрованному списку операций по телеметрии САУБ /// /// /// /// [HttpGet("stat")] [ProducesResponseType(typeof(IEnumerable), (int)System.Net.HttpStatusCode.OK)] public async Task GetStatAsync( [FromQuery] DetectedOperationRequest request, CancellationToken token = default) { if (!await UserHasAccesToWellAsync(request.IdWell, token)) return Forbid(); var result = await detectedOperationService.GetOperationsStatAsync(request, token); return Ok(result); } /// /// Удалить операции. /// Удаленные операции будут определены повторно сервисом автоматизированного определения операций. /// Может потребоваться при изменении алгоритмов определения /// /// /// /// [HttpDelete] [Permission] [ProducesResponseType(typeof(int), (int)System.Net.HttpStatusCode.OK)] public async Task DeleteAsync( [FromQuery] DetectedOperationRequest request, CancellationToken token) { if (!await UserHasAccesToWellAsync(request.IdWell, token)) return Forbid(); var result = await detectedOperationService.DeleteAsync(request, token); return Ok(result); } protected async Task UserHasAccesToWellAsync(int idWell, CancellationToken token) { var idCompany = User.GetCompanyId(); if (idCompany is not null && await wellService.IsCompanyInvolvedInWellAsync((int)idCompany, idWell, token) .ConfigureAwait(false)) return true; return false; } /// /// Создает excel файл с операциями по скважине /// /// id скважины /// /// Токен отмены задачи /// Запрашиваемый файл [HttpGet] [Route("export")] [Permission] [ProducesResponseType(typeof(PhysicalFileResult), (int)System.Net.HttpStatusCode.OK)] public async Task ExportAsync(int? idWell, int? idCluster, CancellationToken token = default) { if (idCluster is null && idWell is null) return this.MakeBadRequest(nameof(idWell), $"One of {nameof(idWell)} or {nameof(idCluster)} mast be set."); int? idCompany = User.GetCompanyId(); if (idCompany is null) return Forbid(); IEnumerable idsWells; if (idCluster is not null) { var companyWells = await wellService.GetAsync(new() { IdCompany = idCompany }, token); idsWells = companyWells.Where(w => w.IdCluster == idCluster) .Select(w=>w.Id); } else { if (!await wellService.IsCompanyInvolvedInWellAsync((int)idCompany, (int)idWell, token).ConfigureAwait(false)) return Forbid(); idsWells = new List { (int)idWell }; } var stream = await detectedOperationService.ExportAsync(idsWells, token); var fileName = "operations.xlsx"; return File(stream, "application/octet-stream", fileName); } } }