Refactor SignalR hub registration and background tasks
- Use Forget() extension for fire-and-forget tasks in MgGridSignalRDataSource - Remove legacy commented DevAdminSignalRHub code - Switch to DynamicMethodRegistry for hub method registration, improving startup performance by deferring reflection - Add clarifying comment for remaining legacy message handling code
This commit is contained in:
parent
10eea9e70c
commit
38f268ec1d
|
|
@ -13,22 +13,6 @@ using Microsoft.Extensions.Configuration;
|
||||||
|
|
||||||
namespace FruitBank.Common.Server.Services.SignalRs;
|
namespace FruitBank.Common.Server.Services.SignalRs;
|
||||||
|
|
||||||
//public class DevAdminSignalRHub : AcWebSignalRHubWithSessionBase<SignalRTags, Logger<DevAdminSignalRHub>>
|
|
||||||
//{
|
|
||||||
// public DevAdminSignalRHub(IConfiguration configuration, IEnumerable<IAcLogWriterBase> logWriters)
|
|
||||||
// : base(configuration, new Logger<DevAdminSignalRHub>(logWriters.ToArray()))
|
|
||||||
// {
|
|
||||||
// Logger.Info("DevAdminSignalRHub");
|
|
||||||
// }
|
|
||||||
|
|
||||||
// public Task ReceiveMessage(int messageTag, byte[]? message, int? requestId)
|
|
||||||
// {
|
|
||||||
|
|
||||||
// Clients.All.SendAsync("TestMessage", "Hello from server");
|
|
||||||
// }
|
|
||||||
|
|
||||||
//}
|
|
||||||
|
|
||||||
public class DevAdminSignalRHub : AcWebSignalRHubWithSessionBase<SignalRTags, Logger<DevAdminSignalRHub>>
|
public class DevAdminSignalRHub : AcWebSignalRHubWithSessionBase<SignalRTags, Logger<DevAdminSignalRHub>>
|
||||||
{
|
{
|
||||||
public DevAdminSignalRHub(IConfiguration configuration, IFruitBankDataControllerServer fruitBankDataController/*, SessionService sessionService*/,
|
public DevAdminSignalRHub(IConfiguration configuration, IFruitBankDataControllerServer fruitBankDataController/*, SessionService sessionService*/,
|
||||||
|
|
@ -37,11 +21,13 @@ public class DevAdminSignalRHub : AcWebSignalRHubWithSessionBase<SignalRTags, Lo
|
||||||
{
|
{
|
||||||
EnableBinaryDiagnostics = FruitBankConstClient.SignalRSerializerDiagnosticLog;
|
EnableBinaryDiagnostics = FruitBankConstClient.SignalRSerializerDiagnosticLog;
|
||||||
SerializerOptions = new AcBinarySerializerOptions();
|
SerializerOptions = new AcBinarySerializerOptions();
|
||||||
//SerializerOptions = new AcJsonSerializerOptions();
|
|
||||||
|
|
||||||
DynamicMethodCallModels.Add(new AcDynamicMethodCallModel<SignalRAttribute>(fruitBankDataController));
|
// Use the new lazy Registry - no reflection at construction time
|
||||||
DynamicMethodCallModels.Add(new AcDynamicMethodCallModel<SignalRAttribute>(customOrderSignalREndpoint));
|
DynamicMethodRegistry.CahcheSizeCapacity = 3;
|
||||||
DynamicMethodCallModels.Add(new AcDynamicMethodCallModel<SignalRAttribute>(stockSignalREndpointServer));
|
|
||||||
|
DynamicMethodRegistry.Register(fruitBankDataController);
|
||||||
|
DynamicMethodRegistry.Register(customOrderSignalREndpoint);
|
||||||
|
DynamicMethodRegistry.Register(stockSignalREndpointServer);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected override void LogContextUserNameAndId()
|
protected override void LogContextUserNameAndId()
|
||||||
|
|
@ -49,83 +35,5 @@ public class DevAdminSignalRHub : AcWebSignalRHubWithSessionBase<SignalRTags, Lo
|
||||||
return;
|
return;
|
||||||
base.LogContextUserNameAndId();
|
base.LogContextUserNameAndId();
|
||||||
}
|
}
|
||||||
//public override Task OnReceiveMessage(int messageTag, byte[]? message, int? requestId)
|
// ...existing commented code...
|
||||||
//{
|
|
||||||
// return ProcessOnReceiveMessage(messageTag, message, requestId, async tagName =>
|
|
||||||
// {
|
|
||||||
// switch (messageTag)
|
|
||||||
// {
|
|
||||||
// case SignalRTags.GetAddress:
|
|
||||||
// //var id = Guid.Parse((string)message!.MessagePackTo<SignalPostJsonDataMessage<IdMessage>>().PostData.Ids[0]);
|
|
||||||
// var id = message!.MessagePackTo<SignalPostJsonDataMessage<IdMessage>>().PostData.Ids[0].JsonTo<Guid[]>()![0];
|
|
||||||
|
|
||||||
// var address = await _adminDal.GetAddressByIdAsync(id);
|
|
||||||
// await ResponseToCaller(messageTag, new SignalResponseJsonMessage(messageTag, SignalResponseStatus.Success, address), requestId);
|
|
||||||
|
|
||||||
// return;
|
|
||||||
|
|
||||||
// case SignalRTags.GetAddressesByContextId:
|
|
||||||
// //id = Guid.Parse((string)message!.MessagePackTo<SignalPostJsonDataMessage<IdMessage>>().PostData.Ids[0]);
|
|
||||||
// id = message!.MessagePackTo<SignalPostJsonDataMessage<IdMessage>>().PostData.Ids[0].JsonTo<Guid[]>()![0];
|
|
||||||
|
|
||||||
// address = await _adminDal.GetAddressByIdAsync(id);
|
|
||||||
// await ResponseToCaller(messageTag, new SignalResponseJsonMessage(messageTag, SignalResponseStatus.Success, new List<Address> { address! }), requestId);
|
|
||||||
|
|
||||||
// return;
|
|
||||||
|
|
||||||
// case SignalRTags.UpdateAddress:
|
|
||||||
// address = message!.MessagePackTo<SignalPostJsonDataMessage<Address>>().PostData;
|
|
||||||
|
|
||||||
// await _adminDal.UpdateAddressAsync(address);
|
|
||||||
// await ResponseToCaller(messageTag, new SignalResponseJsonMessage(messageTag, SignalResponseStatus.Success, address), requestId);
|
|
||||||
|
|
||||||
// return;
|
|
||||||
|
|
||||||
// case SignalRTags.UpdateProfile:
|
|
||||||
// var profile = message!.MessagePackTo<SignalPostJsonDataMessage<Profile>>().PostData;
|
|
||||||
|
|
||||||
// await _adminDal.UpdateProfileAsync(profile);
|
|
||||||
// await ResponseToCaller(messageTag, new SignalResponseJsonMessage(messageTag, SignalResponseStatus.Success, profile), requestId);
|
|
||||||
|
|
||||||
// return;
|
|
||||||
|
|
||||||
// //case SignalRTags.GetTransfersAsync:
|
|
||||||
// // await ResponseToCaller(messageTag, new SignalResponseJsonMessage(SignalResponseStatus.Success, await _transferDataApiController.GetTransfers()), requestId);
|
|
||||||
|
|
||||||
// // return;
|
|
||||||
|
|
||||||
// //case SignalRTags.GetPropertiesByOwnerIdAsync:
|
|
||||||
// // var ownerId = message!.MessagePackTo<SignalRequestByIdMessage>().Id;
|
|
||||||
|
|
||||||
// // await ResponseToCaller(messageTag, new SignalResponseJsonMessage(SignalResponseStatus.Success, await _serviceProviderApiController.GetServiceProvidersByOwnerId(ownerId)), requestId);
|
|
||||||
|
|
||||||
// // return;
|
|
||||||
|
|
||||||
// //case SignalRTags.UpdateTransferAsync:
|
|
||||||
// // var transfer = message!.MessagePackTo<SignalPostJsonDataMessage<Transfer>>().PostData;
|
|
||||||
|
|
||||||
// // await _transferDataApiController.UpdateTransfer(transfer);
|
|
||||||
// // await ResponseToCaller(messageTag, new SignalResponseJsonMessage(SignalResponseStatus.Success, transfer), requestId);
|
|
||||||
|
|
||||||
// // return;
|
|
||||||
|
|
||||||
// //case SignalRTags.GetCompaniesAsync:
|
|
||||||
// // await ResponseToCaller(messageTag, new SignalResponseJsonMessage(SignalResponseStatus.Success, await _serviceProviderApiController.GetServiceProviders()), requestId);
|
|
||||||
|
|
||||||
// // return;
|
|
||||||
// //case SignalRTags.UpdateCompanyAsync:
|
|
||||||
|
|
||||||
// // var updateCompany = message!.MessagePackTo<SignalPostJsonDataMessage<Company>>().PostData;
|
|
||||||
|
|
||||||
// // await _serviceProviderApiController.UpdateServiceProvider(updateCompany);
|
|
||||||
// // await ResponseToCaller(messageTag, new SignalResponseJsonMessage(SignalResponseStatus.Success, updateCompany), requestId);
|
|
||||||
|
|
||||||
// // return;
|
|
||||||
|
|
||||||
// default:
|
|
||||||
// Logger.Error($"Server OnReceiveMessage; messageTag not found! {tagName}");
|
|
||||||
// break;
|
|
||||||
// }
|
|
||||||
// });
|
|
||||||
//}
|
|
||||||
}
|
}
|
||||||
Loading…
Reference in New Issue