using AsbCloudApp.Data.SAUB; using AsbCloudApp.Services; using AsbCloudDb.Model; using Microsoft.EntityFrameworkCore; using System; using System.Collections.Generic; using System.Linq; using System.Threading; using System.Threading.Tasks; namespace AsbCloudInfrastructure.Services.SAUB { public class SetpointsService : ISetpointsService { // ## Инфо от АПГ от 26.11.2021, дополнения ШОВ от 26.11.2021 private static readonly Dictionary SetpointInfos = new() { { "bitLoad", new SetpointInfoDto { Name = "bitLoad", DisplayName = "Осевая нагрузка, т" } }, { "dPressureMaxRotorSP", new SetpointInfoDto { Name = "dPressureMaxRotorSP", DisplayName = "Дифференциальное рабочее давление в роторе, атм" } }, { "dPressureMaxSlideSP", new SetpointInfoDto { Name = "dPressureMaxSlideSP", DisplayName = "Дифференциальное рабочее давление в слайде, атм" } }, { "torque", new SetpointInfoDto { Name = "torque", DisplayName = "Крутящий момент, кН*м" } }, { "speedRotorSp", new SetpointInfoDto { Name = "speedRotorSp", DisplayName = "Скорость бурения в роторе, м/ч" } }, { "speedSlideSp", new SetpointInfoDto { Name = "speedSlideSp", DisplayName = "Скорость бурения в слайде, м/ч" } }, { "speedDevelopSp", new SetpointInfoDto { Name = "speedDevelopSp", DisplayName = "Скорость проработки, м/ч" } }, { "torque_pid_out_limit", new SetpointInfoDto { Name = "torque_pid_out_limit", DisplayName = "Торк мастер. Допустимый процент отклонения от заданной скорости вращения" } }, // Такая же что и прямой //{ "", new SetpointInfoDto { Name = "", DisplayName = "Обороты ВСП, об/мин" } }, // Оно в ПЛК спинмастера, пока сделать нельзя, позднее можно. //{ "", new SetpointInfoDto { Name = "", DisplayName = "Расход промывочной жидкости, л/с" } }, // Нет в контроллере }; private readonly IAsbCloudDbContext db; private readonly ITelemetryService telemetryService; private readonly CrudCacheServiceBase setpointsRepository; public SetpointsService(IAsbCloudDbContext db, ITelemetryService telemetryService) { setpointsRepository = new CrudCacheServiceBase(db, q => q.Include(s => s.Author).Include(s => s.Well)); this.db = db; this.telemetryService = telemetryService; } public async Task InsertAsync(SetpointsRequestDto setpointsRequest, CancellationToken token) { setpointsRequest.IdState = 1; setpointsRequest.UploadDate = DateTime.UtcNow; var result = await setpointsRepository.InsertAsync(setpointsRequest, token); return result; } public async Task> GetAsync(int idWell, CancellationToken token) { var all = await setpointsRepository.GetAllAsync(token); var dtos = all.Where(s => s.IdWell == idWell); return dtos; } public async Task> GetForPanelAsync(string uid, CancellationToken token) { var idWell = telemetryService.GetIdWellByTelemetryUid(uid) ?? -1; if (idWell < 0) return null; var all = await setpointsRepository.GetAllAsync(token); var filtered = all.Where(s => s.IdWell == idWell && s.IdState == 1 && s.UploadDate.AddSeconds(s.ObsolescenceSec) > DateTime.Now); if (!filtered.Any()) return null; foreach (var entity in filtered) entity.IdState = 2; await setpointsRepository.UpdateRangeAsync(filtered, token); return filtered; } public async Task UpdateStateAsync(int id, SetpointsRequestDto setpointsRequestDto, CancellationToken token) { if (setpointsRequestDto.IdState != 3 && setpointsRequestDto.IdState != 4) throw new ArgumentOutOfRangeException(nameof(setpointsRequestDto), $"{nameof(setpointsRequestDto.IdState)} = {setpointsRequestDto.IdState}. Mast be 3 or 4."); var entity = await setpointsRepository.GetAsync(id, token); if (entity is null) return 0; entity.IdState = setpointsRequestDto.IdState; var affected = await setpointsRepository.UpdateAsync(entity, token); return affected; } public async Task TryDelete(int id, CancellationToken token) { var affected = await setpointsRepository.DeleteAsync(id, token); return affected; } public IEnumerable GetSetpointsNames() => SetpointInfos.Values; } }