-
-
Notifications
You must be signed in to change notification settings - Fork 433
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Change the backend of HubGroup to Multicaster #778
Conversation
what happened to IInMemoryStorage |
This is because MagicOnion itself is not suitable for storing application state, for example when handling multiple servers or when there is a need to separate logic. Application developers can implement equivalent functionality using DI and ConcurrentDictionary, etc. as needed. |
Thank you for clarification. |
How do I send message to Client on another service? public class AnotherService(IDownloadNotificationHub hub) There are not enough info about StreamingHub
Readme.md still using Broadcast but group.All.OnMessage |
The README is currently for v6. With v7 (not yet released), you can receive IMulticastGroupProvider via DI. By using the GroupProvider in both the Hub and Service, you can create and delete groups and add and remove members from anywhere. However, developers need to consider that the lifetime of the group is managed by the application. public class GroupService(IMulticastGroupProvider groupProvider) : IDisposable
{
// NOTE: You can also manage multiple groups using a dictionary, etc.
private readonly IMulticastSyncGroup<Guid, IMyReceiver> _group = groupProvider.GetOrAddSynchronousGroup<Guid, IMyHubReceiver>();
public void SendMessageToAll(string message) => _group.All.OnMessage(message);
public void AddMember(Guid id, IMyHubReceiver receiver) => _group.Add(receiver);
public void RemoveMember(Guid id) => _group.Remove(id);
public void Dispose() => _group.Dispose();
}
public class MyBackgroundService(GroupService groupService) : BackgroundService
{
protected override async Task ExecuteAsync(CancellationToken stoppingToken)
{
var timer = new PeriodicTimer(TimeSpan.FromSeconds(60));
while (await timer.WaitForNextTickAsync(stoppingToken))
{
groupService.SendMessageToAll("Send message periodically...");
}
}
}
...
builder.Services.AddSingleton<GroupService>();
builder.Services.AddHostedService<MyBackgroundService>();
...
public class MyHub(GroupService groupService) : StreamingHubBase<IMyHub, IMyHubReceiver>, IMyHub
{
protected override ValueTask OnConnected()
{
groupService.AddMember(ContextId, Client);
return default;
}
protected override ValueTask OnDisconnected()
{
groupService.RemoveMember(ContextId);
return default;
}
public Task SendMessage(string message) => groupService.SendMessageToAll(message);
} |
This PR migrates the implementation of StreamingHub's Group to a new library called Multicaster.
This allows for controls of the Group to be executed within the Hub's methods or within any application logic.
Added APIs
Client Property
A property Client that returns the receiver for the currently connected client is added to
StreamingHubBase<THub, TReceiver>
.This eliminates the need to create a group for receiver invocations to a single client.
Updated APIs
IGroup -> IGroup<T>
Group.AddAsync
inStreamingHubBase<THub, TReceiver>
now returns anIGroup<TReceiver>
.Changes to Broadcast Methods
StreamingHub.Broadcast*
andIGroup.CreateBroadcaster*
methods have been updated to new APIs viaIMulticastGroup
.Broadcast
->All
BroadcastToSelf
->Only
orSingle
or theClient
property of StreamingHubBroadcastExcept
->Except
BroadcastTo
->Only
orSingle
Changes to Types Specified in GroupConfigurationAttribute
Although GroupConfigurationAttribute can be used to select a group's implementation for each Hub, IHubGroupRepositoryFactory has been removed. Instead, a type for IMulticastGroupProvider must be specified.
Controlling Groups through Application Logic
By obtaining IMulticastGroupProvider through DI, you can manage the group's lifecycle and members within the application logic.
Groups created with
IMulticastGroupProvider
can broadcast to clients through the group by registering StreamingHub'sClient
property.While this provides flexible management of groups, be aware that the client registration and group lifecycle are no longer managed by MagicOnion, and manual management will be necessary.
Removed APIs
IInMemoryStorage
has been deleted.We thought it would be better if MagicOnion did not manage application state.
IInMemoryStorage
cannot synchronize state on multiple servers, and it is usual for the game logic to manage state.Application developers can implement a similar feature using DI and ConcurrentDictionary, etc.
Migration v6 -> v7
The following Shims can be imported into a project to migrate from v6 to v7 to maintain compatibility where existing APIs are used. You can import this Shim into your project and use
StreamingHubBaseCompat
instead ofStreamingHubBase
.https://gist.github.com/mayuki/974ab44d5464eefb821a5619209f7068