using System.Text; using DotNetty.Transport.Channels; using HybirdFrameworkCore.Autofac.Attribute; using log4net; using Service.Charger.Client; using Service.Charger.Handler; using Service.Charger.Msg.Charger.Req; using Service.Charger.Msg.Host.Resp; namespace HybirdFrameworkServices.Charger.Handler { /// /// 3.5.13 电池包内部接触器状态和故障上报(站内充电模式有电池包时周期性上传) /// /// 1,保存电池包内部接触器状态和故障上报 /// 2,保存日志到log /// /// [Order(8)] [Scope("InstancePerDependency")] public class BatteryPackStateAndFaultHandler : SimpleChannelInboundHandler, IBaseHandler { private static readonly ILog Log = LogManager.GetLogger(typeof(BatteryPackStateAndFaultHandler)); protected override void ChannelRead0(IChannelHandlerContext ctx, BatteryPackStateAndFault msg) { if (ClientMgr.TryGetClient(ctx.Channel, out var sn, out var client)) { Log.Info($"receive {msg} from {sn}"); client.BatteryPackStateAndFault = msg; } } } }