This repository was archived by the owner on Dec 26, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathSimConnectMqttAdapter.cs
106 lines (91 loc) · 3.39 KB
/
SimConnectMqttAdapter.cs
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
namespace FSMosquitoClient
{
using Microsoft.Extensions.Logging;
using System;
public class SimConnectMqttAdapter : ISimConnectMqttAdapter
{
private readonly ILogger<SimConnectMqttAdapter> _logger;
public SimConnectMqttAdapter(IFsMqtt fsMqtt, IFsSimConnect fsSimConnect, ILogger<SimConnectMqttAdapter> logger)
{
FsMqtt = fsMqtt ?? throw new ArgumentNullException(nameof(fsMqtt));
FsSimConnect = fsSimConnect ?? throw new ArgumentNullException(nameof(fsSimConnect));
_logger = logger ?? throw new ArgumentNullException(nameof(logger));
FsSimConnect.SimConnectOpened += SimConnect_SimConnectOpened;
FsSimConnect.SimConnectClosed += SimConnect_SimConnectClosed;
FsSimConnect.TopicValueChanged += SimConnect_TopicValueChanged;
FsMqtt.AtcNotificationReceived += FsMqtt_AtcNotificationReceived;
FsMqtt.SubscribeRequestReceived += FsMqtt_SubscribeRequestReceived; ;
FsMqtt.SetSimVarValueRequestReceived += FsMqtt_SetSimVarValueRequestReceived;
}
public IFsMqtt FsMqtt
{
get;
private set;
}
public IFsSimConnect FsSimConnect
{
get;
private set;
}
public void Start(IntPtr handle)
{
_logger.LogInformation("Starting SimConnectMqttAdapter...");
if (!FsSimConnect.IsConnected)
{
FsSimConnect.Connect(handle);
}
if (!FsMqtt.IsConnected)
{
FsMqtt.Connect();
}
}
public void SignalReceiveSimConnectMessage()
{
FsSimConnect.SignalReceiveSimConnectMessage();
}
private void SimConnect_SimConnectOpened(object sender, EventArgs e)
{
FsMqtt.PublishSimConnectStatus("Opened");
}
private void SimConnect_SimConnectClosed(object sender, EventArgs e)
{
FsMqtt.PublishSimConnectStatus("Closed");
}
private void SimConnect_TopicValueChanged(object sender, (SimConnectTopic topic, uint objectId, object value) topicValue)
{
if (FsMqtt.IsConnected)
{
FsMqtt.PublishTopicValue(topicValue.topic, topicValue.objectId, topicValue.value);
}
}
private void FsMqtt_AtcNotificationReceived(object _, AtcNotification e)
{
switch (e.Message?.ToLower())
{
case "report_status":
{
FsMqtt.PublishSimConnectStatus(FsSimConnect.IsConnected ? "Opened" : "Closed");
}
break;
}
}
private void FsMqtt_SubscribeRequestReceived(object _, (string objectType, SimConnectTopic[] topics) e)
{
if (FsSimConnect.IsConnected)
{
// We're ignoring the object type for now...
foreach (var topic in e.topics)
{
FsSimConnect.Subscribe(topic);
}
}
}
private void FsMqtt_SetSimVarValueRequestReceived(object _, (string datumName, uint? objectId, object value) e)
{
if (FsSimConnect.IsConnected)
{
FsSimConnect.Set(e.datumName, e.objectId, e.value);
}
}
}
}