662f3f9f5c
v2-ci / build (push) Failing after 32s
v2-ci / unit-tests (tests/Core/ZB.MOM.WW.OtOpcUa.Cluster.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.ControlPlane.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.OpcUaServer.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.Runtime.Tests) (push) Has been skipped
v2-ci / unit-tests (tests/Server/ZB.MOM.WW.OtOpcUa.Security.Tests) (push) Has been skipped
v2-ci / integration (tests/Server/ZB.MOM.WW.OtOpcUa.Host.IntegrationTests) (push) Has been skipped
v2-ci / integration (tests/Server/ZB.MOM.WW.OtOpcUa.OpcUaServer.IntegrationTests) (push) Has been skipped
- Topic-name drift fix: DriverHealthChanged.TopicName and DriverControlTopic.Name now live on the message contracts in Commons. AkkaDriverHealthPublisher, DriverStatusSignalRBridge, DriverHostActor, and AdminOperationsActor all delegate to the single constant so a rename can't silently desynchronise publisher and subscriber. - DriverStatusPanel._opResultClearTimer switched from System.Timers.Timer to System.Threading.Timer + awaited DisposeAsync. Prevents an in-flight 8s clear-callback from invoking StateHasChanged on a component whose hub has already been released. - PublishHealthSnapshot deduplicates against the last published (state, lastSuccess, lastError, errorCount) fingerprint. The 30s heartbeat no longer floods the SignalR layer with identical Healthy snapshots — newly-joined clients still warm up via the snapshot store on JoinDriver.
37 lines
1.6 KiB
C#
37 lines
1.6 KiB
C#
namespace ZB.MOM.WW.OtOpcUa.Commons.Messages.Admin;
|
|
|
|
/// <summary>
|
|
/// Shared DPS topic for driver-control commands (<see cref="RestartDriver"/>,
|
|
/// <see cref="ReconnectDriver"/>). Publishers (AdminOperationsActor) and subscribers
|
|
/// (DriverHostActor) reference this single constant so renames can't silently
|
|
/// desynchronise.
|
|
/// </summary>
|
|
public static class DriverControlTopic
|
|
{
|
|
public const string Name = "driver-control";
|
|
}
|
|
|
|
/// <summary>
|
|
/// AdminUI → AdminOperationsActor: restart the driver actor for one instance.
|
|
/// A restart fully stops and respawns the actor — loses in-memory state, may briefly
|
|
/// interrupt active subscriptions. The driver actor's supervisor performs the work.
|
|
/// </summary>
|
|
/// <param name="ClusterId">Cluster scope identifier (for audit).</param>
|
|
/// <param name="DriverInstanceId">The driver instance to restart.</param>
|
|
/// <param name="ActorByUserName">The authenticated admin user who triggered the restart.</param>
|
|
/// <param name="CorrelationId">Round-trip correlation token.</param>
|
|
public sealed record RestartDriver(
|
|
string ClusterId,
|
|
string DriverInstanceId,
|
|
string ActorByUserName,
|
|
Guid CorrelationId);
|
|
|
|
/// <summary>Reply for <see cref="RestartDriver"/>.</summary>
|
|
/// <param name="Ok">True iff the operation was dispatched without error.</param>
|
|
/// <param name="Message">Failure reason; null on success.</param>
|
|
/// <param name="CorrelationId">Echoes the request's correlation token.</param>
|
|
public sealed record RestartDriverResult(
|
|
bool Ok,
|
|
string? Message,
|
|
Guid CorrelationId);
|