forked from ddrilling/AsbCloudServer
CS2-24: Добавлены методы получения данных "глубина-день" и "скорость проходки-интервал".
This commit is contained in:
parent
7069e8af24
commit
70dca51987
11
AsbCloudApp/Data/WellDepthToDayDto.cs
Normal file
11
AsbCloudApp/Data/WellDepthToDayDto.cs
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
using System;
|
||||||
|
|
||||||
|
namespace AsbCloudApp.Data
|
||||||
|
{
|
||||||
|
public class WellDepthToDayDto
|
||||||
|
{
|
||||||
|
public double? WellDepth { get; set; }
|
||||||
|
public double? BitDepth { get; set; }
|
||||||
|
public DateTime Date { get; set; }
|
||||||
|
}
|
||||||
|
}
|
10
AsbCloudApp/Data/WellDepthToIntervalDto.cs
Normal file
10
AsbCloudApp/Data/WellDepthToIntervalDto.cs
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
using System;
|
||||||
|
|
||||||
|
namespace AsbCloudApp.Data
|
||||||
|
{
|
||||||
|
public class WellDepthToIntervalDto
|
||||||
|
{
|
||||||
|
public DateTime IntervalStartDate { get; set; }
|
||||||
|
public double IntervalDepthProgress { get; set; }
|
||||||
|
}
|
||||||
|
}
|
12
AsbCloudApp/Services/IAnalyticsService.cs
Normal file
12
AsbCloudApp/Services/IAnalyticsService.cs
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
using System.Collections.Generic;
|
||||||
|
using AsbCloudApp.Data;
|
||||||
|
|
||||||
|
namespace AsbCloudApp.Services
|
||||||
|
{
|
||||||
|
public interface IAnalyticsService
|
||||||
|
{
|
||||||
|
IEnumerable<WellDepthToDayDto> GetWellDepthToDayData(int wellId);
|
||||||
|
IEnumerable<WellDepthToIntervalDto> GetWellDepthToIntervalData(int wellId,
|
||||||
|
double interval = 24, int beginHour = 8, int beginMinutes = 0);
|
||||||
|
}
|
||||||
|
}
|
@ -34,6 +34,7 @@ namespace AsbCloudInfrastructure
|
|||||||
services.AddTransient<IEventService, EventService>();
|
services.AddTransient<IEventService, EventService>();
|
||||||
services.AddTransient<ITelemetryUserService, TelemetryUserService>();
|
services.AddTransient<ITelemetryUserService, TelemetryUserService>();
|
||||||
services.AddTransient<IReportService, ReportService>();
|
services.AddTransient<IReportService, ReportService>();
|
||||||
|
services.AddTransient<IAnalyticsService, AnalyticsService>();
|
||||||
|
|
||||||
return services;
|
return services;
|
||||||
}
|
}
|
||||||
|
102
AsbCloudInfrastructure/Services/AnalyticsService.cs
Normal file
102
AsbCloudInfrastructure/Services/AnalyticsService.cs
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
using System;
|
||||||
|
using System.Linq;
|
||||||
|
using AsbCloudApp.Data;
|
||||||
|
using AsbCloudApp.Services;
|
||||||
|
using AsbCloudDb.Model;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
|
namespace AsbCloudInfrastructure.Services
|
||||||
|
{
|
||||||
|
public class AnalyticsService : IAnalyticsService
|
||||||
|
{
|
||||||
|
private readonly IAsbCloudDbContext db;
|
||||||
|
private readonly ITelemetryService telemetryService;
|
||||||
|
|
||||||
|
public AnalyticsService(IAsbCloudDbContext db, ITelemetryService telemetryService)
|
||||||
|
{
|
||||||
|
this.db = db;
|
||||||
|
this.telemetryService = telemetryService;
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<WellDepthToDayDto> GetWellDepthToDayData(int wellId)
|
||||||
|
{
|
||||||
|
var telemetry = telemetryService.GetTelemetryByWellId(wellId);
|
||||||
|
|
||||||
|
if (telemetry is null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var depthToTimeData = (from d in db.DataSaubBases
|
||||||
|
where d.IdTelemetry == telemetry.Id
|
||||||
|
select new WellDepthToDayDto
|
||||||
|
{
|
||||||
|
WellDepth = d.WellDepth,
|
||||||
|
BitDepth =d.BitDepth,
|
||||||
|
Date = d.Date
|
||||||
|
}).ToList();
|
||||||
|
|
||||||
|
var m = (int)Math.Round(1d * depthToTimeData.Count / 2048);
|
||||||
|
|
||||||
|
if (m > 1)
|
||||||
|
depthToTimeData = depthToTimeData.Where((d, i) => i % m == 0).ToList();
|
||||||
|
|
||||||
|
return depthToTimeData;
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<WellDepthToIntervalDto> GetWellDepthToIntervalData(int wellId,
|
||||||
|
double interval = 24.0, int beginHour = 8, int beginMinutes = 0)
|
||||||
|
{
|
||||||
|
var intervalHours = TimeSpan.FromHours(interval);
|
||||||
|
var parseResult = TimeSpan.TryParse($"{beginHour}:{beginMinutes}", out var workDayBeginTime);
|
||||||
|
|
||||||
|
if (!parseResult)
|
||||||
|
workDayBeginTime = TimeSpan.FromHours(8);
|
||||||
|
|
||||||
|
var telemetry = telemetryService.GetTelemetryByWellId(wellId);
|
||||||
|
|
||||||
|
if (telemetry is null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var drillingData = (from d in db.DataSaubBases
|
||||||
|
where d.IdTelemetry == telemetry.Id
|
||||||
|
select new
|
||||||
|
{
|
||||||
|
d.WellDepth,
|
||||||
|
d.Date
|
||||||
|
}).ToList();
|
||||||
|
|
||||||
|
if (!drillingData.Any())
|
||||||
|
return null;
|
||||||
|
|
||||||
|
var drillingStartDate = drillingData.First().Date;
|
||||||
|
var periodStart = drillingStartDate.Hour < 8
|
||||||
|
? new DateTime(drillingStartDate.Year, drillingStartDate.Month, drillingStartDate.Day).AddDays(-1) + workDayBeginTime
|
||||||
|
: new DateTime(drillingStartDate.Year, drillingStartDate.Month, drillingStartDate.Day) + workDayBeginTime;
|
||||||
|
|
||||||
|
var periodEnd = periodStart + intervalHours;
|
||||||
|
var onePeriodData = new List<(double?, DateTime)>();
|
||||||
|
var drillingPeriods = new List<IEnumerable<(double?, DateTime)>>();
|
||||||
|
|
||||||
|
foreach (var d in drillingData)
|
||||||
|
{
|
||||||
|
if (d.Date < periodEnd)
|
||||||
|
{
|
||||||
|
onePeriodData.Add((d.WellDepth, d.Date));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
drillingPeriods.Add(onePeriodData);
|
||||||
|
onePeriodData.Clear();
|
||||||
|
periodStart = d.Date;
|
||||||
|
periodEnd = periodStart + intervalHours;
|
||||||
|
onePeriodData.Add((d.WellDepth, d.Date));
|
||||||
|
}
|
||||||
|
|
||||||
|
var wellDepthToIntervalData = drillingPeriods.Select(d => new WellDepthToIntervalDto
|
||||||
|
{
|
||||||
|
IntervalStartDate = d.FirstOrDefault().Item2,
|
||||||
|
IntervalDepthProgress = (d.Last().Item1 - d.FirstOrDefault().Item1) ?? 0.0 / interval
|
||||||
|
});
|
||||||
|
|
||||||
|
return wellDepthToIntervalData;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using AsbCloudApp.Data;
|
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
|
using AsbCloudApp.Data;
|
||||||
|
using AsbCloudApp.Services;
|
||||||
using Microsoft.AspNetCore.Mvc;
|
using Microsoft.AspNetCore.Mvc;
|
||||||
using Microsoft.AspNetCore.Authorization;
|
using Microsoft.AspNetCore.Authorization;
|
||||||
|
|
||||||
@ -11,6 +12,61 @@ namespace AsbCloudWebApi.Controllers
|
|||||||
[Authorize]
|
[Authorize]
|
||||||
public class AnalyticsController : ControllerBase
|
public class AnalyticsController : ControllerBase
|
||||||
{
|
{
|
||||||
|
private readonly IAnalyticsService analyticsService;
|
||||||
|
private readonly IWellService wellService;
|
||||||
|
|
||||||
|
public AnalyticsController(IAnalyticsService analyticsService, IWellService wellService)
|
||||||
|
{
|
||||||
|
this.analyticsService = analyticsService;
|
||||||
|
this.wellService = wellService;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Возвращает данные по скважине "глубина-день"
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="wellId">id скважины</param>
|
||||||
|
/// <returns>Коллекцию данных по скважине "глубина-день"</returns>
|
||||||
|
[HttpGet]
|
||||||
|
[Route("{wellId}/wellDepthToDay")]
|
||||||
|
[ProducesResponseType(typeof(List<WellDepthToDayDto>), (int)System.Net.HttpStatusCode.OK)]
|
||||||
|
public IActionResult GetWellDepthToDay(int wellId)
|
||||||
|
{
|
||||||
|
int? idCustomer = User.GetCustomerId();
|
||||||
|
|
||||||
|
if (idCustomer is null)
|
||||||
|
return BadRequest();
|
||||||
|
|
||||||
|
if (!wellService.CheckWellOwnership((int)idCustomer, wellId))
|
||||||
|
return Forbid();
|
||||||
|
|
||||||
|
var wellDepthToDayData = analyticsService.GetWellDepthToDayData(wellId);
|
||||||
|
|
||||||
|
return Ok(wellDepthToDayData);
|
||||||
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Возвращает данные по глубине скважины за период
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="wellId">id скважины</param>
|
||||||
|
/// <returns>Коллекцию данных по глубине скважины за период</returns>
|
||||||
|
[HttpGet]
|
||||||
|
[Route("{wellId}/wellDepthToInterval")]
|
||||||
|
[ProducesResponseType(typeof(List<WellDepthToIntervalDto>), (int)System.Net.HttpStatusCode.OK)]
|
||||||
|
public IActionResult GetWellDepthToInterval(int wellId)
|
||||||
|
{
|
||||||
|
int? idCustomer = User.GetCustomerId();
|
||||||
|
|
||||||
|
if (idCustomer is null)
|
||||||
|
return BadRequest();
|
||||||
|
|
||||||
|
if (!wellService.CheckWellOwnership((int)idCustomer, wellId))
|
||||||
|
return Forbid();
|
||||||
|
|
||||||
|
var wellDepthToIntervalData = analyticsService.GetWellDepthToIntervalData(wellId);
|
||||||
|
|
||||||
|
return Ok(wellDepthToIntervalData);
|
||||||
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Возвращает данные по операциям на скважине за период
|
/// Возвращает данные по операциям на скважине за период
|
||||||
/// </summary>
|
/// </summary>
|
||||||
@ -19,10 +75,18 @@ namespace AsbCloudWebApi.Controllers
|
|||||||
/// <param name="end">дата окончания интервала</param>
|
/// <param name="end">дата окончания интервала</param>
|
||||||
/// <returns>Коллекцию операций на скважине</returns>
|
/// <returns>Коллекцию операций на скважине</returns>
|
||||||
[HttpGet]
|
[HttpGet]
|
||||||
[Route("{wellId}/get")]
|
[Route("{wellId}/operationsToTime")]
|
||||||
[ProducesResponseType(typeof(List<OperationPercentageDto>), (int)System.Net.HttpStatusCode.OK)]
|
[ProducesResponseType(typeof(List<OperationPercentageDto>), (int)System.Net.HttpStatusCode.OK)]
|
||||||
public IActionResult GetAnalytics(int wellId, DateTime begin = default, DateTime end = default)
|
public IActionResult GetOperationsToTime(int wellId, DateTime begin = default, DateTime end = default)
|
||||||
{
|
{
|
||||||
|
int? idCustomer = User.GetCustomerId();
|
||||||
|
|
||||||
|
if (idCustomer is null)
|
||||||
|
return BadRequest();
|
||||||
|
|
||||||
|
if (!wellService.CheckWellOwnership((int)idCustomer, wellId))
|
||||||
|
return Forbid();
|
||||||
|
|
||||||
var analytics = new List<OperationPercentageDto>
|
var analytics = new List<OperationPercentageDto>
|
||||||
{
|
{
|
||||||
new OperationPercentageDto { ProcessName = "Роторное бурение", Percentage = 19.7 },
|
new OperationPercentageDto { ProcessName = "Роторное бурение", Percentage = 19.7 },
|
||||||
|
Loading…
Reference in New Issue
Block a user