MqttControllerService.cs
2.51 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
using HHECS.DAQServer.Dto.Equipment;
using HHECS.DAQShared.Dto;
using MQTTnet.Server;
using System.Text;
using System.Text.Json;
namespace HHECS.DAQServer.Services
{
public class MqttControllerService
{
private readonly EquipmentService _equipmentService;
private readonly ILogger<MqttControllerService> _logger;
public MqttControllerService(EquipmentService equipmentService, ILogger<MqttControllerService> logger)
{
_equipmentService = equipmentService;
_logger = logger;
}
public Task OnClientConnected(ClientConnectedEventArgs eventArgs)
{
_logger.LogInformation("Client '{ClientId}' connected.", eventArgs.ClientId);
return Task.CompletedTask;
}
public Task ValidateConnection(ValidatingConnectionEventArgs eventArgs)
{
_logger.LogInformation("Client '{ClientId}' wants to connect. Accepting!", eventArgs.ClientId);
return Task.CompletedTask;
}
public async Task InterceptingPublish(InterceptingPublishEventArgs args)
{
try
{
var topic = args.ApplicationMessage.Topic;
var payload = args.ApplicationMessage.Payload;
var payloadString = Encoding.Default.GetString(payload);
//这里建议topic与api接口路径保持一致,方法共用
const string equipmentApi = "api/equipment/";
if (topic == $"{equipmentApi}SendEquipmentData")
{
var data = JsonSerializer.Deserialize<List<EquipmentDataDto>>(payloadString);
await _equipmentService.SendEquipmentData(data);
}
if (topic == $"{equipmentApi}SendEquipmentDataV2")
{
var data = JsonSerializer.Deserialize<List<EquipmentDataV2Dto>>(payloadString);
await _equipmentService.SendEquipmentDataV2(data);
}
if (topic == $"{equipmentApi}UpdateClientStatus")
{
var data = JsonSerializer.Deserialize<ClientStatusDto>(payloadString);
await _equipmentService.UpdateClientStatus(data.ClientId);
}
}
catch (Exception ex)
{
_logger.LogError(ex, "[{ServiceName}]的“{MethodName}”方法异常:{ErrorMessage}", nameof(MqttControllerService), nameof(InterceptingPublish), ex.Message);
}
}
}
}