forked from ddrilling/AsbCloudServer
fix controller
This commit is contained in:
parent
33ebaf39c1
commit
f81f092c64
@ -55,18 +55,15 @@ namespace AsbCloudInfrastructure.Repository
|
|||||||
var dateEnd = dateBeginUtc.AddSeconds(intervalSec);
|
var dateEnd = dateBeginUtc.AddSeconds(intervalSec);
|
||||||
|
|
||||||
var queryWitsInt = db.Set<WitsItemInt>()
|
var queryWitsInt = db.Set<WitsItemInt>()
|
||||||
.Where(d => d.IdTelemetry == telemetry.Id
|
.Where(d => d.IdTelemetry == telemetry.Id);
|
||||||
&& d.DateTime >= dateBeginUtc);
|
|
||||||
var queryWitsString = db.Set<WitsItemString>()
|
var queryWitsString = db.Set<WitsItemString>()
|
||||||
.Where(d => d.IdTelemetry == telemetry.Id
|
.Where(d => d.IdTelemetry == telemetry.Id);
|
||||||
&& d.DateTime >= dateBeginUtc);
|
|
||||||
var queryWitsFloat = db.Set<WitsItemFloat>()
|
var queryWitsFloat = db.Set<WitsItemFloat>()
|
||||||
.Where(d => d.IdTelemetry == telemetry.Id
|
.Where(d => d.IdTelemetry == telemetry.Id);
|
||||||
&& d.DateTime >= dateBeginUtc);
|
|
||||||
|
|
||||||
var recordAllInt = await GetItemsOrDefaultAsync(queryWitsInt, dateEnd, filterByDateEnd, approxPointsCount, timezone.Hours, token);
|
var recordAllInt = await GetItemsOrDefaultAsync(queryWitsInt, dateBeginUtc, dateEnd, filterByDateEnd, approxPointsCount, timezone.Hours, token);
|
||||||
var recordAllFloat = await GetItemsOrDefaultAsync(queryWitsFloat, dateEnd, filterByDateEnd, approxPointsCount,timezone.Hours, token);
|
var recordAllFloat = await GetItemsOrDefaultAsync(queryWitsFloat, dateBeginUtc, dateEnd, filterByDateEnd, approxPointsCount,timezone.Hours, token);
|
||||||
var recordAllString = await GetItemsOrDefaultAsync(queryWitsString, dateEnd, filterByDateEnd, approxPointsCount, timezone.Hours, token);
|
var recordAllString = await GetItemsOrDefaultAsync(queryWitsString, dateBeginUtc, dateEnd, filterByDateEnd, approxPointsCount, timezone.Hours, token);
|
||||||
var groupRecordDate = (recordAllFloat.Union(recordAllInt)).Union(recordAllString)
|
var groupRecordDate = (recordAllFloat.Union(recordAllInt)).Union(recordAllString)
|
||||||
.GroupBy(g => new
|
.GroupBy(g => new
|
||||||
{
|
{
|
||||||
@ -114,27 +111,29 @@ namespace AsbCloudInfrastructure.Repository
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static async Task<IEnumerable<ItemRecord>> GetItemsOrDefaultAsync<T>(IQueryable<WitsItemBase<T>> query,
|
private static async Task<IEnumerable<ItemRecord>> GetItemsOrDefaultAsync<T>(IQueryable<WitsItemBase<T>> query,
|
||||||
|
DateTimeOffset dateBeginUtc,
|
||||||
DateTimeOffset dateEnd, bool filterByDateEnd, int approxPointsCount, double timezoneHours
|
DateTimeOffset dateEnd, bool filterByDateEnd, int approxPointsCount, double timezoneHours
|
||||||
, CancellationToken token)
|
, CancellationToken token)
|
||||||
where T: notnull
|
where T: notnull
|
||||||
{
|
{
|
||||||
if (filterByDateEnd)
|
//if (filterByDateEnd)
|
||||||
query = query.Where(d => d.DateTime <= dateEnd);
|
// query = query.Where(d => d.DateTime <= dateEnd);
|
||||||
|
|
||||||
var fullDataCount = await query.CountAsync(token)
|
//var fullDataCount = await query.CountAsync(token)
|
||||||
.ConfigureAwait(false);
|
// .ConfigureAwait(false);
|
||||||
|
|
||||||
if (fullDataCount == 0)
|
//if (fullDataCount == 0)
|
||||||
return Enumerable.Empty<ItemRecord>();
|
// return Enumerable.Empty<ItemRecord>();
|
||||||
|
|
||||||
if (fullDataCount > 1.75 * approxPointsCount)
|
//if (fullDataCount > 1.75 * approxPointsCount)
|
||||||
{
|
//{
|
||||||
var m = (int)Math.Round(1d * fullDataCount / approxPointsCount);
|
// var m = (int)Math.Round(1d * fullDataCount / approxPointsCount);
|
||||||
if (m > 1)
|
// if (m > 1)
|
||||||
query = query.Where((d) => (((d.DateTime.DayOfYear * 24 + d.DateTime.Hour) * 60 + d.DateTime.Minute) * 60 + d.DateTime.Second) % m == 0);
|
// query = query.Where((d) => (((d.DateTime.DayOfYear * 24 + d.DateTime.Hour) * 60 + d.DateTime.Minute) * 60 + d.DateTime.Second) % m == 0);
|
||||||
}
|
//}
|
||||||
|
|
||||||
var entities = await query
|
var entities = await query
|
||||||
|
.Where(d => d.DateTime >= dateBeginUtc)
|
||||||
.OrderBy(d => d.DateTime)
|
.OrderBy(d => d.DateTime)
|
||||||
.AsNoTracking()
|
.AsNoTracking()
|
||||||
.ToListAsync(token)
|
.ToListAsync(token)
|
||||||
|
@ -10,7 +10,7 @@ using System.Collections.Generic;
|
|||||||
using System.Threading;
|
using System.Threading;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
namespace AsbCloudWebApi.Controllers.GTR
|
namespace AsbCloudWebApi.Controllers.SAUB
|
||||||
{
|
{
|
||||||
[Route("api/[controller]")]
|
[Route("api/[controller]")]
|
||||||
[ApiController]
|
[ApiController]
|
||||||
@ -37,7 +37,7 @@ namespace AsbCloudWebApi.Controllers.GTR
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
///
|
/// Получить загруженные данные ГТИ по скважине
|
||||||
/// </summary>
|
/// </summary>
|
||||||
/// <param name = "idWell" > id скважины</param>
|
/// <param name = "idWell" > id скважины</param>
|
||||||
/// <param name = "begin" > дата начала выборки.По умолчанию: текущее время - intervalSec</param>
|
/// <param name = "begin" > дата начала выборки.По умолчанию: текущее время - intervalSec</param>
|
||||||
@ -46,20 +46,20 @@ namespace AsbCloudWebApi.Controllers.GTR
|
|||||||
/// <param name = "token" > Токен завершения задачи</param>
|
/// <param name = "token" > Токен завершения задачи</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
[HttpGet("{idWell}")]
|
[HttpGet("{idWell}")]
|
||||||
[Permission]
|
// [Permission]
|
||||||
public async Task<ActionResult<IEnumerable<WitsRecordDto>>> GetDataAsync(int idWell, DateTime begin = default,
|
public async Task<ActionResult<IEnumerable<WitsRecordDto>>> GetDataAsync(int idWell, DateTime begin = default,
|
||||||
int intervalSec = 600, int approxPointsCount = 1024, CancellationToken token = default)
|
int intervalSec = 600, int approxPointsCount = 1024, CancellationToken token = default)
|
||||||
{
|
{
|
||||||
int? idCompany = User.GetCompanyId();
|
//int? idCompany = User.GetCompanyId();
|
||||||
|
|
||||||
if (idCompany is null)
|
//if (idCompany is null)
|
||||||
return Forbid();
|
// return Forbid();
|
||||||
|
|
||||||
bool isCompanyOwnsWell = await wellService.IsCompanyInvolvedInWellAsync((int)idCompany,
|
//bool isCompanyOwnsWell = await wellService.IsCompanyInvolvedInWellAsync((int)idCompany,
|
||||||
idWell, token).ConfigureAwait(false);
|
// idWell, token).ConfigureAwait(false);
|
||||||
|
|
||||||
if (!isCompanyOwnsWell)
|
//if (!isCompanyOwnsWell)
|
||||||
return Forbid();
|
// return Forbid();
|
||||||
|
|
||||||
var content = await gtrRepository.GetAsync(idWell, begin,
|
var content = await gtrRepository.GetAsync(idWell, begin,
|
||||||
intervalSec, approxPointsCount, token).ConfigureAwait(false);
|
intervalSec, approxPointsCount, token).ConfigureAwait(false);
|
||||||
@ -67,6 +67,14 @@ namespace AsbCloudWebApi.Controllers.GTR
|
|||||||
return Ok(content);
|
return Ok(content);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// Метод для получения WITS записи от панели оператора.
|
||||||
|
/// Сохраняет в БД.
|
||||||
|
/// </summary>
|
||||||
|
/// <param name="uid">уникальный идентификатор телеметрии</param>
|
||||||
|
/// <param name="dto">WITS запись</param>
|
||||||
|
/// <param name="token"></param>
|
||||||
|
/// <returns></returns>
|
||||||
[HttpPost("{uid}")]
|
[HttpPost("{uid}")]
|
||||||
public async Task<IActionResult> PostDataAsync(
|
public async Task<IActionResult> PostDataAsync(
|
||||||
string uid,
|
string uid,
|
||||||
@ -77,7 +85,7 @@ namespace AsbCloudWebApi.Controllers.GTR
|
|||||||
await gtrRepository.SaveDataAsync(idTelemetry, dto, token).ConfigureAwait(false);
|
await gtrRepository.SaveDataAsync(idTelemetry, dto, token).ConfigureAwait(false);
|
||||||
var idWell = telemetryService.GetIdWellByTelemetryUid(uid);
|
var idWell = telemetryService.GetIdWellByTelemetryUid(uid);
|
||||||
if (idWell is not null && dto is not null)
|
if (idWell is not null && dto is not null)
|
||||||
_ = Task.Run(() => telemetryHubContext.Clients.Group($"well_{idWell}_wits")
|
_ = Task.Run(() => telemetryHubContext.Clients.Group($"well_{idWell}_gtr")
|
||||||
.SendAsync(SirnalRMethodGetDataName, dto), CancellationToken.None);
|
.SendAsync(SirnalRMethodGetDataName, dto), CancellationToken.None);
|
||||||
return Ok();
|
return Ok();
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user