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( () =>
{
Debug.Console(1, this, "Linking Devices...");
foreach (var d in PropertiesConfig.Devices)
{
var device = DeviceManager.GetDeviceForKey(d.DeviceKey);
@@ -73,10 +75,13 @@ namespace PepperDash.Essentials.Bridges
{
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)
{
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;
if (uo is Action<bool>)
(uo as Action<bool>)(args.Sig.BoolValue);
@@ -114,6 +119,9 @@ namespace PepperDash.Essentials.Bridges
[JsonProperty("joinStart")]
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 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
comm.CommPort.TextReceived += (s, a) => trilist.SetString(joinStart, a.Text);
trilist.SetStringSigAction(joinStart, new Action<string>(s => comm.CommPort.SendText(s)));
trilist.SetStringSigAction(joinStart + 1, new Action<string>(s => comm.SetPortConfig(s)));
comm.CommPort.TextReceived += (s, a) => trilist.SetString(joinMap.TextReceived, a.Text);
trilist.SetStringSigAction(joinMap.SendText, new Action<string>(s => comm.CommPort.SendText(s)));
trilist.SetStringSigAction(joinMap.SetPortConfig + 1, new Action<string>(s => comm.SetPortConfig(s)));
var sComm = comm.CommPort as ISocketStatus;
@@ -26,12 +41,12 @@ namespace PepperDash.Essentials.Bridges
{
sComm.ConnectionChange += (s, a) =>
{
trilist.SetUshort(joinStart, (ushort)(a.Client.ClientStatus));
trilist.SetBool(joinStart, a.Client.ClientStatus ==
trilist.SetUshort(joinMap.Status, (ushort)(a.Client.ClientStatus));
trilist.SetBool(joinMap.Connected, a.Client.ClientStatus ==
Crestron.SimplSharp.CrestronSockets.SocketStatus.SOCKET_STATUS_CONNECTED);
};
trilist.SetBoolSigAction(joinStart, new Action<bool>(b =>
trilist.SetBoolSigAction(joinMap.Connect, new Action<bool>(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>
/////