Zway [v1.5.0] Throw Exception if 3 times failed to connect to Raspberry server, add 3 new commandlcasses to IgnoredClasses
Zway-Bot [v1.7.0] rewrite to Threaded Modules, edit service file for systemd
This commit is contained in:
parent
c47895e6bb
commit
af7eeeaf15
@ -10,7 +10,7 @@ using LitJson;
|
|||||||
namespace BlubbFish.IoT.Zway.Devices {
|
namespace BlubbFish.IoT.Zway.Devices {
|
||||||
public class Instance {
|
public class Instance {
|
||||||
private DateTime nextwakeup;
|
private DateTime nextwakeup;
|
||||||
private Boolean polling;
|
private readonly Boolean polling;
|
||||||
|
|
||||||
public delegate void UpdatedInstance(Object sender, DeviceUpdateEvent e);
|
public delegate void UpdatedInstance(Object sender, DeviceUpdateEvent e);
|
||||||
public event UpdatedInstance Update;
|
public event UpdatedInstance Update;
|
||||||
|
@ -31,18 +31,21 @@ namespace BlubbFish.IoT.Zway.Interfaces {
|
|||||||
ZWavePlusInfo = 94,
|
ZWavePlusInfo = 94,
|
||||||
MultiChannel = 96,
|
MultiChannel = 96,
|
||||||
DoorLock = 98,
|
DoorLock = 98,
|
||||||
|
BarrierOperator = 102,
|
||||||
ManufacturerSpecific = 114,
|
ManufacturerSpecific = 114,
|
||||||
PowerLevel = 115,
|
PowerLevel = 115,
|
||||||
InclusionController = 116,
|
InclusionController = 116,
|
||||||
Protection = 117,
|
Protection = 117,
|
||||||
NodeNaming = 119,
|
NodeNaming = 119,
|
||||||
FirmwareUpdate = 122,
|
FirmwareUpdate = 122,
|
||||||
|
Clock = 129,
|
||||||
Association = 133,
|
Association = 133,
|
||||||
Version = 134,
|
Version = 134,
|
||||||
Proprietary = 136,
|
Proprietary = 136,
|
||||||
TimeParameters = 139,
|
TimeParameters = 139,
|
||||||
MultiChannelAssociation = 142,
|
MultiChannelAssociation = 142,
|
||||||
MultiCmd = 143,
|
MultiCmd = 143,
|
||||||
|
SimpleAVControl = 148,
|
||||||
Security = 152
|
Security = 152
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ using System.Runtime.InteropServices;
|
|||||||
[assembly: AssemblyConfiguration("")]
|
[assembly: AssemblyConfiguration("")]
|
||||||
[assembly: AssemblyCompany("")]
|
[assembly: AssemblyCompany("")]
|
||||||
[assembly: AssemblyProduct("Zway")]
|
[assembly: AssemblyProduct("Zway")]
|
||||||
[assembly: AssemblyCopyright("Copyright © 2017 - 03.05.2018")]
|
[assembly: AssemblyCopyright("Copyright © 2017 - 29.09.2018")]
|
||||||
[assembly: AssemblyTrademark("")]
|
[assembly: AssemblyTrademark("")]
|
||||||
[assembly: AssemblyCulture("")]
|
[assembly: AssemblyCulture("")]
|
||||||
|
|
||||||
@ -32,5 +32,5 @@ using System.Runtime.InteropServices;
|
|||||||
// Sie können alle Werte angeben oder Standardwerte für die Build- und Revisionsnummern verwenden,
|
// Sie können alle Werte angeben oder Standardwerte für die Build- und Revisionsnummern verwenden,
|
||||||
// indem Sie "*" wie unten gezeigt eingeben:
|
// indem Sie "*" wie unten gezeigt eingeben:
|
||||||
// [assembly: AssemblyVersion("1.0.*")]
|
// [assembly: AssemblyVersion("1.0.*")]
|
||||||
[assembly: AssemblyVersion("1.4.4")]
|
[assembly: AssemblyVersion("1.5.0")]
|
||||||
[assembly: AssemblyFileVersion("1.4.4")]
|
[assembly: AssemblyFileVersion("1.5.0")]
|
||||||
|
@ -104,9 +104,11 @@ namespace BlubbFish.IoT.Zway {
|
|||||||
CultureInfo.DefaultThreadCurrentUICulture = info;
|
CultureInfo.DefaultThreadCurrentUICulture = info;
|
||||||
Thread.CurrentThread.CurrentCulture = info;
|
Thread.CurrentThread.CurrentCulture = info;
|
||||||
Thread.CurrentThread.CurrentUICulture = info;
|
Thread.CurrentThread.CurrentUICulture = info;
|
||||||
|
DateTime lastRequest = DateTime.Now.AddSeconds(-2);
|
||||||
while (true) {
|
while (true) {
|
||||||
Int64 date = ((DateTimeOffset)DateTime.Now.AddSeconds(-2)).ToUnixTimeSeconds();
|
Int64 date = ((DateTimeOffset)lastRequest).ToUnixTimeSeconds();
|
||||||
JsonData notifications = this.http.GetJson("ZWave.zway/Data/"+date);
|
lastRequest = DateTime.Now;
|
||||||
|
JsonData notifications = this.http.GetJson("ZWave.zway/Data/" + date);
|
||||||
foreach (String item in notifications.Keys) {
|
foreach (String item in notifications.Keys) {
|
||||||
Match match = new Regex("^devices\\.([0-9]+)\\.instances\\.([0-9]+)\\.commandClasses\\.([0-9]+)(\\.data\\.([0-9]+)|\\.data\\.[a-z].*|\\.data)$", RegexOptions.IgnoreCase).Match(item);
|
Match match = new Regex("^devices\\.([0-9]+)\\.instances\\.([0-9]+)\\.commandClasses\\.([0-9]+)(\\.data\\.([0-9]+)|\\.data\\.[a-z].*|\\.data)$", RegexOptions.IgnoreCase).Match(item);
|
||||||
if(match.Success) {
|
if(match.Success) {
|
||||||
|
Binary file not shown.
@ -8,7 +8,7 @@ namespace BlubbFish.IoT.Zway.lib {
|
|||||||
public class HttpConnection {
|
public class HttpConnection {
|
||||||
private readonly String auth;
|
private readonly String auth;
|
||||||
private readonly String server;
|
private readonly String server;
|
||||||
private readonly Object getLock = new Object();
|
private static readonly Object getLock = new Object();
|
||||||
|
|
||||||
internal HttpConnection(String server, String user, String pass) {
|
internal HttpConnection(String server, String user, String pass) {
|
||||||
this.auth = "Basic " + Convert.ToBase64String(Encoding.ASCII.GetBytes(user + ":" + pass));
|
this.auth = "Basic " + Convert.ToBase64String(Encoding.ASCII.GetBytes(user + ":" + pass));
|
||||||
@ -17,11 +17,23 @@ namespace BlubbFish.IoT.Zway.lib {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void Init() {
|
private void Init() {
|
||||||
this.GetString("ZAutomation/api/v1/status");
|
this.GetVoid("ZAutomation/api/v1/status");
|
||||||
}
|
}
|
||||||
|
|
||||||
internal JsonData GetJson(String v) {
|
internal JsonData GetJson(String v) {
|
||||||
String text = this.GetString(v);
|
String text = null;
|
||||||
|
for (Int32 i = 0; i < 3; i++) {
|
||||||
|
try {
|
||||||
|
text = this.GetString(v);
|
||||||
|
break;
|
||||||
|
} catch (Exception e) {
|
||||||
|
Helper.WriteError(e.Message);
|
||||||
|
if(i==2) {
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
System.Threading.Thread.Sleep(30000);
|
||||||
|
}
|
||||||
|
}
|
||||||
if(text == null) {
|
if(text == null) {
|
||||||
return new JsonData();
|
return new JsonData();
|
||||||
}
|
}
|
||||||
@ -33,14 +45,25 @@ namespace BlubbFish.IoT.Zway.lib {
|
|||||||
}
|
}
|
||||||
|
|
||||||
internal void GetVoid(String v) {
|
internal void GetVoid(String v) {
|
||||||
|
for (Int32 i = 0; i < 3; i++) {
|
||||||
|
try {
|
||||||
this.GetString(v, false);
|
this.GetString(v, false);
|
||||||
|
break;
|
||||||
|
} catch (Exception e) {
|
||||||
|
Helper.WriteError(e.Message);
|
||||||
|
if (i == 2) {
|
||||||
|
throw;
|
||||||
|
}
|
||||||
|
System.Threading.Thread.Sleep(30000);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private String GetString(String v, Boolean withoutput = true) {
|
private String GetString(String v, Boolean withoutput = true) {
|
||||||
String ret = null;
|
String ret = null;
|
||||||
lock (this.getLock) {
|
lock (getLock) {
|
||||||
HttpWebRequest request = WebRequest.CreateHttp(this.server + v);
|
HttpWebRequest request = WebRequest.CreateHttp(this.server + v);
|
||||||
request.Timeout = 5000;
|
request.Timeout = 10000;
|
||||||
request.Headers.Add(HttpRequestHeader.Authorization, this.auth);
|
request.Headers.Add(HttpRequestHeader.Authorization, this.auth);
|
||||||
try {
|
try {
|
||||||
using (HttpWebResponse response = (HttpWebResponse)request.GetResponse()) {
|
using (HttpWebResponse response = (HttpWebResponse)request.GetResponse()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user