[DW] Alarmsensor added

This commit is contained in:
BlubbFish 2017-12-29 13:09:52 +00:00
parent beea6c1ee0
commit 8dd8605d73
5 changed files with 135 additions and 7 deletions

View File

@ -0,0 +1,62 @@
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Text.RegularExpressions;
using BlubbFish.IoT.Zway.Devices.CommandClasses.CommandClassSubs;
using BlubbFish.IoT.Zway.Events;
using BlubbFish.IoT.Zway.Interfaces;
using BlubbFish.IoT.Zway.lib;
using LitJson;
namespace BlubbFish.IoT.Zway.Devices.CommandClasses {
/// <summary>
/// 50 = Meter
/// </summary>
public class Alarmsensor : ACommandClass {
public override event UpdatedValue Update;
public Alarmsensor(JsonData json, Tuple<Int32, Int32, Classes> id, HttpConnection http, Boolean polling) : base(json, id, http, polling) {
this.HasSub = true;
this.InitComplex(json);
foreach (KeyValuePair<Int32, ACommandClass> item in this.Sub) {
item.Value.Update += this.DeviceUpdate;
}
}
private void DeviceUpdate(Object sender, DeviceUpdateEvent e) {
this.Update?.Invoke(this, e);
}
internal override void SetUpdate(JsonData json, Match match) {
if (match.Groups[4].Value.StartsWith(".data.")) {
Int32 subid = Int32.Parse(match.Groups[5].Value);
if (this.Sub.ContainsKey(subid)) {
this.Sub[subid].SetUpdate(json, match);
}
} else {
Helper.WriteError("Kenne in " + this.Name + " [" + this.Id + "] " + match.Groups[4].Value + " nicht!");
}
}
private void InitComplex(JsonData json) {
if (json.Keys.Contains("data")) {
JsonData data = json["data"];
Dictionary<Int32, ACommandClass> subs = new Dictionary<Int32, ACommandClass>();
foreach (String item in data.Keys) {
if (Int32.TryParse(item, out Int32 subid) &&
data[item].Keys.Contains("srcId") &&
data[item].Keys.Contains("sensorState") &&
data[item].Keys.Contains("sensorTime") &&
data[item].Keys.Contains("typeString")) {
subs.Add(subid, new Alarmsensorsub(data[item], new Tuple<Int32, Int32, Classes, Int32>(this.DeviceId, this.Instance, this.Commandclass, subid), this.http, this.Polling));
}
}
this.Sub = new ReadOnlyDictionary<Int32, ACommandClass>(subs);
}
}
internal override void Poll() => this.PollSubGlobal();
public override Dictionary<String, Object> ToDictionary() => this.ToDictionarySub();
}
}

View File

@ -0,0 +1,64 @@
using System;
using System.Collections.Generic;
using System.Text.RegularExpressions;
using BlubbFish.IoT.Zway.Events;
using BlubbFish.IoT.Zway.Interfaces;
using BlubbFish.IoT.Zway.lib;
using LitJson;
namespace BlubbFish.IoT.Zway.Devices.CommandClasses.CommandClassSubs {
public class Alarmsensorsub : ACommandClass {
public override event UpdatedValue Update;
public Int32 Source { get; private set; }
public Int32 Level { get; private set; }
public Int32 Time { get; private set; }
public String Type { get; private set; }
public Alarmsensorsub(JsonData json, Tuple<Int32, Int32, Classes, Int32> id, HttpConnection http, Boolean polling) : base(json, id, http, polling) {
this.IsSub = true;
InitComplex(json);
}
private void InitComplex(JsonData json) {
if (json.Keys.Contains("srcId") && json["srcId"].Keys.Contains("value") &&
json.Keys.Contains("sensorState") && json["sensorState"].Keys.Contains("value") &&
json.Keys.Contains("sensorTime") && json["sensorTime"].Keys.Contains("value") &&
json.Keys.Contains("typeString") && json["typeString"].Keys.Contains("value")) {
this.Source = Int32.Parse(json["srcId"]["value"].ToString());
this.Level = Int32.Parse(json["sensorState"]["value"].ToString());
this.Time = Int32.Parse(json["sensorTime"]["value"].ToString());
this.Type = json["typeString"]["value"].ToString();
}
}
internal override void SetUpdate(JsonData json, Match match) {
if (json.Keys.Contains("srcId") && json["srcId"].Keys.Contains("value") &&
json.Keys.Contains("sensorState") && json["sensorState"].Keys.Contains("value") &&
json.Keys.Contains("sensorTime") && json["sensorTime"].Keys.Contains("value") &&
json.Keys.Contains("typeString") && json["typeString"].Keys.Contains("value") &&
this.CheckSetUpdateTime(json)) {
this.Source = Int32.Parse(json["srcId"]["value"].ToString());
this.Level = Int32.Parse(json["sensorState"]["value"].ToString());
this.Time = Int32.Parse(json["sensorTime"]["value"].ToString());
this.Type = json["typeString"]["value"].ToString();
this.Update?.Invoke(this, new DeviceUpdateEvent(new Tuple<Int32, Int32, Int32, String>(this.Source, this.Level, this.Time, this.Type), this.LastUpdate, this));
}
}
public override String ToString() {
return "AlarmSensor " + this.Name + " [" + this.Id + "]: " + this.Type + " " + this.Source + " " + this.Level + " " + this.Time + " " + this.Type;
}
internal override void Poll() => this.PollNone();
public override Dictionary<String, Object> ToDictionary() {
return new Dictionary<String, Object> {
{ "Source", this.Source },
{ "Level", this.Level },
{ "Time", this.Time },
{ "Type", this.Type }
};
}
}
}

View File

@ -36,8 +36,7 @@ namespace BlubbFish.IoT.Zway.Interfaces {
Proprietary = 136, Proprietary = 136,
MultiChannelAssociation = 142, MultiChannelAssociation = 142,
MultiCmd = 143, MultiCmd = 143,
Security = 152, Security = 152
AlarmSensor = 156 //
} }
public enum Classes : Int32 { public enum Classes : Int32 {
@ -54,7 +53,8 @@ namespace BlubbFish.IoT.Zway.Interfaces {
Alarm = 113, Alarm = 113,
Battery = 128, Battery = 128,
Wakeup = 132, Wakeup = 132,
Indicator = 135 Indicator = 135,
AlarmSensor = 156
} }
public Int32 DeviceId { get; } public Int32 DeviceId { get; }

View File

@ -9,8 +9,9 @@
<AppDesignerFolder>Properties</AppDesignerFolder> <AppDesignerFolder>Properties</AppDesignerFolder>
<RootNamespace>BlubbFish.IoT.Zway</RootNamespace> <RootNamespace>BlubbFish.IoT.Zway</RootNamespace>
<AssemblyName>Zway</AssemblyName> <AssemblyName>Zway</AssemblyName>
<TargetFrameworkVersion>v4.6.1</TargetFrameworkVersion> <TargetFrameworkVersion>v4.7.1</TargetFrameworkVersion>
<FileAlignment>512</FileAlignment> <FileAlignment>512</FileAlignment>
<TargetFrameworkProfile />
</PropertyGroup> </PropertyGroup>
<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' "> <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|AnyCPU' ">
<DebugSymbols>true</DebugSymbols> <DebugSymbols>true</DebugSymbols>
@ -31,7 +32,7 @@
</PropertyGroup> </PropertyGroup>
<ItemGroup> <ItemGroup>
<Reference Include="LitJson, Version=0.9.0.0, Culture=neutral, processorArchitecture=MSIL"> <Reference Include="LitJson, Version=0.9.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>..\..\IoT-Bot\packages\LitJson.0.9.0\lib\LitJson.dll</HintPath> <HintPath>..\packages\LitJson.0.9.0\lib\LitJson.dll</HintPath>
</Reference> </Reference>
<Reference Include="System" /> <Reference Include="System" />
<Reference Include="System.Core" /> <Reference Include="System.Core" />
@ -46,11 +47,13 @@
<Compile Include="Devices\CommandClasses\Alarm.cs" /> <Compile Include="Devices\CommandClasses\Alarm.cs" />
<Compile Include="Devices\CommandClasses\Battery.cs" /> <Compile Include="Devices\CommandClasses\Battery.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\Configurationsub.cs" /> <Compile Include="Devices\CommandClasses\CommandClassSubs\Configurationsub.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\Alarmsensorsub.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\SceneControllerConfSub.cs" /> <Compile Include="Devices\CommandClasses\CommandClassSubs\SceneControllerConfSub.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\SensorBinarySub.cs" /> <Compile Include="Devices\CommandClasses\CommandClassSubs\SensorBinarySub.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\ThermostatSetPointSub.cs" /> <Compile Include="Devices\CommandClasses\CommandClassSubs\ThermostatSetPointSub.cs" />
<Compile Include="Devices\CommandClasses\Configuration.cs" /> <Compile Include="Devices\CommandClasses\Configuration.cs" />
<Compile Include="Devices\CommandClasses\Indicator.cs" /> <Compile Include="Devices\CommandClasses\Indicator.cs" />
<Compile Include="Devices\CommandClasses\AlarmSensor.cs" />
<Compile Include="Devices\CommandClasses\Meter.cs" /> <Compile Include="Devices\CommandClasses\Meter.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\MeterSub.cs" /> <Compile Include="Devices\CommandClasses\CommandClassSubs\MeterSub.cs" />
<Compile Include="Devices\CommandClasses\CommandClassSubs\SensorMultilevelSub.cs" /> <Compile Include="Devices\CommandClasses\CommandClassSubs\SensorMultilevelSub.cs" />
@ -76,6 +79,5 @@
<ItemGroup> <ItemGroup>
<None Include="packages.config" /> <None Include="packages.config" />
</ItemGroup> </ItemGroup>
<ItemGroup />
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" /> <Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
</Project> </Project>

View File

@ -1,4 +1,4 @@
<?xml version="1.0" encoding="utf-8"?> <?xml version="1.0" encoding="utf-8"?>
<packages> <packages>
<package id="LitJson" version="0.9.0" targetFramework="net461" /> <package id="LitJson" version="0.9.0" targetFramework="net471" />
</packages> </packages>