2021-12-07 18:27:52 +05:00
|
|
|
|
using System;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
2021-12-07 18:27:52 +05:00
|
|
|
|
using AsbCloudDb.Model;
|
|
|
|
|
using AsbSaubReport.Model;
|
|
|
|
|
using Microsoft.EntityFrameworkCore;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
|
2021-12-07 18:27:52 +05:00
|
|
|
|
namespace AsbCloudInfrastructure
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
|
|
|
|
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;
|
2021-05-18 12:33:23 +05:00
|
|
|
|
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)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
{
|
|
|
|
|
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)
|
2021-05-18 12:33:23 +05:00
|
|
|
|
.Include(w => w.Telemetry)
|
2021-07-27 14:43:30 +05:00
|
|
|
|
.FirstOrDefault(w => w.Id == idWell);
|
2021-05-18 12:33:23 +05:00
|
|
|
|
|
|
|
|
|
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-05-18 12:33:23 +05:00
|
|
|
|
|
2021-08-10 16:37:13 +05:00
|
|
|
|
events = context.TelemetryEvents
|
2021-05-18 12:33:23 +05:00
|
|
|
|
.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
|
|
|
|
|
{
|
2021-12-07 18:27:52 +05:00
|
|
|
|
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,
|
2021-05-18 12:33:23 +05:00
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
|
2021-07-23 14:55:31 +05:00
|
|
|
|
public AnalyzeResult Analyze()
|
|
|
|
|
{
|
2021-09-20 15:25:08 +05:00
|
|
|
|
var messagesStat = (from item in context.TelemetryMessages
|
2021-08-09 15:41:42 +05:00
|
|
|
|
where item.IdTelemetry == idTelemetry
|
2021-09-20 15:25:08 +05:00
|
|
|
|
group item.Date by item.IdTelemetry into g
|
2021-09-23 10:52:10 +05:00
|
|
|
|
select new { min = g.Min(), max = g.Max(), count = g.Count() })
|
2021-09-20 15:25:08 +05:00
|
|
|
|
.FirstOrDefault();
|
2021-07-23 14:55:31 +05:00
|
|
|
|
|
2021-09-20 15:25:08 +05:00
|
|
|
|
var dataStat = (from item in context.TelemetryDataSaub
|
2021-09-23 10:52:10 +05:00
|
|
|
|
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();
|
2021-07-23 14:55:31 +05:00
|
|
|
|
|
2021-08-09 15:41:42 +05:00
|
|
|
|
var result = new AnalyzeResult
|
|
|
|
|
{
|
2021-09-23 10:52:10 +05:00
|
|
|
|
MinDate = dataStat?.min ?? messagesStat?.min ?? default,
|
|
|
|
|
MaxDate = dataStat?.max ?? messagesStat?.max ?? default,
|
2021-09-20 15:25:08 +05:00
|
|
|
|
MessagesCount = messagesStat?.count ?? 0,
|
2021-07-23 14:55:31 +05:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
return result;
|
|
|
|
|
}
|
|
|
|
|
|
2021-05-18 12:33:23 +05:00
|
|
|
|
public IQueryable<DataSaubReport> GetDataSaubItems(DateTime begin, DateTime end)
|
2021-09-14 17:17:33 +05:00
|
|
|
|
=> from item in context.TelemetryDataSaub
|
2021-07-21 15:29:19 +05:00
|
|
|
|
where item.IdTelemetry == idTelemetry
|
|
|
|
|
&& item.Date >= begin
|
|
|
|
|
&& item.Date <= end
|
2021-09-23 10:52:10 +05:00
|
|
|
|
orderby item.Date
|
2021-07-21 15:29:19 +05:00
|
|
|
|
select new DataSaubReport
|
|
|
|
|
{
|
2021-11-13 18:47:11 +05:00
|
|
|
|
//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,
|
|
|
|
|
};
|
|
|
|
|
|
2021-05-18 12:33:23 +05:00
|
|
|
|
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
|
2021-09-23 10:52:10 +05:00
|
|
|
|
orderby item.Date
|
2021-07-21 15:29:19 +05:00
|
|
|
|
select new MessageReport
|
|
|
|
|
{
|
|
|
|
|
Id = item.Id,
|
|
|
|
|
Date = item.Date,
|
2021-09-23 18:00:41 +05:00
|
|
|
|
Category = events.GetValueOrDefault(item.IdEvent) == null
|
|
|
|
|
? $""
|
|
|
|
|
: categories[events[item.IdEvent].IdCategory],
|
2021-07-21 15:29:19 +05:00
|
|
|
|
User = item.IdTelemetryUser == null
|
|
|
|
|
? ""
|
2021-09-23 18:00:41 +05:00
|
|
|
|
: 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
|
|
|
|
};
|
2021-05-18 12:33:23 +05:00
|
|
|
|
|
|
|
|
|
public WellInfoReport GetWellInfo()
|
|
|
|
|
=> info;
|
|
|
|
|
}
|
|
|
|
|
}
|