DD.WellWorkover.Cloud/AsbCloudInfrastructure/ReportDataSourcePgCloud.cs

142 lines
5.7 KiB
C#
Raw Normal View History

using System;
using System.Collections.Generic;
using System.Linq;
using AsbCloudDb.Model;
using AsbSaubReport.Model;
using Microsoft.EntityFrameworkCore;
namespace AsbCloudInfrastructure
{
public class ReportDataSourcePgCloud : IReportDataSource
{
private readonly AsbCloudDbContext context;
private readonly int? idTelemetry;
private readonly WellInfoReport info;
2021-08-10 16:37:13 +05:00
private readonly Dictionary<int, TelemetryEvent> events;
private readonly Dictionary<int, TelemetryUser> users;
private readonly Dictionary<int, string> categories = new Dictionary<int, string>
{
{1, "Авария"},
{2, "Предупреждение"},
{3, "Информация"},
};
2021-07-27 14:43:30 +05:00
public ReportDataSourcePgCloud(AsbCloudDbContext context, int idWell)
{
this.context = context;
var well = context.Wells
2021-07-21 15:29:19 +05:00
.Include(w => w.Cluster)
.ThenInclude(c => c.Deposit)
2021-07-21 16:30:57 +05:00
.Include(w => w.RelationCompaniesWells)
.ThenInclude(r => r.Company)
.Include(w => w.Telemetry)
2021-07-27 14:43:30 +05:00
.FirstOrDefault(w => w.Id == idWell);
idTelemetry = well?.IdTelemetry;
if (idTelemetry is null)
2021-07-27 14:43:30 +05:00
throw new ArgumentException($"Well {idWell} doesn't contain telemetry", nameof(idWell));
2021-08-10 16:37:13 +05:00
events = context.TelemetryEvents
.Where(e => e.IdTelemetry == idTelemetry)
.ToDictionary(e => e.IdEvent, e => e);
users = context.TelemetryUsers
.Where(u => u.IdTelemetry == idTelemetry)
.ToDictionary(u => u.IdUser, u => u);
info = new WellInfoReport
{
Deposit = well?.Cluster?.Deposit?.Caption,
Cluster = well?.Cluster?.Caption,
Well = well?.Caption,
Customer = well?.RelationCompaniesWells.FirstOrDefault(c => c.Company.IdCompanyType == 1)?.Company.Caption,
DrillingStartDate = well?.Telemetry?.Info?.DrillingStartDate ?? default,
TimeZoneId = well?.Telemetry?.Info?.TimeZoneId ?? default,
TimeZoneOffsetTotalHours = well?.Telemetry?.Info?.TimeZoneOffsetTotalHours ?? default,
};
}
public AnalyzeResult Analyze()
{
2021-09-20 15:25:08 +05:00
var messagesStat = (from item in context.TelemetryMessages
where item.IdTelemetry == idTelemetry
2021-09-20 15:25:08 +05:00
group item.Date by item.IdTelemetry into g
select new { min = g.Min(), max = g.Max(), count = g.Count() })
2021-09-20 15:25:08 +05:00
.FirstOrDefault();
2021-09-20 15:25:08 +05:00
var dataStat = (from item in context.TelemetryDataSaub
where item.IdTelemetry == idTelemetry
2021-09-20 15:25:08 +05:00
group item.Date by item.IdTelemetry into g
select new { min = g.Min(), max = g.Max(), count = g.Count() })
.FirstOrDefault();
var result = new AnalyzeResult
{
MinDate = dataStat?.min ?? messagesStat?.min ?? default,
MaxDate = dataStat?.max ?? messagesStat?.max ?? default,
2021-09-20 15:25:08 +05:00
MessagesCount = messagesStat?.count ?? 0,
};
return result;
}
public IQueryable<DataSaubReport> GetDataSaubItems(DateTime begin, DateTime end)
=> from item in context.TelemetryDataSaub
2021-07-21 15:29:19 +05:00
where item.IdTelemetry == idTelemetry
&& item.Date >= begin
&& item.Date <= end
orderby item.Date
2021-07-21 15:29:19 +05:00
select new DataSaubReport
{
//Id = item.Id,
2021-07-21 15:29:19 +05:00
Date = item.Date,
Mode = item.Mode,
WellDepth = item.WellDepth,
BitDepth = item.BitDepth,
BlockPosition = item.BlockPosition,
BlockSpeed = item.BlockSpeed,
BlockSpeedSp = item.BlockSpeedSp,
BlockSpeedSpDevelop = item.BlockSpeedSpDevelop,
Pressure = item.Pressure,
PressureSp = item.PressureSp,
AxialLoad = item.AxialLoad,
AxialLoadSp = item.AxialLoadSp,
AxialLoadLimitMax = item.AxialLoadLimitMax,
HookWeight = item.HookWeight,
RotorTorque = item.RotorTorque,
RotorTorqueSp = item.RotorTorqueSp,
RotorSpeed = item.RotorSpeed,
Flow = item.Flow,
PressureSpDevelop = item.PressureSpDevelop,
};
public IQueryable<MessageReport> GetMessages(DateTime begin, DateTime end)
2021-08-10 16:37:13 +05:00
=> from item in context.TelemetryMessages
2021-07-21 15:29:19 +05:00
where item.IdTelemetry == idTelemetry
&& item.Date >= begin
&& item.Date <= end
orderby item.Date
2021-07-21 15:29:19 +05:00
select new MessageReport
{
Id = item.Id,
Date = item.Date,
Category = events.GetValueOrDefault(item.IdEvent) == null
? $""
: categories[events[item.IdEvent].IdCategory],
2021-07-21 15:29:19 +05:00
User = item.IdTelemetryUser == null
? ""
: users.GetValueOrDefault((int)item.IdTelemetryUser) == null
? $"User id{item.IdTelemetryUser}"
: users[(int)item.IdTelemetryUser].MakeDisplayName(),
Text = events.GetValueOrDefault(item.IdEvent) == null
? $"Стбытие {item.IdEvent} {item.Arg0} {item.Arg1} {item.Arg2} {item.Arg3}"
: events[item.IdEvent].MakeMessageText(item)
2021-07-21 15:29:19 +05:00
};
public WellInfoReport GetWellInfo()
=> info;
}
}