forked from ddrilling/AsbCloudServer
Merge pull request 'fix/#13108961-typing-signalr-clients-methods' (#144) from fix/#13108961-typing-signalr-clients-methods into dev
Reviewed-on: http://test.digitaldrilling.ru:8080/DDrilling/AsbCloudServer/pulls/144
This commit is contained in:
commit
fb68ca76e7
@ -2,7 +2,7 @@
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<GenerateDocumentationFile>true</GenerateDocumentationFile>
|
||||
<GenerateDocumentationFile>true</GenerateDocumentationFile>
|
||||
<ServerGarbageCollection>true</ServerGarbageCollection>
|
||||
<NoWarn>$(NoWarn);1591</NoWarn>
|
||||
<UserSecretsId>80899ceb-210f-4f19-ac56-aa90a5d666d4</UserSecretsId>
|
||||
@ -14,6 +14,7 @@
|
||||
<PackageReference Include="Microsoft.AspNetCore.SpaServices.Extensions" Version="6.0.8" />
|
||||
<PackageReference Include="protobuf-net" Version="3.1.17" />
|
||||
<PackageReference Include="protobuf-net.AspNetCore" Version="3.1.17" />
|
||||
<PackageReference Include="SignalRSwaggerGen" Version="4.4.0" />
|
||||
<PackageReference Include="Swashbuckle.AspNetCore" Version="6.4.0" />
|
||||
<PackageReference Include="Swashbuckle.AspNetCore.Annotations" Version="6.4.0" />
|
||||
</ItemGroup>
|
||||
|
@ -5,6 +5,7 @@ using AsbCloudApp.Repositories;
|
||||
using AsbCloudApp.Requests;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
@ -28,16 +29,15 @@ public class DrillTestController : ControllerBase
|
||||
private readonly IDrillTestRepository drillTestRepository;
|
||||
private readonly IWellService wellService;
|
||||
private readonly ITelemetryService telemetryService;
|
||||
private readonly IHubContext<TelemetryHub> telemetryHubContext;
|
||||
private readonly IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext;
|
||||
|
||||
public string SignalRMethodGetDataName { get; protected set; } = "ReceiveDrilltestData";
|
||||
|
||||
public DrillTestController(
|
||||
IDrillTestReportService drillTestReportService,
|
||||
IDrillTestRepository drillTestRepository,
|
||||
IWellService wellService,
|
||||
ITelemetryService telemetryService,
|
||||
IHubContext<TelemetryHub> telemetryHubContext)
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext)
|
||||
{
|
||||
this.drillTestReportService = drillTestReportService;
|
||||
this.drillTestRepository = drillTestRepository;
|
||||
@ -71,7 +71,7 @@ public class DrillTestController : ControllerBase
|
||||
_ = Task.Run(async () =>
|
||||
{
|
||||
var clients = telemetryHubContext.Clients.Group($"well_{idWell}");
|
||||
await clients.SendAsync(SignalRMethodGetDataName, dto);
|
||||
await clients.ReceiveDrilltestData(dto, token);
|
||||
}, CancellationToken.None);
|
||||
|
||||
return Ok();
|
||||
|
@ -9,6 +9,7 @@ using AsbCloudApp.Repositories;
|
||||
using AsbCloudApp.Requests;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
@ -25,7 +26,7 @@ namespace AsbCloudWebApi.Controllers.ProcessMaps;
|
||||
public abstract class ProcessMapBaseController<T> : ControllerBase
|
||||
where T : ProcessMapPlanBaseDto
|
||||
{
|
||||
private readonly IHubContext<TelemetryHub> telemetryHubContext;
|
||||
private readonly IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext;
|
||||
private readonly ITelemetryService telemetryService;
|
||||
private readonly IWellService wellService;
|
||||
private readonly IUserRepository userRepository;
|
||||
@ -36,7 +37,7 @@ public abstract class ProcessMapBaseController<T> : ControllerBase
|
||||
IProcessMapPlanRepository<T> repository,
|
||||
IUserRepository userRepository,
|
||||
ICrudRepository<WellSectionTypeDto> wellSectionRepository,
|
||||
IHubContext<TelemetryHub> telemetryHubContext,
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext,
|
||||
ITelemetryService telemetryService)
|
||||
{
|
||||
this.wellService = wellService;
|
||||
@ -204,7 +205,7 @@ public abstract class ProcessMapBaseController<T> : ControllerBase
|
||||
|
||||
await telemetryHubContext.Clients
|
||||
.Group($"{SignalRMethod}_{idWell}")
|
||||
.SendAsync("UpdateProcessMap", dtos, cancellationToken);
|
||||
.UpdateProcessMap(dtos, cancellationToken);
|
||||
}
|
||||
|
||||
private async Task CheckIsExistsWellSectionTypeAsync(int idWellSectionType, CancellationToken cancellationToken)
|
||||
|
@ -10,6 +10,7 @@ using AsbCloudApp.Services;
|
||||
using AsbCloudApp.Services.ProcessMaps;
|
||||
using AsbCloudApp.Services.ProcessMaps.WellDrilling;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
@ -34,7 +35,7 @@ public class ProcessMapWellDrillingController : ProcessMapBaseController<Process
|
||||
IProcessMapPlanImportService processMapPlanImportService,
|
||||
IProcessMapReportWellDrillingService processMapReportWellDrillingService,
|
||||
ICrudRepository<WellSectionTypeDto> wellSectionRepository,
|
||||
IHubContext<TelemetryHub> telemetryHubContext,
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext,
|
||||
ITelemetryService telemetryService)
|
||||
: base(wellService, repository, userRepository, wellSectionRepository, telemetryHubContext, telemetryService)
|
||||
{
|
||||
|
@ -3,6 +3,7 @@ using AsbCloudApp.Data.ProcessMaps;
|
||||
using AsbCloudApp.Repositories;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
|
||||
namespace AsbCloudWebApi.Controllers.ProcessMaps;
|
||||
@ -16,7 +17,7 @@ public class ProcessMapWellReamController : ProcessMapBaseController<ProcessMapP
|
||||
IProcessMapPlanRepository<ProcessMapPlanWellReamDto> repository,
|
||||
IUserRepository userRepository,
|
||||
ICrudRepository<WellSectionTypeDto> wellSectionRepository,
|
||||
IHubContext<TelemetryHub> telemetryHubContext,
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext,
|
||||
ITelemetryService telemetryService)
|
||||
: base(wellService, repository, userRepository, wellSectionRepository, telemetryHubContext, telemetryService)
|
||||
{
|
||||
|
@ -8,6 +8,7 @@ using System.ComponentModel.DataAnnotations;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using AsbCloudApp.Requests;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
|
||||
namespace AsbCloudWebApi.Controllers
|
||||
{
|
||||
@ -21,10 +22,10 @@ namespace AsbCloudWebApi.Controllers
|
||||
private readonly IReportService reportService;
|
||||
private readonly FileService fileService;
|
||||
private readonly IWellService wellService;
|
||||
private readonly IHubContext<ReportsHub> reportsHubContext;
|
||||
private readonly IHubContext<ReportsHub, IReportHubClient> reportsHubContext;
|
||||
|
||||
public ReportController(IReportService reportService, IWellService wellService,
|
||||
FileService fileService, IHubContext<ReportsHub> reportsHubContext)
|
||||
FileService fileService, IHubContext<ReportsHub, IReportHubClient> reportsHubContext)
|
||||
{
|
||||
this.reportService = reportService;
|
||||
this.fileService = fileService;
|
||||
@ -57,13 +58,10 @@ namespace AsbCloudWebApi.Controllers
|
||||
return Forbid();
|
||||
|
||||
void HandleReportProgressAsync(object progress, string id) =>
|
||||
Task.Run(() =>
|
||||
Task.Run(async() =>
|
||||
{
|
||||
reportsHubContext.Clients.Group($"Report_{id}").SendAsync(
|
||||
nameof(IReportHubClient.GetReportProgress),
|
||||
progress,
|
||||
token
|
||||
).ConfigureAwait(false);
|
||||
await reportsHubContext.Clients.Group($"Report_{id}")
|
||||
.GetReportProgress(progress, token);
|
||||
}, token);
|
||||
|
||||
var id = reportService.EnqueueCreateReportWork(idWell, (int)idUser,
|
||||
|
@ -2,6 +2,7 @@
|
||||
using AsbCloudApp.Requests;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
@ -23,22 +24,23 @@ namespace AsbCloudWebApi.Controllers.SAUB
|
||||
protected readonly IWellService wellService;
|
||||
private readonly ITelemetryService telemetryService;
|
||||
private readonly ITelemetryDataService<TDto> telemetryDataService;
|
||||
private readonly IHubContext<TelemetryHub> telemetryHubContext;
|
||||
|
||||
public string SignalRMethodGetDataName { get; protected set; } = "ReceiveData";
|
||||
protected readonly IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext;
|
||||
|
||||
public TelemetryDataBaseController(
|
||||
ITelemetryService telemetryService,
|
||||
ITelemetryDataService<TDto> telemetryDataService,
|
||||
IWellService wellService,
|
||||
IHubContext<TelemetryHub> telemetryHubContext)
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext)
|
||||
{
|
||||
this.telemetryService = telemetryService;
|
||||
this.telemetryDataService = telemetryDataService;
|
||||
this.wellService = wellService;
|
||||
this.telemetryHubContext = telemetryHubContext;
|
||||
|
||||
}
|
||||
|
||||
protected abstract Task SignalRNotifyAsync(int idWell, IEnumerable<TDto> dtos, CancellationToken token);
|
||||
|
||||
/// <summary>
|
||||
/// Принимает данные от разных систем по скважине
|
||||
/// </summary>
|
||||
@ -55,8 +57,7 @@ namespace AsbCloudWebApi.Controllers.SAUB
|
||||
|
||||
var idWell = telemetryService.GetIdWellByTelemetryUid(uid);
|
||||
if (idWell is not null && dtos.Any())
|
||||
_ = Task.Run(() => telemetryHubContext.Clients.Group($"well_{idWell}")
|
||||
.SendAsync(SignalRMethodGetDataName, dtos), CancellationToken.None);
|
||||
_ = Task.Run(() => SignalRNotifyAsync(idWell.Value, dtos, CancellationToken.None));
|
||||
|
||||
return Ok();
|
||||
}
|
||||
@ -75,7 +76,7 @@ namespace AsbCloudWebApi.Controllers.SAUB
|
||||
[Permission]
|
||||
public virtual async Task<ActionResult<IEnumerable<TDto>>> GetDataAsync(int idWell,
|
||||
DateTime begin = default,
|
||||
int intervalSec = 600,
|
||||
int intervalSec = 600,
|
||||
int approxPointsCount = 1024,
|
||||
//TODO: сделать cancellationToken обязательным
|
||||
CancellationToken token = default)
|
||||
|
@ -1,12 +1,14 @@
|
||||
using AsbCloudApp.Data.SAUB;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
using System.Threading.Tasks;
|
||||
using System.Threading;
|
||||
using System;
|
||||
using Microsoft.AspNetCore.Http;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AsbCloudWebApi.Controllers.SAUB
|
||||
{
|
||||
@ -23,14 +25,13 @@ namespace AsbCloudWebApi.Controllers.SAUB
|
||||
ITelemetryService telemetryService,
|
||||
ITelemetryDataSaubService telemetryDataService,
|
||||
IWellService wellService,
|
||||
IHubContext<TelemetryHub> telemetryHubContext)
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext)
|
||||
: base(
|
||||
telemetryService,
|
||||
telemetryDataService,
|
||||
wellService,
|
||||
telemetryHubContext)
|
||||
{
|
||||
SignalRMethodGetDataName = "ReceiveDataSaub";
|
||||
telemetryDataSaubService = telemetryDataService;
|
||||
}
|
||||
|
||||
@ -62,5 +63,10 @@ namespace AsbCloudWebApi.Controllers.SAUB
|
||||
var fileName = $"DataSaub idWell{idWell} {beginDate:yyyy-MM-DDTHH-mm} - {endDate:yyyy-MM-DDTHH-mm}.zip";
|
||||
return File(stream, "application/octet-stream", fileName);
|
||||
}
|
||||
|
||||
protected override Task SignalRNotifyAsync(int idWell, IEnumerable<TelemetryDataSaubDto> dtos, CancellationToken token)
|
||||
{
|
||||
return telemetryHubContext.Clients.Group($"well_{idWell}").ReceiveDataSaub(dtos, token);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,8 +1,12 @@
|
||||
using AsbCloudApp.Data.SAUB;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AsbCloudWebApi.Controllers.SAUB
|
||||
{
|
||||
@ -17,14 +21,17 @@ namespace AsbCloudWebApi.Controllers.SAUB
|
||||
ITelemetryService telemetryService,
|
||||
ITelemetryDataService<TelemetryDataSpinDto> telemetryDataService,
|
||||
IWellService wellService,
|
||||
IHubContext<TelemetryHub> telemetryHubContext)
|
||||
IHubContext<TelemetryHub, ITelemetryHubClient> telemetryHubContext)
|
||||
: base(
|
||||
telemetryService,
|
||||
telemetryDataService,
|
||||
wellService,
|
||||
telemetryHubContext)
|
||||
{}
|
||||
|
||||
protected override Task SignalRNotifyAsync(int idWell, IEnumerable<TelemetryDataSpinDto> dtos, CancellationToken token)
|
||||
{
|
||||
SignalRMethodGetDataName = "ReceiveDataSpin";
|
||||
return telemetryHubContext.Clients.Group($"well_{idWell}").ReceiveDataSpin(dtos, token);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -0,0 +1,13 @@
|
||||
using Microsoft.AspNetCore.Mvc.ApplicationModels;
|
||||
using System.Linq;
|
||||
|
||||
namespace AsbCloudWebApi.Conventions
|
||||
{
|
||||
public class ApiExplorerGroupPerVersionConvention : IControllerModelConvention
|
||||
{
|
||||
public void Apply(ControllerModel controller)
|
||||
{
|
||||
controller.ApiExplorer.GroupName = "v1";
|
||||
}
|
||||
}
|
||||
}
|
@ -19,6 +19,7 @@ using AsbCloudWebApi.SignalR;
|
||||
using AsbCloudWebApi.SignalR.Services;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.OpenApi.Any;
|
||||
using Swashbuckle.AspNetCore.SwaggerGen;
|
||||
|
||||
namespace AsbCloudWebApi
|
||||
{
|
||||
@ -46,6 +47,7 @@ namespace AsbCloudWebApi
|
||||
});
|
||||
|
||||
c.SwaggerDoc("v1", new OpenApiInfo { Title = "ASB cloud web api", Version = "v1" });
|
||||
c.SwaggerDoc("signalr", new OpenApiInfo { Title = "SignalR client methods", Version = "signalr" });
|
||||
c.AddSecurityDefinition("Bearer", new OpenApiSecurityScheme
|
||||
{
|
||||
Description = @"JWT Authorization header using the Bearer scheme. Enter 'Bearer' [space] and then your token in the text input below. Example: 'Bearer 12345abcdef'",
|
||||
@ -78,6 +80,13 @@ namespace AsbCloudWebApi
|
||||
var includeControllerXmlComment = true;
|
||||
c.IncludeXmlComments(xmlPath, includeControllerXmlComment);
|
||||
c.IncludeXmlComments(Path.Combine(AppContext.BaseDirectory, "AsbCloudApp.xml"), includeControllerXmlComment);
|
||||
|
||||
c.AddSignalRSwaggerGen(options => {
|
||||
options.DisplayInDocument("signalr");
|
||||
options.UseHubXmlCommentsSummaryAsTagDescription = true;
|
||||
options.UseHubXmlCommentsSummaryAsTag = true;
|
||||
options.UseXmlComments(xmlPath);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
|
@ -1,9 +1,10 @@
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR;
|
||||
|
||||
public abstract class BaseHub : Hub
|
||||
public abstract class BaseHub<T> : Hub<T> where T : class
|
||||
{
|
||||
public virtual Task AddToGroup(string groupName) =>
|
||||
Groups.AddToGroupAsync(Context.ConnectionId, groupName);
|
||||
@ -11,9 +12,3 @@ public abstract class BaseHub : Hub
|
||||
public virtual Task RemoveFromGroup(string groupName) =>
|
||||
Groups.RemoveFromGroupAsync(Context.ConnectionId, groupName);
|
||||
}
|
||||
|
||||
public abstract class BaseHub<T> : BaseHub
|
||||
where T : class
|
||||
{
|
||||
|
||||
}
|
23
AsbCloudWebApi/SignalR/Clients/INotificationHubClient.cs
Normal file
23
AsbCloudWebApi/SignalR/Clients/INotificationHubClient.cs
Normal file
@ -0,0 +1,23 @@
|
||||
using AsbCloudWebApi.SignalR.Messages;
|
||||
using SignalRSwaggerGen.Attributes;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR.Clients
|
||||
{
|
||||
/// <summary>
|
||||
/// Hub по работе с уведомлениями
|
||||
/// </summary>
|
||||
[SignalRHub]
|
||||
public interface INotificationHubClient
|
||||
{
|
||||
/// <summary>
|
||||
/// Отправка клиенту сообщения с уведомлением.
|
||||
/// Для подписки на метод необходимо отправить connectionId
|
||||
/// </summary>
|
||||
/// <param name="message">сообщение с уведомлением</param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task ReceiveNotifications(NotificationMessage message, CancellationToken token);
|
||||
}
|
||||
}
|
22
AsbCloudWebApi/SignalR/Clients/IReportHubClient.cs
Normal file
22
AsbCloudWebApi/SignalR/Clients/IReportHubClient.cs
Normal file
@ -0,0 +1,22 @@
|
||||
using SignalRSwaggerGen.Attributes;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR.Clients
|
||||
{
|
||||
/// <summary>
|
||||
/// Hub по работе с отчетами
|
||||
/// </summary>
|
||||
[SignalRHub]
|
||||
public interface IReportHubClient
|
||||
{
|
||||
/// <summary>
|
||||
/// Отправка клиенту сообщения о статусе формирования отчета.
|
||||
/// Для подписки на метод необходимо отправить сообщение в формате $"Report_{id}"
|
||||
/// </summary>
|
||||
/// <param name="progress">статус формирования отчета</param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task GetReportProgress(object progress, CancellationToken token);
|
||||
}
|
||||
}
|
54
AsbCloudWebApi/SignalR/Clients/ITelemetryHubClient.cs
Normal file
54
AsbCloudWebApi/SignalR/Clients/ITelemetryHubClient.cs
Normal file
@ -0,0 +1,54 @@
|
||||
using AsbCloudApp.Data.SAUB;
|
||||
using SignalRSwaggerGen.Attributes;
|
||||
using System.Collections;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR.Clients
|
||||
{
|
||||
/// <summary>
|
||||
/// Hub по работе с телеметрией
|
||||
/// </summary>
|
||||
[SignalRHub]
|
||||
public interface ITelemetryHubClient
|
||||
{
|
||||
/// <summary>
|
||||
/// Отправка клиенту уведомления о доставке с панели drill test данных.
|
||||
/// Для подписки на метод необходимо отправить сообщение в формате $"well_{idWell}"
|
||||
/// </summary>
|
||||
/// <param name="dto"></param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task ReceiveDrilltestData(DrillTestDto dto, CancellationToken token);
|
||||
|
||||
/// <summary>
|
||||
///
|
||||
/// </summary>
|
||||
/// <param name="dtos"></param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task UpdateProcessMap(IEnumerable dtos, CancellationToken token);
|
||||
|
||||
/// <summary>
|
||||
/// Отправка сауб-данных клиенту.
|
||||
/// Для подписки на метод необходимо отправить сообщение в формате $"well_{idWell}"
|
||||
/// </summary>
|
||||
/// <typeparam name="T"></typeparam>
|
||||
/// <param name="dtos"></param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task ReceiveDataSaub(IEnumerable<TelemetryDataSaubDto> dtos, CancellationToken token);
|
||||
|
||||
/// <summary>
|
||||
/// Отправка спин-данных клиенту.
|
||||
/// Для подписки на метод необходимо отправить сообщение в формате $"well_{idWell}"
|
||||
/// </summary>
|
||||
/// <typeparam name="T"></typeparam>
|
||||
/// <param name="dtos"></param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task ReceiveDataSpin(IEnumerable<TelemetryDataSpinDto> dtos, CancellationToken token);
|
||||
|
||||
}
|
||||
}
|
23
AsbCloudWebApi/SignalR/Clients/IWellInfoHubClient.cs
Normal file
23
AsbCloudWebApi/SignalR/Clients/IWellInfoHubClient.cs
Normal file
@ -0,0 +1,23 @@
|
||||
using AsbCloudApp.Data;
|
||||
using SignalRSwaggerGen.Attributes;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR.Clients
|
||||
{
|
||||
/// <summary>
|
||||
/// Hub по работе с информацией о скважине
|
||||
/// </summary>
|
||||
[SignalRHub]
|
||||
public interface IWellInfoHubClient
|
||||
{
|
||||
/// <summary>
|
||||
/// Отправка клиенту сообщения об обновлении информации о скважине
|
||||
/// Для подписки на метод необходимо отправить сообщение в формате $"well_info_{idWell}"
|
||||
/// </summary>
|
||||
/// <param name="wellInfo">информация о скважине</param>
|
||||
/// <param name="token"></param>
|
||||
/// <returns></returns>
|
||||
Task UpdateWellInfo(object wellInfo, CancellationToken token);
|
||||
}
|
||||
}
|
@ -1,7 +0,0 @@
|
||||
namespace AsbCloudWebApi.SignalR
|
||||
{
|
||||
public interface IReportHubClient
|
||||
{
|
||||
float GetReportProgress(float progress);
|
||||
}
|
||||
}
|
@ -2,6 +2,7 @@ using System;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using AsbCloudApp.Services.Notifications;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using AsbCloudWebApi.SignalR.Services;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
@ -9,7 +10,7 @@ using Microsoft.AspNetCore.Mvc;
|
||||
namespace AsbCloudWebApi.SignalR;
|
||||
|
||||
[Authorize]
|
||||
public class NotificationHub : BaseHub
|
||||
public class NotificationHub : BaseHub<INotificationHubClient>
|
||||
{
|
||||
private readonly ConnectionManagerService connectionManagerService;
|
||||
private readonly NotificationService notificationService;
|
||||
|
@ -1,7 +1,7 @@
|
||||
using AsbCloudApp.Data;
|
||||
using AsbCloudInfrastructure.Background;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
using System.Linq;
|
||||
using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
@ -10,7 +10,10 @@ namespace AsbCloudWebApi.SignalR
|
||||
{
|
||||
// SignalR manual:
|
||||
// https://docs.microsoft.com/ru-ru/aspnet/core/signalr/introduction?view=aspnetcore-5.0
|
||||
|
||||
//[SignalRHub]
|
||||
/// <summary>
|
||||
/// ReportsHub
|
||||
/// </summary>
|
||||
[Authorize]
|
||||
public class ReportsHub : BaseHub<IReportHubClient>
|
||||
{
|
||||
@ -21,6 +24,11 @@ namespace AsbCloudWebApi.SignalR
|
||||
this.backgroundWorker = backgroundWorker;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Добавление в группу, отправка данных о формировании отчета
|
||||
/// </summary>
|
||||
/// <param name="groupName"></param>
|
||||
/// <returns></returns>
|
||||
public override async Task AddToGroup(string groupName)
|
||||
{
|
||||
await base.AddToGroup(groupName);
|
||||
@ -34,19 +42,14 @@ namespace AsbCloudWebApi.SignalR
|
||||
Progress = 0f,
|
||||
};
|
||||
|
||||
var state = work?.CurrentState;
|
||||
var state = work?.CurrentState;
|
||||
if (state is not null)
|
||||
{
|
||||
progress.Operation = state.State;
|
||||
progress.Progress = (float)state.Progress;
|
||||
}
|
||||
|
||||
await Clients.Group(groupName).SendAsync(
|
||||
nameof(IReportHubClient.GetReportProgress),
|
||||
progress,
|
||||
CancellationToken.None
|
||||
);
|
||||
|
||||
await Clients.Group(groupName).GetReportProgress(progress, CancellationToken.None);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,7 @@ using System.Threading;
|
||||
using System.Threading.Tasks;
|
||||
using AsbCloudApp.Data;
|
||||
using AsbCloudApp.Repositories;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using AsbCloudWebApi.SignalR.Messages;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
|
||||
@ -12,11 +13,11 @@ namespace AsbCloudWebApi.SignalR.Services;
|
||||
public class NotificationPublisher
|
||||
{
|
||||
private readonly ConnectionManagerService connectionManagerService;
|
||||
private readonly IHubContext<NotificationHub> notificationHubContext;
|
||||
private readonly IHubContext<NotificationHub, INotificationHubClient> notificationHubContext;
|
||||
private readonly INotificationRepository notificationRepository;
|
||||
|
||||
public NotificationPublisher(ConnectionManagerService connectionManagerService,
|
||||
IHubContext<NotificationHub> notificationHubContext,
|
||||
IHubContext<NotificationHub, INotificationHubClient> notificationHubContext,
|
||||
INotificationRepository notificationRepository)
|
||||
{
|
||||
this.connectionManagerService = connectionManagerService;
|
||||
@ -70,8 +71,6 @@ public class NotificationPublisher
|
||||
CancellationToken cancellationToken)
|
||||
{
|
||||
await notificationHubContext.Clients.Client(connectionId)
|
||||
.SendAsync("receiveNotifications",
|
||||
message,
|
||||
cancellationToken);
|
||||
.ReceiveNotifications(message, cancellationToken);
|
||||
}
|
||||
}
|
@ -1,4 +1,5 @@
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.Authorization;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR
|
||||
{
|
||||
@ -6,7 +7,7 @@ namespace AsbCloudWebApi.SignalR
|
||||
// https://docs.microsoft.com/ru-ru/aspnet/core/signalr/introduction?view=aspnetcore-5.0
|
||||
|
||||
[Authorize]
|
||||
public class TelemetryHub : BaseHub
|
||||
public class TelemetryHub : BaseHub<ITelemetryHubClient>
|
||||
{
|
||||
|
||||
}
|
||||
|
@ -4,17 +4,18 @@ using AsbCloudApp.IntegrationEvents;
|
||||
using AsbCloudApp.IntegrationEvents.Interfaces;
|
||||
using AsbCloudApp.Services;
|
||||
using AsbCloudInfrastructure.Services;
|
||||
using AsbCloudWebApi.SignalR.Clients;
|
||||
using Microsoft.AspNetCore.SignalR;
|
||||
|
||||
namespace AsbCloudWebApi.SignalR;
|
||||
|
||||
public class WellInfoHub : BaseHub, IIntegrationEventHandler<UpdateWellInfoEvent>
|
||||
public class WellInfoHub : BaseHub<IWellInfoHubClient>, IIntegrationEventHandler<UpdateWellInfoEvent>
|
||||
{
|
||||
private readonly IHubContext<WellInfoHub> hubContext;
|
||||
private readonly IHubContext<WellInfoHub, IWellInfoHubClient> hubContext;
|
||||
private readonly IWellService wellService;
|
||||
private readonly WellInfoService wellInfoService;
|
||||
|
||||
public WellInfoHub(IHubContext<WellInfoHub> hubContext,
|
||||
public WellInfoHub(IHubContext<WellInfoHub, IWellInfoHubClient> hubContext,
|
||||
IWellService wellService,
|
||||
WellInfoService wellInfoService)
|
||||
{
|
||||
@ -34,8 +35,6 @@ public class WellInfoHub : BaseHub, IIntegrationEventHandler<UpdateWellInfoEvent
|
||||
|
||||
public async Task HandleAsync(UpdateWellInfoEvent integrationEvent, CancellationToken cancellationToken)
|
||||
{
|
||||
const string method = "update_well_info";
|
||||
|
||||
var well = await wellService.GetOrDefaultAsync(integrationEvent.IdWell, cancellationToken);
|
||||
|
||||
if(well is null)
|
||||
@ -44,7 +43,7 @@ public class WellInfoHub : BaseHub, IIntegrationEventHandler<UpdateWellInfoEvent
|
||||
var wellInfo = wellInfoService.FirstOrDefault(w => w.Id == well.Id);
|
||||
|
||||
await hubContext.Clients.Group($"well_info_{integrationEvent.IdWell}")
|
||||
.SendAsync(method, new
|
||||
.UpdateWellInfo(new
|
||||
{
|
||||
Well = well,
|
||||
WellInfo = wellInfo
|
||||
|
@ -10,6 +10,7 @@ using Microsoft.Extensions.DependencyInjection;
|
||||
using Microsoft.Extensions.Hosting;
|
||||
using Microsoft.AspNetCore.Mvc;
|
||||
using Microsoft.AspNetCore.ResponseCompression;
|
||||
using AsbCloudWebApi.Conventions;
|
||||
|
||||
namespace AsbCloudWebApi
|
||||
{
|
||||
@ -108,6 +109,10 @@ namespace AsbCloudWebApi
|
||||
options.EnableForHttps = true;
|
||||
options.Providers.Add<GzipCompressionProvider>();
|
||||
});
|
||||
|
||||
services.AddMvc(c =>
|
||||
c.Conventions.Add(new ApiExplorerGroupPerVersionConvention())
|
||||
);
|
||||
}
|
||||
|
||||
public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
|
||||
@ -116,6 +121,7 @@ namespace AsbCloudWebApi
|
||||
app.UseSwaggerUI(c =>
|
||||
{
|
||||
c.SwaggerEndpoint("/swagger/v1/swagger.json", "V1");
|
||||
c.SwaggerEndpoint("/swagger/signalr/swagger.json", "signalr");
|
||||
c.EnablePersistAuthorization();
|
||||
c.EnableFilter();
|
||||
c.DisplayOperationId();
|
||||
|
Loading…
Reference in New Issue
Block a user