using Prism.Events; using System.Text.Json; using YY.Admin.Core; using YY.Admin.Core.Events; namespace YY.Admin.Services.Service.Print; /// 订阅 STOMP:PRINT_BIZ_TEMPLATE_BIND_CHANGED,驱动列表静默刷新;网络恢复补偿。 public class PrintBizTemplateBindSyncCoordinator : ISingletonDependency { private readonly IEventAggregator _eventAggregator; private readonly ILoggerService _logger; private SubscriptionToken? _remoteCommandToken; private SubscriptionToken? _networkStatusToken; public PrintBizTemplateBindSyncCoordinator( IEventAggregator eventAggregator, SyncPollManager pollManager, ILoggerService logger) { _eventAggregator = eventAggregator; _logger = logger; _remoteCommandToken = _eventAggregator .GetEvent() .Subscribe(OnRemoteCommand, ThreadOption.BackgroundThread); _networkStatusToken = _eventAggregator .GetEvent() .Subscribe(OnNetworkStatusChanged, ThreadOption.BackgroundThread); pollManager.Register("业务打印绑定", () => { _eventAggregator.GetEvent() .Publish(new PrintBizTemplateBindChangedPayload { Action = "poll" }); return Task.CompletedTask; }); _logger.Information("[业务打印绑定推送] PrintBizTemplateBindSyncCoordinator 已启动"); } private void OnNetworkStatusChanged(NetworkStatusChangedPayload payload) { if (!payload.IsOnline) return; _logger.Information("[业务打印绑定推送] 网络恢复,触发补偿刷新"); _eventAggregator.GetEvent() .Publish(new PrintBizTemplateBindChangedPayload { Action = "reconnect" }); } private void OnRemoteCommand(RemoteCommandPayload payload) { try { var json = payload.CommandJson ?? string.Empty; if (string.IsNullOrWhiteSpace(json)) return; using var doc = JsonDocument.Parse(json); if (!doc.RootElement.TryGetProperty("cmd", out var cmdEl)) return; var cmd = cmdEl.GetString() ?? string.Empty; if (!cmd.Equals("PRINT_BIZ_TEMPLATE_BIND_CHANGED", StringComparison.OrdinalIgnoreCase)) return; doc.RootElement.TryGetProperty("action", out var actionEl); doc.RootElement.TryGetProperty("bindId", out var idEl); var changedPayload = new PrintBizTemplateBindChangedPayload { Action = actionEl.GetString() ?? string.Empty, BindId = idEl.ValueKind == JsonValueKind.String ? idEl.GetString() : null }; _logger.Information($"[业务打印绑定推送] 收到变更 action={changedPayload.Action}, bindId={changedPayload.BindId}"); _eventAggregator.GetEvent().Publish(changedPayload); } catch (Exception ex) { _logger.Warning($"[业务打印绑定推送] 处理 STOMP 信号失败: {ex.Message}"); } } }