Added joinmap for IBasicCommunication and testet Com, Tcp, Ssh

This commit is contained in:
Neil Dorin
2018-09-24 10:39:55 -06:00
parent 6ec0295aba
commit 780f7bc249
5 changed files with 85 additions and 10 deletions

View File

@@ -65,6 +65,8 @@ namespace PepperDash.Essentials.Bridges
AddPostActivationAction( () => AddPostActivationAction( () =>
{ {
Debug.Console(1, this, "Linking Devices...");
foreach (var d in PropertiesConfig.Devices) foreach (var d in PropertiesConfig.Devices)
{ {
var device = DeviceManager.GetDeviceForKey(d.DeviceKey); var device = DeviceManager.GetDeviceForKey(d.DeviceKey);
@@ -73,10 +75,13 @@ namespace PepperDash.Essentials.Bridges
{ {
if (device is GenericComm) if (device is GenericComm)
{ {
(device as GenericComm).LinkToApi(Eisc, d.JoinStart);
(device as GenericComm).LinkToApi(Eisc, d.JoinStart, d.JoinMapKey);
} }
} }
} }
Debug.Console(1, this, "Devices Linked.");
}); });
} }
@@ -88,7 +93,7 @@ namespace PepperDash.Essentials.Bridges
void Eisc_SigChange(object currentDevice, Crestron.SimplSharpPro.SigEventArgs args) void Eisc_SigChange(object currentDevice, Crestron.SimplSharpPro.SigEventArgs args)
{ {
if (Debug.Level >= 1) if (Debug.Level >= 1)
Debug.Console(1, this, "BridgeApi EISC change: {0} {1}={2}", args.Sig.Type, args.Sig.Number, args.Sig.StringValue); Debug.Console(1, this, "EiscApi change: {0} {1}={2}", args.Sig.Type, args.Sig.Number, args.Sig.StringValue);
var uo = args.Sig.UserObject; var uo = args.Sig.UserObject;
if (uo is Action<bool>) if (uo is Action<bool>)
(uo as Action<bool>)(args.Sig.BoolValue); (uo as Action<bool>)(args.Sig.BoolValue);
@@ -114,6 +119,9 @@ namespace PepperDash.Essentials.Bridges
[JsonProperty("joinStart")] [JsonProperty("joinStart")]
public uint JoinStart { get; set; } public uint JoinStart { get; set; }
[JsonProperty("joinMapKey")]
public string JoinMapKey { get; set; }
} }
} }

View File

@@ -13,12 +13,27 @@ namespace PepperDash.Essentials.Bridges
{ {
public static class IBasicCommunicationExtensions public static class IBasicCommunicationExtensions
{ {
public static void LinkToApi(this GenericComm comm, BasicTriList trilist, uint joinStart) public static void LinkToApi(this GenericComm comm, BasicTriList trilist, uint joinStart, string joinMapKey)
{ {
var joinMap = GetJoinMapForDevice(joinMapKey);
if (joinMap == null)
joinMap = new IBasicCommunicationJoinMap();
joinMap.OffsetJoinNumbers(joinStart);
if (comm.CommPort == null)
{
Debug.Console(1, comm, "Unable to link device '{0}'. CommPort is null", comm.Key);
return;
}
Debug.Console(1, comm, "Linking device '{0}' to Trilist '{1}'", comm.Key, trilist.ID);
// this is a permanent event handler. This cannot be -= from event // this is a permanent event handler. This cannot be -= from event
comm.CommPort.TextReceived += (s, a) => trilist.SetString(joinStart, a.Text); comm.CommPort.TextReceived += (s, a) => trilist.SetString(joinMap.TextReceived, a.Text);
trilist.SetStringSigAction(joinStart, new Action<string>(s => comm.CommPort.SendText(s))); trilist.SetStringSigAction(joinMap.SendText, new Action<string>(s => comm.CommPort.SendText(s)));
trilist.SetStringSigAction(joinStart + 1, new Action<string>(s => comm.SetPortConfig(s))); trilist.SetStringSigAction(joinMap.SetPortConfig + 1, new Action<string>(s => comm.SetPortConfig(s)));
var sComm = comm.CommPort as ISocketStatus; var sComm = comm.CommPort as ISocketStatus;
@@ -26,12 +41,12 @@ namespace PepperDash.Essentials.Bridges
{ {
sComm.ConnectionChange += (s, a) => sComm.ConnectionChange += (s, a) =>
{ {
trilist.SetUshort(joinStart, (ushort)(a.Client.ClientStatus)); trilist.SetUshort(joinMap.Status, (ushort)(a.Client.ClientStatus));
trilist.SetBool(joinStart, a.Client.ClientStatus == trilist.SetBool(joinMap.Connected, a.Client.ClientStatus ==
Crestron.SimplSharp.CrestronSockets.SocketStatus.SOCKET_STATUS_CONNECTED); Crestron.SimplSharp.CrestronSockets.SocketStatus.SOCKET_STATUS_CONNECTED);
}; };
trilist.SetBoolSigAction(joinStart, new Action<bool>(b => trilist.SetBoolSigAction(joinMap.Connect, new Action<bool>(b =>
{ {
if (b) if (b)
{ {
@@ -44,6 +59,58 @@ namespace PepperDash.Essentials.Bridges
})); }));
} }
} }
/// <summary>
/// Attempts to get the join map from config
/// </summary>
/// <param name="joinMapKey"></param>
/// <returns></returns>
public static IBasicCommunicationJoinMap GetJoinMapForDevice(string joinMapKey)
{
if(!string.IsNullOrEmpty(joinMapKey))
return null;
// TODO: Get the join map from the ConfigReader.ConfigObject
return null;
}
public class IBasicCommunicationJoinMap
{
// Default joins
public uint TextReceived { get; set; }
public uint SendText { get; set; }
public uint SetPortConfig { get; set; }
public uint Connect { get; set; }
public uint Connected { get; set; }
public uint Status { get; set; }
public IBasicCommunicationJoinMap()
{
TextReceived = 1;
SendText = 1;
SetPortConfig = 2;
Connect = 1;
Connected = 1;
Status = 1;
}
/// <summary>
/// Modifies all the join numbers by adding the offset. This should never be called twice
/// </summary>
/// <param name="joinStart"></param>
public void OffsetJoinNumbers(uint joinStart)
{
var joinOffset = joinStart - 1;
TextReceived = TextReceived + joinOffset;
SendText = SendText + joinOffset;
SetPortConfig = SetPortConfig + joinOffset;
Connect = Connect + joinOffset;
Connected = Connected + joinOffset;
Status = Status + joinOffset;
}
}
} }
///// <summary> ///// <summary>
///// /////