Merge pull request '#7963103 Отображение общей наработки тальканата по всем объектам' (#17) from TelemetryWireline into dev

Reviewed-on: http://test.digitaldrilling.ru:8080/DDrilling/AsbCloudServer/pulls/17
This commit is contained in:
Никита Фролов 2023-01-11 16:14:07 +05:00
commit 5c9e656b01
17 changed files with 20900 additions and 111 deletions

View File

@ -2,6 +2,7 @@
namespace AsbCloudApp.Data.SAUB namespace AsbCloudApp.Data.SAUB
{ {
#nullable enable
/// <summary> /// <summary>
/// DTO телеметрии наработки талевого каната /// DTO телеметрии наработки талевого каната
/// </summary> /// </summary>
@ -32,5 +33,10 @@ namespace AsbCloudApp.Data.SAUB
/// </summary> /// </summary>
public float ReplaceWarnSp { get; set; } public float ReplaceWarnSp { get; set; }
/// <summary>
/// Информация по скважине
/// </summary>
public WellInfoDto WellInfo { get; set; } = null!;
} }
#nullable disable
} }

View File

@ -0,0 +1,42 @@
using AsbCloudApp.Data;
using AsbCloudApp.Data.SAUB;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;
namespace AsbCloudApp.Repositories
{
#nullable enable
/// <summary>
/// Наработка талевого каната
/// </summary>
public interface ITelemetryWirelineRunOutRepository
{
/// <summary>
/// Принимает данные от панели
/// </summary>
/// <param name="uid"></param>
/// <param name="dto"></param>
/// <param name="token"></param>
/// <returns></returns>
Task<int> AddOrUpdateAsync(string uid, TelemetryWirelineRunOutDto dto, CancellationToken token);
/// <summary>
/// Выдает данные по скважине
/// </summary>
/// <param name="idWell"></param>
/// <param name="token"></param>
/// <param name="wellInfo"></param>
/// <returns></returns>
Task<TelemetryWirelineRunOutDto?> GetOrDefaultAsync(int idWell, CancellationToken token);
/// <summary>
/// Возвращает данные по всем скважинам
/// </summary>
/// <param name="idCompany"></param>
/// <param name="token"></param>
/// <returns></returns>
Task<IEnumerable<TelemetryWirelineRunOutDto>> GetAllAsync(int idCompany, CancellationToken token);
}
#nullable disable
}

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,40 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
#nullable disable
namespace AsbCloudDb.Migrations
{
public partial class AddTable_t_telemetry_wireline_run_out : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.CreateTable(
name: "t_telemetry_wireline_run_out",
columns: table => new
{
id = table.Column<int>(type: "integer", nullable: false)
.Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn),
id_well = table.Column<int>(type: "integer", nullable: false),
id_telemetry = table.Column<int>(type: "integer", nullable: false),
date_time = table.Column<DateTimeOffset>(type: "timestamp with time zone", nullable: false),
hauling = table.Column<float>(type: "real", nullable: false),
hauling_warn_sp = table.Column<float>(type: "real", nullable: false),
replace = table.Column<float>(type: "real", nullable: false),
replace_warn_sp = table.Column<float>(type: "real", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_t_telemetry_wireline_run_out", x => x.id);
},
comment: "Наработка талевого каната");
}
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropTable(
name: "t_telemetry_wireline_run_out");
}
}
}

File diff suppressed because it is too large Load Diff

View File

@ -0,0 +1,26 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace AsbCloudDb.Migrations
{
public partial class UpdateTable_t_telemetry_wireline_run_out : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropColumn(
name: "id_well",
table: "t_telemetry_wireline_run_out");
}
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<int>(
name: "id_well",
table: "t_telemetry_wireline_run_out",
type: "integer",
nullable: false,
defaultValue: 0);
}
}
}

View File

@ -0,0 +1,157 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
#nullable disable
namespace AsbCloudDb.Migrations
{
public partial class UpdateTable_t_telemetry_wireline_run_out_comment : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropPrimaryKey(
name: "PK_t_telemetry_wireline_run_out",
table: "t_telemetry_wireline_run_out");
migrationBuilder.DropColumn(
name: "id",
table: "t_telemetry_wireline_run_out");
migrationBuilder.AlterColumn<float>(
name: "replace_warn_sp",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
comment: "Наработка талевого каната до сигнализации о необходимости замены, т*км",
oldClrType: typeof(float),
oldType: "real");
migrationBuilder.AlterColumn<float>(
name: "replace",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
comment: "Наработка талевого каната с момента замены каната, т*км",
oldClrType: typeof(float),
oldType: "real");
migrationBuilder.AlterColumn<int>(
name: "id_telemetry",
table: "t_telemetry_wireline_run_out",
type: "integer",
nullable: false,
comment: "Идентификатор телеметрии",
oldClrType: typeof(int),
oldType: "integer")
.Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
migrationBuilder.AlterColumn<float>(
name: "hauling_warn_sp",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
comment: "Наработка талевого каната до сигнализации о необходимости перетяжки, т*км",
oldClrType: typeof(float),
oldType: "real");
migrationBuilder.AlterColumn<float>(
name: "hauling",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
comment: "Наработка талевого каната с момента перетяжки каната, т*км",
oldClrType: typeof(float),
oldType: "real");
migrationBuilder.AlterColumn<DateTimeOffset>(
name: "date_time",
table: "t_telemetry_wireline_run_out",
type: "timestamp with time zone",
nullable: false,
comment: "Отметка времени",
oldClrType: typeof(DateTimeOffset),
oldType: "timestamp with time zone");
migrationBuilder.AddPrimaryKey(
name: "PK_t_telemetry_wireline_run_out",
table: "t_telemetry_wireline_run_out",
column: "id_telemetry");
}
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropPrimaryKey(
name: "PK_t_telemetry_wireline_run_out",
table: "t_telemetry_wireline_run_out");
migrationBuilder.AlterColumn<float>(
name: "replace_warn_sp",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
oldClrType: typeof(float),
oldType: "real",
oldComment: "Наработка талевого каната до сигнализации о необходимости замены, т*км");
migrationBuilder.AlterColumn<float>(
name: "replace",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
oldClrType: typeof(float),
oldType: "real",
oldComment: "Наработка талевого каната с момента замены каната, т*км");
migrationBuilder.AlterColumn<float>(
name: "hauling_warn_sp",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
oldClrType: typeof(float),
oldType: "real",
oldComment: "Наработка талевого каната до сигнализации о необходимости перетяжки, т*км");
migrationBuilder.AlterColumn<float>(
name: "hauling",
table: "t_telemetry_wireline_run_out",
type: "real",
nullable: false,
oldClrType: typeof(float),
oldType: "real",
oldComment: "Наработка талевого каната с момента перетяжки каната, т*км");
migrationBuilder.AlterColumn<DateTimeOffset>(
name: "date_time",
table: "t_telemetry_wireline_run_out",
type: "timestamp with time zone",
nullable: false,
oldClrType: typeof(DateTimeOffset),
oldType: "timestamp with time zone",
oldComment: "Отметка времени");
migrationBuilder.AlterColumn<int>(
name: "id_telemetry",
table: "t_telemetry_wireline_run_out",
type: "integer",
nullable: false,
oldClrType: typeof(int),
oldType: "integer",
oldComment: "Идентификатор телеметрии")
.OldAnnotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
migrationBuilder.AddColumn<int>(
name: "id",
table: "t_telemetry_wireline_run_out",
type: "integer",
nullable: false,
defaultValue: 0)
.Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn);
migrationBuilder.AddPrimaryKey(
name: "PK_t_telemetry_wireline_run_out",
table: "t_telemetry_wireline_run_out",
column: "id");
}
}
}

View File

@ -3550,6 +3550,48 @@ namespace AsbCloudDb.Migrations
b.HasComment("Пользователи панели САУБ. Для сообщений."); b.HasComment("Пользователи панели САУБ. Для сообщений.");
}); });
modelBuilder.Entity("AsbCloudDb.Model.TelemetryWirelineRunOut", b =>
{
b.Property<int>("IdTelemetry")
.ValueGeneratedOnAdd()
.HasColumnType("integer")
.HasColumnName("id_telemetry")
.HasComment("Идентификатор телеметрии");
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("IdTelemetry"));
b.Property<DateTime>("DateTime")
.HasColumnType("timestamp with time zone")
.HasColumnName("date_time")
.HasComment("Отметка времени");
b.Property<float>("Hauling")
.HasColumnType("real")
.HasColumnName("hauling")
.HasComment("Наработка талевого каната с момента перетяжки каната, т*км");
b.Property<float>("HaulingWarnSp")
.HasColumnType("real")
.HasColumnName("hauling_warn_sp")
.HasComment("Наработка талевого каната до сигнализации о необходимости перетяжки, т*км");
b.Property<float>("Replace")
.HasColumnType("real")
.HasColumnName("replace")
.HasComment("Наработка талевого каната с момента замены каната, т*км");
b.Property<float>("ReplaceWarnSp")
.HasColumnType("real")
.HasColumnName("replace_warn_sp")
.HasComment("Наработка талевого каната до сигнализации о необходимости замены, т*км");
b.HasKey("IdTelemetry");
b.ToTable("t_telemetry_wireline_run_out");
b.HasComment("Наработка талевого каната");
});
modelBuilder.Entity("AsbCloudDb.Model.User", b => modelBuilder.Entity("AsbCloudDb.Model.User", b =>
{ {
b.Property<int>("Id") b.Property<int>("Id")

View File

@ -52,6 +52,8 @@ namespace AsbCloudDb.Model
public virtual DbSet<WellFinalDocument> WellFinalDocuments => Set<WellFinalDocument>(); public virtual DbSet<WellFinalDocument> WellFinalDocuments => Set<WellFinalDocument>();
public virtual DbSet<LimitingParameter> LimitingParameter => Set<LimitingParameter>(); public virtual DbSet<LimitingParameter> LimitingParameter => Set<LimitingParameter>();
public virtual DbSet<TelemetryWirelineRunOut> TelemetryWirelineRunOut => Set<TelemetryWirelineRunOut>();
// WITS // WITS
public DbSet<WITS.Record1> Record1 => Set<WITS.Record1>(); public DbSet<WITS.Record1> Record1 => Set<WITS.Record1>();
public DbSet<WITS.Record7> Record7 => Set<WITS.Record7>(); public DbSet<WITS.Record7> Record7 => Set<WITS.Record7>();

View File

@ -51,6 +51,7 @@ namespace AsbCloudDb.Model
DbSet<OperationValue> OperationValues { get; } DbSet<OperationValue> OperationValues { get; }
DbSet<WellFinalDocument> WellFinalDocuments { get; } DbSet<WellFinalDocument> WellFinalDocuments { get; }
DbSet<LimitingParameter> LimitingParameter { get; } DbSet<LimitingParameter> LimitingParameter { get; }
DbSet<TelemetryWirelineRunOut> TelemetryWirelineRunOut { get; }
DbSet<Record1> Record1 { get; } DbSet<Record1> Record1 { get; }
DbSet<Record7> Record7 { get; } DbSet<Record7> Record7 { get; }

View File

@ -0,0 +1,30 @@
using Microsoft.EntityFrameworkCore;
using System;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;
namespace AsbCloudDb.Model
{
[Table("t_telemetry_wireline_run_out"), Comment("Наработка талевого каната")]
public class TelemetryWirelineRunOut
{
[Key]
[Column("id_telemetry"), Comment("Идентификатор телеметрии")]
public int IdTelemetry { get; set; }
[Column("date_time"), Comment("Отметка времени")]
public DateTimeOffset DateTime { get; set; }
[Column("hauling"), Comment("Наработка талевого каната с момента перетяжки каната, т*км")]
public float Hauling { get; set; }
[Column("hauling_warn_sp"), Comment("Наработка талевого каната до сигнализации о необходимости перетяжки, т*км")]
public float HaulingWarnSp { get; set; }
[Column("replace"), Comment("Наработка талевого каната с момента замены каната, т*км")]
public float Replace { get; set; }
[Column("replace_warn_sp"), Comment("Наработка талевого каната до сигнализации о необходимости замены, т*км")]
public float ReplaceWarnSp { get; set; }
}
}

View File

@ -4,6 +4,12 @@ namespace AsbCloudInfrastructure
{ {
public static class DateTimeExtentions public static class DateTimeExtentions
{ {
/// <summary>
/// Приветсти к UTC из времени куста
/// </summary>
/// <param name="date"></param>
/// <param name="remoteTimezoneOffsetHours"></param>
/// <returns></returns>
public static DateTimeOffset ToUtcDateTimeOffset(this DateTime date, double remoteTimezoneOffsetHours) public static DateTimeOffset ToUtcDateTimeOffset(this DateTime date, double remoteTimezoneOffsetHours)
{ {
if (date == default) if (date == default)
@ -18,6 +24,12 @@ namespace AsbCloudInfrastructure
return new DateTimeOffset(dateUtc); return new DateTimeOffset(dateUtc);
} }
/// <summary>
/// Привести ко времени куста из utc
/// </summary>
/// <param name="date"></param>
/// <param name="remoteTimezoneOffsetHours"></param>
/// <returns></returns>
public static DateTime ToRemoteDateTime(this DateTimeOffset date, double remoteTimezoneOffsetHours) public static DateTime ToRemoteDateTime(this DateTimeOffset date, double remoteTimezoneOffsetHours)
{ {
if (date == default) if (date == default)

View File

@ -169,6 +169,8 @@ namespace AsbCloudInfrastructure
services.AddTransient<IUserRoleRepository, UserRoleRepository>(); services.AddTransient<IUserRoleRepository, UserRoleRepository>();
services.AddTransient<IUserRepository, UserRepository>(); services.AddTransient<IUserRepository, UserRepository>();
services.AddTransient<ILimitingParameterRepository, LimitingParameterRepository>(); services.AddTransient<ILimitingParameterRepository, LimitingParameterRepository>();
services.AddTransient<ITelemetryWirelineRunOutRepository, TelemetryWirelineRunOutRepository>();
// Subsystem service // Subsystem service
services.AddTransient<ICrudRepository<SubsystemDto>, CrudCacheRepositoryBase<SubsystemDto, Subsystem>>(); services.AddTransient<ICrudRepository<SubsystemDto>, CrudCacheRepositoryBase<SubsystemDto, Subsystem>>();
services.AddTransient<ISubsystemService, SubsystemService>(); services.AddTransient<ISubsystemService, SubsystemService>();

View File

@ -0,0 +1,115 @@
using AsbCloudApp.Data;
using AsbCloudApp.Data.SAUB;
using AsbCloudApp.Repositories;
using AsbCloudApp.Services;
using AsbCloudDb;
using AsbCloudDb.Model;
using AsbCloudInfrastructure.Services.SAUB;
using Mapster;
using Microsoft.EntityFrameworkCore;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
namespace AsbCloudInfrastructure.Repository
{
#nullable enable
public class TelemetryWirelineRunOutRepository : ITelemetryWirelineRunOutRepository
{
private readonly IAsbCloudDbContext context;
private readonly ITelemetryService telemetryService;
private readonly IWellService wellService;
public TelemetryWirelineRunOutRepository(IAsbCloudDbContext context,
ITelemetryService telemetryService,
IWellService wellService)
{
this.context = context;
this.telemetryService = telemetryService;
this.wellService = wellService;
}
/// <inheritdoc/>
public async Task<int> AddOrUpdateAsync(string uid, TelemetryWirelineRunOutDto dto, CancellationToken token)
{
var idTelemetry = telemetryService.GetOrCreateTelemetryIdByUid(uid);
var timezoneOffset = telemetryService.GetTimezone(idTelemetry).Hours;
var entity = Convert(idTelemetry, dto, timezoneOffset);
var updatingItem = context.TelemetryWirelineRunOut
.Where(x => x.IdTelemetry == idTelemetry)
.FirstOrDefault();
if (updatingItem is null)
context.TelemetryWirelineRunOut.Add(entity);
else
context.TelemetryWirelineRunOut.Update(entity);
return await context.SaveChangesAsync(token);
}
/// <inheritdoc/>
public async Task<TelemetryWirelineRunOutDto?> GetOrDefaultAsync(int idWell, CancellationToken token)
{
var well = await wellService.GetOrDefaultAsync(idWell, token).ConfigureAwait(false);
if (well is null)
return null;
return await GetOrDefaultAsync(well, token);
}
private async Task<TelemetryWirelineRunOutDto?> GetOrDefaultAsync(WellDto well, CancellationToken token)
{
var idTelemetry = telemetryService.GetOrDefaultIdTelemetryByIdWell(well.Id);
if (idTelemetry is null)
return null;
var entity = await context.TelemetryWirelineRunOut
.Where(x => x.IdTelemetry == idTelemetry)
.AsNoTracking()
.FirstOrDefaultAsync(token)
.ConfigureAwait(false);
if (entity is null)
return null;
var timezoneHours = well.Timezone.Hours;
return Convert(entity, well, timezoneHours);
}
/// <inheritdoc/>
public async Task<IEnumerable<TelemetryWirelineRunOutDto>> GetAllAsync(int idCompany, CancellationToken token)
{
var wells = await wellService.GetWellsByCompanyAsync(idCompany, token)
.ConfigureAwait(false);
var result = new List<TelemetryWirelineRunOutDto>(wells.Count());
foreach (var well in wells)
{
var dto = await GetOrDefaultAsync(well, token);
if (dto is not null)
result.Add(dto);
}
return result;
}
private static TelemetryWirelineRunOut Convert(int idTelemetry, TelemetryWirelineRunOutDto dto, double timezoneOffset)
{
var entity = dto.Adapt<TelemetryWirelineRunOut>();
entity.IdTelemetry = idTelemetry;
entity.DateTime = dto.DateTime.ToUtcDateTimeOffset(timezoneOffset);
return entity;
}
private static TelemetryWirelineRunOutDto Convert(TelemetryWirelineRunOut entity, WellDto well, double timezoneOffset)
{
var dto = entity.Adapt<TelemetryWirelineRunOutDto>();
dto.DateTime = entity.DateTime.ToRemoteDateTime(timezoneOffset);
dto.WellInfo = well;
return dto;
}
}
#nullable disable
}

View File

@ -1,107 +0,0 @@
using AsbCloudApp.Services;
using AsbCloudWebApi.SignalR;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.SignalR;
using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;
namespace AsbCloudWebApi.Controllers.SAUB
{
[Route("api/[controller]")]
[ApiController]
public abstract class TelemetryInstantDataController<TDto> : ControllerBase
{
private readonly ITelemetryService telemetryService;
private readonly IWellService wellService;
private readonly IHubContext<TelemetryHub> telemetryHubContext;
private readonly InstantDataRepository repository;
protected abstract string SirnalRMethodGetDataName { get; }
public TelemetryInstantDataController(
ITelemetryService telemetryService,
IWellService wellService,
IHubContext<TelemetryHub> telemetryHubContext,
InstantDataRepository repository)
{
this.telemetryService = telemetryService;
this.wellService = wellService;
this.telemetryHubContext = telemetryHubContext;
this.repository = repository;
}
/// <summary>
/// Принимает данные от панели
/// </summary>
/// <param name="uid"></param>
/// <param name="dto"></param>
/// <returns></returns>
[HttpPost]
[Route("{uid}")]
[AllowAnonymous]
public virtual IActionResult PostData(
string uid,
[FromBody] TDto dto)
{
if (dto is null)
return BadRequest("Dto shouldn't be null");
var idTelemetry = telemetryService.GetOrCreateTelemetryIdByUid(uid);
var typedStore = repository.GetOrAdd(idTelemetry, (id) => new System.Collections.Concurrent.ConcurrentDictionary<Type, object>());
var typeDto = typeof(TDto);
typedStore.AddOrUpdate(typeDto, dto, (_, _) => dto);
var idWell = telemetryService.GetIdWellByTelemetryUid(uid);
if (idWell is not null)
_ = Task.Run(async () =>
{
var clients = telemetryHubContext.Clients.Group($"well_{idWell}");
await clients.SendAsync(SirnalRMethodGetDataName, dto);
}, CancellationToken.None);
return Ok();
}
/// <summary>
/// Выдает данные по скважине
/// </summary>
/// <param name="idWell"></param>
/// <param name="token"></param>
/// <returns></returns>
[HttpGet("{idWell}")]
//[Permission]
public virtual async Task<ActionResult<TDto>> GetDataAsync(
int idWell,
CancellationToken token = default)
{
int? idCompany = User.GetCompanyId();
if (idCompany is null)
return Forbid();
bool isCompanyOwnsWell = await wellService.IsCompanyInvolvedInWellAsync((int)idCompany,
idWell, token).ConfigureAwait(false);
if (!isCompanyOwnsWell)
return Forbid();
int? idTelemetry = telemetryService.GetOrDefaultIdTelemetryByIdWell(idWell);
if (idTelemetry is null)
return NoContent();
var typedStore = repository.GetValueOrDefault((int)idTelemetry, null);
if (typedStore is null)
return NoContent();
var typeDto = typeof(TDto);
var dto = typedStore.GetValueOrDefault(typeDto);
return Ok(dto);
}
}
}

View File

@ -4,26 +4,107 @@ using AsbCloudWebApi.SignalR;
using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.SignalR; using Microsoft.AspNetCore.SignalR;
using System.Collections.Generic;
using System.Threading.Tasks;
using System.Threading;
using AsbCloudApp.Repositories;
namespace AsbCloudWebApi.Controllers.SAUB namespace AsbCloudWebApi.Controllers.SAUB
{ {
#nullable enable
/// <summary> /// <summary>
/// Наработка талевого каната /// Наработка талевого каната
/// </summary> /// </summary>
[ApiController] [ApiController]
[Authorize] [Authorize]
[Route("api/[controller]")] [Route("api/[controller]")]
public class TelemetryWirelineRunOutController : TelemetryInstantDataController<TelemetryWirelineRunOutDto> public class TelemetryWirelineRunOutController : ControllerBase
{ {
protected override string SirnalRMethodGetDataName => "ReceiveWirelineRunOut"; private readonly ITelemetryService telemetryService;
private readonly IWellService wellService;
private readonly IHubContext<TelemetryHub> telemetryHubContext;
private readonly ITelemetryWirelineRunOutRepository repository;
private string SirnalRMethodGetDataName => "ReceiveWirelineRunOut";
public TelemetryWirelineRunOutController( public TelemetryWirelineRunOutController(
ITelemetryService telemetryService, ITelemetryService telemetryService,
IWellService wellService, IWellService wellService,
IHubContext<TelemetryHub> telemetryHubContext, IHubContext<TelemetryHub> telemetryHubContext,
InstantDataRepository repository) ITelemetryWirelineRunOutRepository repository)
: base(telemetryService, wellService, telemetryHubContext, repository)
{ {
this.telemetryService = telemetryService;
this.wellService = wellService;
this.telemetryHubContext = telemetryHubContext;
this.repository = repository;
} }
/// <summary>
/// Принимает данные от панели
/// </summary>
/// <param name="uid"></param>
/// <param name="dto"></param>
/// <param name="token"></param>
/// <returns></returns>
[HttpPost]
[Route("{uid}")]
[AllowAnonymous]
public IActionResult PostData(string uid, [FromBody] TelemetryWirelineRunOutDto dto, CancellationToken token)
{
if (dto is null)
return BadRequest("Dto shouldn't be null");
var data = repository.AddOrUpdateAsync(uid, dto, token);
var idWell = telemetryService.GetIdWellByTelemetryUid(uid);
if (idWell is not null)
_ = Task.Run(async () =>
{
var clients = telemetryHubContext.Clients.Group($"well_{idWell}");
await clients.SendAsync(SirnalRMethodGetDataName, dto);
}, CancellationToken.None);
return Ok();
}
/// <summary>
/// Выдает данные по скважине
/// </summary>
/// <param name="idWell"></param>
/// <param name="token"></param>
/// <returns></returns>
[HttpGet("{idWell}")]
[Permission]
public async Task<ActionResult<TelemetryWirelineRunOutDto>> GetDataAsync(int idWell, CancellationToken token)
{
int? idCompany = User.GetCompanyId();
if (idCompany is null)
return Forbid();
bool isCompanyOwnsWell = await wellService.IsCompanyInvolvedInWellAsync((int)idCompany,
idWell, token).ConfigureAwait(false);
if (!isCompanyOwnsWell)
return Forbid();
var dto = await repository.GetOrDefaultAsync(idWell, token);
if (dto is null)
return NoContent();
return Ok(dto);
}
[HttpGet]
public async Task<ActionResult<IEnumerable<TelemetryWirelineRunOutDto>>> GetAllAsync(CancellationToken token)
{
int? idCompany = User.GetCompanyId();
if (idCompany is null)
return Forbid();
var dtos = await repository.GetAllAsync((int)idCompany, token);
return Ok(dtos);
}
} }
#nullable disable
} }