152 lines
6.5 KiB
C#
Raw Normal View History

2025-04-24 23:39:39 +08:00
using JiShe.CollectBus.Common.BuildSendDatas;
using JiShe.CollectBus.Common.Consts;
using JiShe.CollectBus.Common.Enums;
2024-10-29 16:28:14 +08:00
using JiShe.CollectBus.Common.Extensions;
using JiShe.CollectBus.Common.Helpers;
2024-10-29 16:28:14 +08:00
using JiShe.CollectBus.Common.Models;
using JiShe.CollectBus.Enums;
using JiShe.CollectBus.IotSystems.Devices;
2025-03-14 14:28:04 +08:00
using JiShe.CollectBus.IotSystems.MessageReceiveds;
using JiShe.CollectBus.IotSystems.Protocols;
using JiShe.CollectBus.Kafka.Producer;
2025-04-24 17:48:20 +08:00
using JiShe.CollectBus.Protocol.Contracts.SendData;
using JiShe.CollectBus.Protocol.SendData;
using Mapster;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using TouchSocket.Sockets;
using Volo.Abp.Domain.Repositories;
2024-09-30 17:10:43 +08:00
namespace JiShe.CollectBus.Protocol
{
2025-04-25 12:01:15 +08:00
public class T1882018ProtocolPlugin : T37612012ProtocolPlugin
2024-09-30 17:10:43 +08:00
{
2025-04-25 12:01:15 +08:00
private readonly ILogger<T1882018ProtocolPlugin> _logger;
private readonly IProducerService _producerService;
private readonly IRepository<Device, Guid> _deviceRepository;
private readonly ITcpService _tcpService;
2025-04-24 19:31:28 +08:00
2025-04-25 14:37:35 +08:00
public readonly Dictionary<string, Telemetry1882018PacketBuilder.T1882018Delegate> T188ControlHandlers;
2025-04-24 17:48:20 +08:00
2024-12-19 16:07:07 +08:00
/// <summary>
2025-04-25 12:01:15 +08:00
/// Initializes a new instance of the <see cref="T1882018ProtocolPlugin"/> class.
2024-12-19 16:07:07 +08:00
/// </summary>
2025-02-24 13:47:12 +08:00
/// <param name="serviceProvider">The service provider.</param>
2025-04-25 14:37:35 +08:00
public T1882018ProtocolPlugin(IServiceProvider serviceProvider, ILogger<T1882018ProtocolPlugin> logger, ITcpService tcpService) : base(serviceProvider, logger, tcpService)
2024-09-30 17:53:14 +08:00
{
_logger = logger;
//_logger = serviceProvider.GetRequiredService<ILogger<StandardProtocolPlugin>>();
_producerService = serviceProvider.GetRequiredService<IProducerService>();
_deviceRepository = serviceProvider.GetRequiredService<IRepository<Device, Guid>>();
_tcpService = tcpService;
2025-04-25 14:37:35 +08:00
T188ControlHandlers = Telemetry1882018PacketBuilder.T1882018ControlHandlers;
2024-09-30 17:10:43 +08:00
}
2025-04-25 14:37:35 +08:00
public sealed override ProtocolInfo Info => new(nameof(T1882018ProtocolPlugin), "376.1/188", "TCP", "376.1协议", "DTS1980");
2024-10-21 13:30:53 +08:00
public override async Task<T> AnalyzeAsync<T>(ITcpSessionClient client, string messageReceived, Action<T>? sendAction = null)
2024-10-29 16:28:14 +08:00
{
2025-04-25 14:37:35 +08:00
//TB3761? tB3761 = Analysis3761(messageReceived);
//if (tB3761 != null)
2025-04-25 09:28:56 +08:00
//{
2025-04-25 14:37:35 +08:00
// if (tB3761.AFN_FC?.AFN == (int)AFN.链路接口检测)
// {
// if (tB3761.A == null || tB3761.A.Code.IsNullOrWhiteSpace() || tB3761.A.A3?.D1_D7 == null || tB3761.SEQ?.PSEQ == null)
// {
// _logger.LogError($"解析AFN.链路接口检测报文失败,报文:{messageReceived},TB3761:{tB3761.Serialize()}");
// }
// else
// {
// if (tB3761.DT?.Fn == (int)FN.登录)
// {
// // 登录回复
// if (tB3761.SEQ.CON == (int)CON.需要对该帧进行确认)
// await LoginAsync(client, messageReceived, tB3761.A.Code, tB3761.A.A3?.D1_D7, tB3761.SEQ?.PSEQ);
// }
// else if (tB3761.DT?.Fn == (int)FN.心跳)
// {
// // 心跳回复
// //心跳帧有两种情况:
// //1. 集中器先有登录帧,再有心跳帧
// //2. 集中器没有登录帧,只有心跳帧
// await HeartbeatAsync(client, messageReceived, tB3761.A.Code, tB3761.A.A3?.D1_D7, tB3761.SEQ?.PSEQ);
// }
// }
// }
// await OnTcpNormalReceived(client, tB3761);
//}
//return (tB3761 as T)!;
return null;
2025-04-25 09:28:56 +08:00
}
2025-04-24 19:31:28 +08:00
2025-04-23 23:42:35 +08:00
/// <summary>
2025-04-24 17:48:20 +08:00
/// 组装报文
2025-04-23 23:42:35 +08:00
/// </summary>
2025-04-24 23:39:39 +08:00
/// <param name="request">报文构建参数</param>
2025-04-23 23:42:35 +08:00
/// <returns></returns>
2025-04-24 23:39:39 +08:00
public override async Task<ProtocolBuildResponse> BuildAsync(ProtocolBuildRequest request)
2025-04-23 23:42:35 +08:00
{
2025-04-24 23:39:39 +08:00
if (request == null)
{
2025-04-25 12:01:15 +08:00
throw new Exception($"{nameof(T1882018ProtocolPlugin)} 报文构建失败,参数为空");
2025-04-24 23:39:39 +08:00
}
2025-04-24 17:48:20 +08:00
var itemCodeArr = request.ItemCode.Split('_');
var aFNStr = itemCodeArr[0];
var aFN = (AFN)aFNStr.HexToDec();
var fn = int.Parse(itemCodeArr[1]);
Telemetry3761PacketResponse builderResponse = null;
List<string> dataUnit = new List<string>();
2025-04-24 23:39:39 +08:00
//数据转发场景 10H_F1_1CH
if (aFNStr == "10" && request.SubProtocolRequest != null && string.IsNullOrWhiteSpace(request.SubProtocolRequest.ItemCode) == false)
2025-04-24 17:48:20 +08:00
{
2025-04-24 23:39:39 +08:00
var t645PacketHandlerName = $"C{request.SubProtocolRequest.ItemCode}_Send";
2025-04-25 12:01:15 +08:00
Telemetry1882018PacketResponse t645PacketResponse = null;
2025-04-24 17:48:20 +08:00
2025-04-25 14:37:35 +08:00
if (T188ControlHandlers != null && T188ControlHandlers.TryGetValue(t645PacketHandlerName
2025-04-24 23:39:39 +08:00
, out var t645PacketHandler))
2025-04-24 17:48:20 +08:00
{
2025-04-25 12:01:15 +08:00
t645PacketResponse = t645PacketHandler(new Telemetry1882018PacketRequest()
2025-04-24 17:48:20 +08:00
{
2025-04-24 23:39:39 +08:00
MeterAddress = request.SubProtocolRequest.MeterAddress,
Password = request.SubProtocolRequest.Password,
ItemCode = request.SubProtocolRequest.ItemCode,
2025-04-24 17:48:20 +08:00
});
}
if (t645PacketResponse != null)
{
dataUnit = t645PacketResponse.Data;
}
}
string afnMethonCode = $"AFN{aFNStr}_Fn_Send";
2025-04-25 14:37:35 +08:00
if (base.T3761AFNHandlers != null && base.T3761AFNHandlers.TryGetValue(afnMethonCode
2025-04-24 17:48:20 +08:00
, out var handler))
{
builderResponse = handler(new Telemetry3761PacketRequest()
{
FocusAddress = request.FocusAddress,
Fn = fn,
Pn = request.Pn,
DataUnit = dataUnit,
});
}
if (builderResponse == null)
{
2025-04-24 23:39:39 +08:00
return new ProtocolBuildResponse();
2025-04-24 17:48:20 +08:00
}
2025-04-24 23:39:39 +08:00
var result = builderResponse.Adapt<ProtocolBuildResponse>();
2025-04-24 17:48:20 +08:00
result.IsSuccess = true;
2025-04-24 17:48:20 +08:00
return await Task.FromResult(result);
2025-04-25 14:37:35 +08:00
}
2024-09-30 17:10:43 +08:00
}
}