mirror of
https://github.com/fhem/fhem-mirror.git
synced 2025-04-06 06:08:44 +00:00
00_SIGNALduino.pm Version 3.3.3
feature: getAvailableFirmware returns only version for which a file could be found. change: Attribute hardware does not longer support nano. select nano328 instead feature: new webmenu "Display protocollist" feature: Serval new protocols added feature: New Oregon V3 sensors suppored. feature: Firmware for avr boards can be downloaded and flashed on demand from gitghub releases feature: supports dupTimeout on same iodev Protocol definitions are now located in sepaerate file: FHEM/lib/signalduino_protocols.hash git-svn-id: https://svn.fhem.de/fhem/trunk@18676 2b470e98-0d58-463d-a4d8-8e2adae1ed80
This commit is contained in:
parent
9db6763760
commit
e3f38508ed
@ -1,5 +1,14 @@
|
|||||||
# Add changes at the top of the list. Keep it in ASCII, and 80-char wide.
|
# Add changes at the top of the list. Keep it in ASCII, and 80-char wide.
|
||||||
# Do not insert empty lines here, update check depends on it.
|
# Do not insert empty lines here, update check depends on it.
|
||||||
|
- feature: 00_SIGNALduino:
|
||||||
|
new webmenu "Display protocollist".
|
||||||
|
Serval new protocols added.
|
||||||
|
New Oregon V3 sensors suppored.
|
||||||
|
Firmware for avr boards can be downloaded and flashed.
|
||||||
|
on demand from gitghub releases.
|
||||||
|
supports dupTimeout on same iodev
|
||||||
|
change: 00_SIGNALduino: Attribute hardware does not longer support nano
|
||||||
|
select nano328 instead
|
||||||
- feature: 14_SD_RSL: Updated implementation for "all" button on devices
|
- feature: 14_SD_RSL: Updated implementation for "all" button on devices
|
||||||
- feature: 14_SD_WS: support sensors E0001PA,S522,TX-EZ6,other
|
- feature: 14_SD_WS: support sensors E0001PA,S522,TX-EZ6,other
|
||||||
reading sendmode humidityTrend, temperatureTrend,
|
reading sendmode humidityTrend, temperatureTrend,
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -1,10 +1,10 @@
|
|||||||
##############################################
|
##############################################
|
||||||
# $Id$
|
# $Id$
|
||||||
|
#
|
||||||
# The file is part of the SIGNALduino project
|
# The file is part of the SIGNALduino project
|
||||||
# see http://www.fhemwiki.de/wiki/SIGNALduino
|
# see http://www.fhemwiki.de/wiki/SIGNALduino to support debugging of unknown signal data
|
||||||
# to support debugging of unknown signal data
|
|
||||||
# The purpos is to use it as addition to the SIGNALduino
|
# The purpos is to use it as addition to the SIGNALduino
|
||||||
# S. Butzek, 2015
|
# S. Butzek, 2015 | HomeAuto_User & elektron-bbs - 2018
|
||||||
#
|
#
|
||||||
|
|
||||||
package main;
|
package main;
|
||||||
@ -12,6 +12,9 @@ package main;
|
|||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use POSIX;
|
use POSIX;
|
||||||
|
use List::Util qw(any); # for any function
|
||||||
|
|
||||||
|
my @bitcountlength = (0,0,0); # array min|default|max
|
||||||
|
|
||||||
#####################################
|
#####################################
|
||||||
sub
|
sub
|
||||||
@ -20,15 +23,15 @@ SIGNALduino_un_Initialize($)
|
|||||||
my ($hash) = @_;
|
my ($hash) = @_;
|
||||||
|
|
||||||
|
|
||||||
$hash->{Match} = '^[uP]\d+#.*';
|
$hash->{Match} = '^[u]\d+#.*';
|
||||||
$hash->{DefFn} = "SIGNALduino_un_Define";
|
$hash->{DefFn} = "SIGNALduino_un_Define";
|
||||||
$hash->{UndefFn} = "SIGNALduino_un_Undef";
|
$hash->{UndefFn} = "SIGNALduino_un_Undef";
|
||||||
$hash->{AttrFn} = "SIGNALduino_un_Attr";
|
$hash->{AttrFn} = "SIGNALduino_un_Attr";
|
||||||
|
$hash->{SetFn} = "SIGNALduino_un_Set";
|
||||||
$hash->{ParseFn} = "SIGNALduino_un_Parse";
|
$hash->{ParseFn} = "SIGNALduino_un_Parse";
|
||||||
$hash->{AttrList} = "IODev do_not_notify:0,1 showtime:0,1 ignore:0,1 ".$readingFnAttributes;
|
$hash->{AttrList} = "IODev do_not_notify:0,1 stateFormat showtime:0,1 ignore:0,1 ".$readingFnAttributes;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#####################################
|
#####################################
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_Define($$)
|
SIGNALduino_un_Define($$)
|
||||||
@ -36,20 +39,25 @@ SIGNALduino_un_Define($$)
|
|||||||
my ($hash, $def) = @_;
|
my ($hash, $def) = @_;
|
||||||
my @a = split("[ \t][ \t]*", $def);
|
my @a = split("[ \t][ \t]*", $def);
|
||||||
|
|
||||||
return "wrong syntax: define <name> SIGNALduino_un <code> <minsecs> <equalmsg>".int(@a)
|
return " wrong syntax: define <name> SIGNALduino_un <code> <optional IODEV> (".int(@a).")" if(int(@a) < 3 || int(@a) > 4);
|
||||||
if(int(@a) < 3 || int(@a) > 5);
|
|
||||||
|
|
||||||
$hash->{CODE} = $a[2];
|
|
||||||
$hash->{minsecs} = ((int(@a) > 3) ? $a[3] : 30);
|
|
||||||
$hash->{equalMSG} = ((int(@a) > 4) ? $a[4] : 0);
|
|
||||||
$hash->{lastMSG} = "";
|
$hash->{lastMSG} = "";
|
||||||
$hash->{bitMSG} = "";
|
$hash->{bitMSG} = "";
|
||||||
|
|
||||||
$modules{SIGNALduino_un}{defptr}{$a[2]} = $hash;
|
|
||||||
$hash->{STATE} = "Defined";
|
$hash->{STATE} = "Defined";
|
||||||
|
my $name = $hash->{NAME};
|
||||||
AssignIoPort($hash);
|
|
||||||
return undef;
|
my $iodevice = $a[3] if($a[3]);
|
||||||
|
$modules{SIGNALduino_un}{defptr}{$a[2]} = $hash;
|
||||||
|
|
||||||
|
my $ioname = $modules{SIGNALduino_un}{defptr}{ioname} if (exists $modules{SIGNALduino_un}{defptr}{ioname} && not $iodevice);
|
||||||
|
$iodevice = $ioname if not $iodevice;
|
||||||
|
|
||||||
|
### Attributes ###
|
||||||
|
if ( $init_done == 1 ) {
|
||||||
|
$attr{$name}{stateFormat} = "{ReadingsVal('$name', 'state', '').' | '.ReadingsTimestamp('$name', 'state', '-');}" if( not defined( $attr{$name}{stateformat} ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
AssignIoPort($hash, $iodevice);
|
||||||
}
|
}
|
||||||
|
|
||||||
#####################################
|
#####################################
|
||||||
@ -57,10 +65,12 @@ sub
|
|||||||
SIGNALduino_un_Undef($$)
|
SIGNALduino_un_Undef($$)
|
||||||
{
|
{
|
||||||
my ($hash, $name) = @_;
|
my ($hash, $name) = @_;
|
||||||
delete($modules{SIGNALduino_un}{defptr}{$hash->{CODE}}) if($hash && $hash->{CODE});
|
delete($modules{SIGNALduino_un}{defptr}{$hash->{DEF}}) if($hash && $hash->{DEF});
|
||||||
|
delete($modules{SIGNALduino_un}{defptr}{ioname}) if (exists $modules{SIGNALduino_un}{defptr}{ioname});
|
||||||
return undef;
|
return undef;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
sub SIGNALduino_un_hex2bin {
|
sub SIGNALduino_un_hex2bin {
|
||||||
my $h = shift;
|
my $h = shift;
|
||||||
my $hlen = length($h);
|
my $hlen = length($h);
|
||||||
@ -68,7 +78,6 @@ sub SIGNALduino_un_hex2bin {
|
|||||||
return unpack("B$blen", pack("H$hlen", $h));
|
return unpack("B$blen", pack("H$hlen", $h));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#####################################
|
#####################################
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_Parse($$)
|
SIGNALduino_un_Parse($$)
|
||||||
@ -76,6 +85,7 @@ SIGNALduino_un_Parse($$)
|
|||||||
my ($hash,$msg) = @_;
|
my ($hash,$msg) = @_;
|
||||||
my @a = split("", $msg);
|
my @a = split("", $msg);
|
||||||
my $name = "SIGNALduino_unknown";# $hash->{NAME};
|
my $name = "SIGNALduino_unknown";# $hash->{NAME};
|
||||||
|
my $ioname = $hash->{NAME};
|
||||||
Log3 $hash, 4, "$name incomming msg: $msg";
|
Log3 $hash, 4, "$name incomming msg: $msg";
|
||||||
#my $rawData=substr($msg,2);
|
#my $rawData=substr($msg,2);
|
||||||
|
|
||||||
@ -92,50 +102,7 @@ SIGNALduino_un_Parse($$)
|
|||||||
my $bitData= unpack("B$blen", pack("H$hlen", $rawData));
|
my $bitData= unpack("B$blen", pack("H$hlen", $rawData));
|
||||||
Log3 $hash, 4, "$name converted to bits: $bitData";
|
Log3 $hash, 4, "$name converted to bits: $bitData";
|
||||||
|
|
||||||
if ($protocol == "7" && length($bitData)>=36) ## Unknown Proto 7
|
if ($protocol == "6" && length($bitData)>=36) ## Eurochron
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
## Try TX70DTH Decoding
|
|
||||||
my $SensorTyp = "TX70DTH";
|
|
||||||
my $channel = SIGNALduino_un_bin2dec(substr($bitData,9,3));
|
|
||||||
my $bin = substr($bitData,0,8);
|
|
||||||
my $id = sprintf('%X', oct("0b$bin"));
|
|
||||||
my $bat = int(substr($bitData,8,1)) eq "1" ? "ok" : "critical";
|
|
||||||
my $trend = "";
|
|
||||||
my $sendMode = "";
|
|
||||||
my $temp = SIGNALduino_un_bin2dec(substr($bitData,16,8));
|
|
||||||
if (substr($bitData,14,1) eq "1") {
|
|
||||||
$temp = $temp - 1024;
|
|
||||||
}
|
|
||||||
$temp = $temp / 10;
|
|
||||||
my $hum = SIGNALduino_un_bin2dec(substr($bitData,29,7));
|
|
||||||
my $val = "T: $temp H: $hum B: $bat";
|
|
||||||
Log3 $hash, 4, "$name decoded protocolid: 7 ($SensorTyp) sensor id=$id, channel=$channel, temp=$temp, hum=$hum, bat=$bat\n" ;
|
|
||||||
|
|
||||||
|
|
||||||
# Try Eurochron EAS 800
|
|
||||||
# 4 8 12 24 28 36
|
|
||||||
# 0011 0110 1010 000100000010 1111 00111000 0000 Kanal 3, 25.8 Grad, 56%
|
|
||||||
# 0011 0110 1010 000011110011 1111 00111000 0000 Kanal 3, 24.3 Grad, 56%
|
|
||||||
# 0011 0001 1001 000100001001 1111 00111101 0000 Kanal 2, 26.5 Grad, 61%
|
|
||||||
# 0011 1000 1000 000100000011 1111 01000000 0000 Kanal 1
|
|
||||||
|
|
||||||
# ID? CHN TMP ?? HUM
|
|
||||||
$SensorTyp = "EAS800z";
|
|
||||||
$id = oct ("0b".substr($bitData,4,4));
|
|
||||||
$channel = SIGNALduino_un_bin2dec(substr($bitData,9,3))+1;
|
|
||||||
$temp = oct ("0b".substr($bitData,12,12))/10;
|
|
||||||
$bat = int(substr($bitData,8,1)) eq "1" ? "ok" : "critical"; # Eventuell falsch!
|
|
||||||
$hum = SIGNALduino_un_bin2dec(substr($bitData,28,8));
|
|
||||||
$sendMode = int(substr($bitData,4,1)) eq "1" ? "auto" : "manual"; # Eventuell falsch!
|
|
||||||
my $type = SIGNALduino_un_bin2dec(substr($bitData,0,4));
|
|
||||||
|
|
||||||
Log3 $hash, 4, "$name decoded protocolid: 7 ($SensorTyp / type=$type) mode=$sendMode, sensor id=$id, channel=$channel, temp=$temp, hum=$hum, bat=$bat\n" ;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
} elsif ($protocol == "6" && length($bitData)>=36) ## Eurochron
|
|
||||||
{
|
{
|
||||||
|
|
||||||
# EuroChron / Tchibo
|
# EuroChron / Tchibo
|
||||||
@ -166,78 +133,14 @@ SIGNALduino_un_Parse($$)
|
|||||||
my $val = "T: $temp H: $hum B: $bat";
|
my $val = "T: $temp H: $hum B: $bat";
|
||||||
Log3 $hash, 4, "$name decoded protocolid: 6 $SensorTyp, sensor id=$id, channel=$channel, temp=$temp\n" ;
|
Log3 $hash, 4, "$name decoded protocolid: 6 $SensorTyp, sensor id=$id, channel=$channel, temp=$temp\n" ;
|
||||||
|
|
||||||
} elsif ($protocol == "9" && length($bitData)>=70) ## Unknown Proto 9
|
} elsif ($protocol == "15" && length($bitData)>=64) ## TCM
|
||||||
{ #http://nupo-artworks.de/media/report.pdf
|
|
||||||
|
|
||||||
my $syncpos= index($bitData,"11111110"); #7x1 1x0 preamble
|
|
||||||
|
|
||||||
if ($syncpos ==-1 || length($bitData)-$syncpos < 68)
|
|
||||||
{
|
|
||||||
Log3 $hash, 4, "$name ctw600 not found, aborting";
|
|
||||||
return undef;
|
|
||||||
}
|
|
||||||
my $sensdata = substr($bitData,$syncpos+8);
|
|
||||||
|
|
||||||
my $bat = substr($sensdata,0,3);
|
|
||||||
my $id = substr($sensdata,4,6);
|
|
||||||
my $temp = substr($sensdata,12,10);
|
|
||||||
my $hum = substr($sensdata,22,8);
|
|
||||||
my $wind = substr($sensdata,30,16);
|
|
||||||
my $rain = substr($sensdata,46,16);
|
|
||||||
my $winddir = substr($sensdata,66,4);
|
|
||||||
|
|
||||||
Log3 $hash, 4, "$name found ctw600 syncpos at $syncpos message is: $sensdata - sensor id:$id, bat:$bat, temp=$temp, hum=$hum, wind=$wind, rain=$rain, winddir=$winddir";
|
|
||||||
|
|
||||||
} elsif ($protocol == "13" && length($bitData)>=14) ## RF21 Protocol
|
|
||||||
{
|
|
||||||
#my $model=$a[3];
|
|
||||||
#my $deviceCode = $a[5].$a[6].$a[7].$a[8].$a[9];
|
|
||||||
#my $Freq = $a[10].$a[11].$a[12].$a[13].$a[14];
|
|
||||||
my $deviceCode = substr($bitData,0,23);
|
|
||||||
my $unit= substr($bitData,23,1);
|
|
||||||
|
|
||||||
|
|
||||||
Log3 $hash, 4, "$name found RF21 protocol. devicecode=$deviceCode, unit=$unit";
|
|
||||||
}
|
|
||||||
elsif ($protocol == "14" && length($bitData)>=12) ## Heidman HX
|
|
||||||
{
|
|
||||||
|
|
||||||
my $bin = substr($bitData,0,4);
|
|
||||||
my $deviceCode = sprintf('%X', oct("0b$bin"));
|
|
||||||
my $sound = substr($bitData,7,5);
|
|
||||||
|
|
||||||
Log3 $hash, 4, "$name found Heidman HX doorbell. devicecode=$deviceCode, sound=$sound";
|
|
||||||
|
|
||||||
}
|
|
||||||
elsif ($protocol == "15" && length($bitData)>=64) ## TCM
|
|
||||||
{
|
{
|
||||||
my $deviceCode = $a[4].$a[5].$a[6].$a[7].$a[8];
|
my $deviceCode = $a[4].$a[5].$a[6].$a[7].$a[8];
|
||||||
|
|
||||||
|
|
||||||
Log3 $hash, 4, "$name found TCM doorbell. devicecode=$deviceCode";
|
Log3 $hash, 4, "$name found TCM doorbell. devicecode=$deviceCode";
|
||||||
|
|
||||||
}
|
} elsif ($protocol == "21" && length($bitData)>=32) ##Einhell doorshutter
|
||||||
elsif ($protocol == "16" && length($bitData)>=36) ##Rohrmotor24
|
|
||||||
{
|
|
||||||
Log3 $hash, 4, "$name / shutter Dooya $bitData received";
|
|
||||||
|
|
||||||
Log3 $hash,4, substr($bitData,0,23)." ".substr($bitData,24,4)." ".substr($bitData,28,4)." ".substr($bitData,32,4)." ".substr($bitData,36,4);
|
|
||||||
my $id = SIGNALduino_un_binaryToNumber($bitData,0,23);
|
|
||||||
my $remote = SIGNALduino_un_binaryToNumber($bitData,24,27);
|
|
||||||
my $channel = SIGNALduino_un_binaryToNumber($bitData,28,31);
|
|
||||||
|
|
||||||
my $all = ($channel == 0) ? "true" : "false";
|
|
||||||
my $commandcode = SIGNALduino_un_binaryToNumber($bitData,32,35);
|
|
||||||
my $direction="";
|
|
||||||
|
|
||||||
if ($commandcode == 0b0001) {$direction="up";}
|
|
||||||
elsif ($commandcode == 0b0011) {$direction="down";}
|
|
||||||
elsif ($commandcode == 0b0101) {$direction="stop";}
|
|
||||||
elsif ($commandcode == 0b1100) {$direction="learn";}
|
|
||||||
else { $direction="unknown";}
|
|
||||||
Log3 $hash, 4, "$name found shutter from Dooya. id=$id, remotetype=$remote, channel=$channel, direction=$direction, all_shutters=$all";
|
|
||||||
}
|
|
||||||
elsif ($protocol == "21" && length($bitData)>=32) ##Einhell doorshutter
|
|
||||||
{
|
{
|
||||||
Log3 $hash, 4, "$name / Einhell doorshutter received";
|
Log3 $hash, 4, "$name / Einhell doorshutter received";
|
||||||
|
|
||||||
@ -263,62 +166,152 @@ SIGNALduino_un_Parse($$)
|
|||||||
Log3 $hash, 4, "$name decoded protocolid: 7 ($SensorTyp / type=$type) mode=$sendMode, sensor id=$id, channel=$channel, temp=$temp, bat=$bat\n" ;
|
Log3 $hash, 4, "$name decoded protocolid: 7 ($SensorTyp / type=$type) mode=$sendMode, sensor id=$id, channel=$channel, temp=$temp, bat=$bat\n" ;
|
||||||
|
|
||||||
|
|
||||||
} elsif ($protocol == "33" && length($bitData)>=42) ## S014 or tcm sensor
|
} elsif ($protocol == "78" && length($bitData)>=14) ## geiger rohrmotor
|
||||||
{
|
{
|
||||||
my $SensorTyp = "s014/TFA 30.3200/TCM/Conrad";
|
my %bintotristate=(
|
||||||
|
"00" => "0",
|
||||||
|
"10" => "F",
|
||||||
|
"11" => "1"
|
||||||
|
);
|
||||||
|
|
||||||
|
my $tscode;
|
||||||
|
for (my $n=0; $n<length($bitData); $n=$n+2) {
|
||||||
|
$tscode = $tscode . $bintotristate{substr($bitData,$n,2)};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
my $id = SIGNALduino_un_binaryToNumber($bitData,0,9);
|
Log3 $hash, 4, "geiger message converted to tristate code: " . $tscode;
|
||||||
#my $unknown1 = SIGNALduino_un_binaryToNumber($bitData,8,10);
|
#Dispatch($hash, $tscode,undef);
|
||||||
my $sendMode = SIGNALduino_un_binaryToNumber($bitData,10,11) eq "1" ? "manual" : "auto";
|
|
||||||
|
|
||||||
my $channel = SIGNALduino_un_binaryToNumber($bitData,12,13)+1;
|
|
||||||
#my $temp = (((oct("0b".substr($bitData,22,4))*256) + (oct("0b".substr($bitData,18,4))*16) + (oct("0b".substr($bitData,14,4)))/10) - 90 - 32) * (5/9);
|
|
||||||
my $temp = (((SIGNALduino_un_binaryToNumber($bitData,22,25)*256 + SIGNALduino_un_binaryToNumber($bitData,18,21)*16 + SIGNALduino_un_binaryToNumber($bitData,14,17)) *10 -12200) /18)/10;
|
|
||||||
|
|
||||||
my $hum=SIGNALduino_un_binaryToNumber($bitData,30,33)*16 + SIGNALduino_un_binaryToNumber($bitData,26,29);
|
|
||||||
my $bat = SIGNALduino_un_binaryToBoolean($bitData,34) eq "1" ? "ok" : "critical"; # Eventuell falsch!
|
|
||||||
my $sync = SIGNALduino_un_binaryToBoolean($bitData,35,35) eq "1" ? "true" : "false";
|
|
||||||
my $unknown3 =SIGNALduino_un_binaryToNumber($bitData,36,37);
|
|
||||||
|
|
||||||
my $crc=substr($bitData,36,4);
|
|
||||||
|
|
||||||
|
|
||||||
Log3 $hash, 4, "$name decoded protocolid: $protocol ($SensorTyp ) mode=$sendMode, sensor id=$id, channel=$channel, temp=$temp, hum=$hum, bat=$bat, crc=$crc, sync=$sync, unkown3=$unknown3\n" ;
|
|
||||||
} elsif ($protocol == "37" && length($bitData)>=40) ## Bresser 7009993
|
|
||||||
{
|
|
||||||
|
|
||||||
# 0 7 8 9 10 12 22 25 31
|
|
||||||
# 01011010 0 0 01 01100001110 10 0111101 11001010
|
|
||||||
# ID B? T Kan Temp ?? Hum Pruefsumme?
|
|
||||||
#
|
|
||||||
|
|
||||||
my $SensorTyp = "Bresser 7009994";
|
|
||||||
|
|
||||||
my $id = SIGNALduino_un_binaryToNumber($bitData,0,7);
|
|
||||||
my $channel = SIGNALduino_un_binaryToNumber($bitData,10,11);
|
|
||||||
my $hum=SIGNALduino_un_binaryToNumber($bitData,25,31);
|
|
||||||
my $rawTemp = SIGNALduino_un_binaryToNumber($bitData,12,22);
|
|
||||||
my $temp = ($rawTemp - 609.93) / 9.014;
|
|
||||||
$temp = sprintf("%.2f", $temp);
|
|
||||||
|
|
||||||
my $bitData2 = substr($bitData,0,8) . ' ' . substr($bitData,8,4) . ' ' . substr($bitData,12,11);
|
|
||||||
$bitData2 = $bitData2 . ' ' . substr($bitData,23,2) . ' ' . substr($bitData,25,7) . ' ' . substr($bitData,32,8);
|
|
||||||
Log3 $hash, 4, "$name converted to bits: " . $bitData2;
|
|
||||||
Log3 $hash, 4, "$name decoded protocolid: $protocol ($SensorTyp) sensor id=$id, channel=$channel, rawTemp=$rawTemp, temp=$temp, hum=$hum";
|
|
||||||
|
|
||||||
|
|
||||||
} else {
|
|
||||||
Log3 $hash, 4, $dummyreturnvalue;
|
|
||||||
|
|
||||||
return undef;
|
} elsif ($protocol == "88" && length($rawData) == 17) {
|
||||||
|
my $serial = substr($bitData,32,28);
|
||||||
|
my $buttonbits = substr($bitData,60,4);
|
||||||
|
|
||||||
|
my %buttons = (
|
||||||
|
"0010" => "hoch",
|
||||||
|
"1001" => "runter",
|
||||||
|
"1000" => "stop"
|
||||||
|
);
|
||||||
|
|
||||||
|
Log3 $hash, 4, "$name: Roto shutter - Serialbits=$serial Serial=".oct( "0b$serial" )." Buttonbits=$buttonbits Button=$buttons{$buttonbits}";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
##############################################################################################
|
||||||
|
# version 1) message with u..# without development y attribut -> Unknown code u..# , help me!
|
||||||
|
# version 2) message with u..# and development y attribut -> no message for Unknown code
|
||||||
|
##############################################################################################
|
||||||
|
|
||||||
|
my $value = AttrVal($ioname, "development", "");
|
||||||
|
my @delevopmentargs = split (",",$value);
|
||||||
|
|
||||||
|
if ($value =~ m/([umyp]$protocol|1)/g) { # check for u|m|y|p|1 development (u|m|y|p downwards compatibility)
|
||||||
|
### Help Device + Logfile ###
|
||||||
|
Log3 $hash, 5, "$name: $ioname Protocol $1$protocol found in AttrVal development!";
|
||||||
|
|
||||||
|
my $def;
|
||||||
|
my $devicedef = $name."_".$protocol;
|
||||||
|
$def = $modules{SIGNALduino_un}{defptr}{$devicedef} if(!$def);
|
||||||
|
$modules{SIGNALduino_un}{defptr}{ioname} = $ioname;
|
||||||
|
|
||||||
|
if(!$def) {
|
||||||
|
Log3 $ioname, 1, "$ioname: $name UNDEFINED sensor " . $devicedef . " detected";
|
||||||
|
return "UNDEFINED $devicedef SIGNALduino_un $devicedef";
|
||||||
|
}
|
||||||
|
|
||||||
|
my $hash = $def;
|
||||||
|
my $name = $hash->{NAME};
|
||||||
|
|
||||||
|
$hash->{lastMSG} = $rawData;
|
||||||
|
$hash->{bitMSG} = $bitData;
|
||||||
|
|
||||||
|
my $bitcount = length($bitData);
|
||||||
|
|
||||||
|
$bitcountlength[1] = $bitcount if ($bitcountlength[1] == 0); # to first receive
|
||||||
|
|
||||||
|
if ($bitcount != $bitcountlength[1]) { # comparison
|
||||||
|
if ($bitcount gt $bitcountlength[1]) {
|
||||||
|
$bitcountlength[2] = $bitcount;
|
||||||
|
$bitcountlength[0] = $bitcountlength[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($bitcount lt $bitcountlength[1]) {
|
||||||
|
$bitcountlength[0] = $bitcount;
|
||||||
|
$bitcountlength[2] = $bitcountlength[1];
|
||||||
|
}
|
||||||
|
|
||||||
|
$bitcountlength[1] = $bitcount;
|
||||||
|
readingsSingleUpdate($hash, "bitCountLength", "$bitcountlength[0] to $bitcountlength[2]" ,0);
|
||||||
|
}
|
||||||
|
|
||||||
|
my $hexcount = length($rawData);
|
||||||
|
my $bitDataInvert = $bitData;
|
||||||
|
$bitDataInvert =~ tr/01/10/; # invert message and check if it is possible to deocde now
|
||||||
|
my $rawDataInvert = SIGNALduino_b2h($bitDataInvert);
|
||||||
|
|
||||||
|
readingsBeginUpdate($hash);
|
||||||
|
readingsBulkUpdate($hash, "state", $rawData,0);
|
||||||
|
readingsBulkUpdate($hash, "bitMsg", $bitData);
|
||||||
|
readingsBulkUpdate($hash, "bitMsg_invert", $bitDataInvert);
|
||||||
|
readingsBulkUpdate($hash, "bitCount", $bitcount);
|
||||||
|
readingsBulkUpdate($hash, "hexMsg", $rawData);
|
||||||
|
readingsBulkUpdate($hash, "hexMsg_invert", $rawDataInvert);
|
||||||
|
readingsBulkUpdate($hash, "hexCount_or_nibble", $hexcount);
|
||||||
|
readingsBulkUpdate($hash, "lastInputDev", $ioname);
|
||||||
|
readingsEndUpdate($hash, 1); # Notify is done by Dispatch
|
||||||
|
|
||||||
|
### Example Logfile ###
|
||||||
|
# 2018-09-24_17:32:53 SIGNALduino_unknown_85 UserInfo: Temp 22.4 Hum 52
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 bitMsg: 11110011101110100011100111111110110110111110111110100110001100101000
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 bitMsg_invert: 00001100010001011100011000000001001001000001000001011001110011010111
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 bitCount: 68
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 hexMsg: F3BA39FEDBEFA6328
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 hexMsg_invert: 0C45C601241059CD7
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 hexCount or nibble: 17
|
||||||
|
# 2018-09-24_17:34:25 SIGNALduino_unknown_85 lastInputDev: sduino_dummy
|
||||||
|
|
||||||
|
return $name;
|
||||||
|
} else {
|
||||||
|
### nothing - Info ###
|
||||||
|
my $value = AttrVal($ioname, "development", ""); # read attr development from IODev
|
||||||
|
|
||||||
|
if ($value ne "") {
|
||||||
|
$value .= ","; # some definitions already exist, so prepend a new one
|
||||||
|
}
|
||||||
|
$value .= "u$protocol";
|
||||||
|
Log3 $hash, 4, "$name $ioname Protocol:$protocol | To help decode or debug, please add u$protocol! (attr $ioname development $value)" if ($protocol); # To help decode or debug, please add u84! (attr sduino_dummy development u84)
|
||||||
|
}
|
||||||
|
############################
|
||||||
|
|
||||||
|
|
||||||
Log3 $hash, 4, $dummyreturnvalue;
|
Log3 $hash, 4, $dummyreturnvalue;
|
||||||
return undef;
|
return undef;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
|
sub
|
||||||
|
SIGNALduino_un_Set($$$@)
|
||||||
|
{
|
||||||
|
my ( $hash, $name, @a ) = @_;
|
||||||
|
my $ret = "UserInfo";
|
||||||
|
|
||||||
|
if ($a[0] ne "?") {
|
||||||
|
my $input = join " ", @a[1 .. (scalar(@a)-1)]; # Teile der Eingabe zusammenfassen
|
||||||
|
return "wrong argument! please use $ret argument and one comment." if($a[0] ne "UserInfo" || not $a[1]);
|
||||||
|
|
||||||
|
readingsBeginUpdate($hash);
|
||||||
|
readingsBulkUpdate($hash, "state" , "UserMSG",0);
|
||||||
|
readingsBulkUpdate($hash, "UserMSG", $input) if (defined($input));
|
||||||
|
readingsEndUpdate($hash, 1); # Notify is done by Dispatch
|
||||||
|
|
||||||
|
return undef; # undef because user is in same windows without message, better to use
|
||||||
|
#return "Thanks";
|
||||||
|
}
|
||||||
|
|
||||||
|
return $ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_Attr(@)
|
SIGNALduino_un_Attr(@)
|
||||||
{
|
{
|
||||||
@ -329,15 +322,14 @@ SIGNALduino_un_Attr(@)
|
|||||||
return if($a[0] ne "set" || $a[2] ne "IODev");
|
return if($a[0] ne "set" || $a[2] ne "IODev");
|
||||||
my $hash = $defs{$a[1]};
|
my $hash = $defs{$a[1]};
|
||||||
my $iohash = $defs{$a[3]};
|
my $iohash = $defs{$a[3]};
|
||||||
my $cde = $hash->{CODE};
|
my $cde = $hash->{DEF};
|
||||||
delete($modules{SIGNALduino_un}{defptr}{$cde});
|
|
||||||
$modules{SIGNALduino_un}{defptr}{$iohash->{NAME} . "." . $cde} = $hash;
|
#delete($modules{SIGNALduino_un}{defptr}{$cde});
|
||||||
|
#$modules{SIGNALduino_un}{defptr}{$iohash->{NAME} . "." . $cde} = $hash;
|
||||||
return undef;
|
return undef;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
# binary string, fistbit #, lastbit #
|
|
||||||
|
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_binaryToNumber
|
SIGNALduino_un_binaryToNumber
|
||||||
{
|
{
|
||||||
@ -351,14 +343,14 @@ SIGNALduino_un_binaryToNumber
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_binaryToBoolean
|
SIGNALduino_un_binaryToBoolean
|
||||||
{
|
{
|
||||||
return int(SIGNALduino_un_binaryToNumber(@_));
|
return int(SIGNALduino_un_binaryToNumber(@_));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_bin2dec($)
|
SIGNALduino_un_bin2dec($)
|
||||||
{
|
{
|
||||||
@ -366,6 +358,8 @@ SIGNALduino_un_bin2dec($)
|
|||||||
my $int = unpack("N", pack("B32",substr("0" x 32 . $h, -32)));
|
my $int = unpack("N", pack("B32",substr("0" x 32 . $h, -32)));
|
||||||
return sprintf("%d", $int);
|
return sprintf("%d", $int);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#####################################
|
||||||
sub
|
sub
|
||||||
SIGNALduino_un_binflip($)
|
SIGNALduino_un_binflip($)
|
||||||
{
|
{
|
||||||
@ -391,25 +385,30 @@ SIGNALduino_un_binflip($)
|
|||||||
<a name="SIGNALduino_un"></a>
|
<a name="SIGNALduino_un"></a>
|
||||||
<h3>SIGNALduino_un</h3>
|
<h3>SIGNALduino_un</h3>
|
||||||
<ul>
|
<ul>
|
||||||
The SIGNALduino_un module is a testing and debugging module to decode some devices, it will not create any devices, it will catch only all messages from the signalduino which can't be send to another module
|
The SIGNALduino_un module is a testing and debugging module to decode some devices, it will catch only all messages from the signalduino which can't be send to another module.<br>
|
||||||
|
It can create one help devices after define development attribute on SIGNALduino device. You get a hint from Verbose 4 in the FHEM Log.<br>
|
||||||
|
<u>example:</u> <code>SIGNALduino_unknown sduino_dummy Protocol:40 | To help decode or debug, please add u40! (attr sduino_dummy development u40)</code>
|
||||||
<br><br>
|
<br><br>
|
||||||
|
|
||||||
<a name="SIGNALduino_undefine"></a>
|
<a name="SIGNALduino_undefine"></a>
|
||||||
<b>Define</b>
|
<b>Define</b>
|
||||||
<ul>
|
<ul>
|
||||||
<code>define <name> SIGNALduino_un <code> ]</code> <br>
|
<code>define <name> SIGNALduino_un <code> </code> <br>
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
You can define a Device, but currently you can do nothing with it.
|
You can define a Device, but currently you can do nothing with it.
|
||||||
Autocreate is also not enabled for this module.
|
The function of this module is only to output some logging at verbose 4 or higher at FHEM-logfile or logging to help device. May some data is decoded correctly but it's also possible that this does not work.
|
||||||
The function of this module is only to output some logging at verbose 4 or higher. May some data is decoded correctly but it's also possible that this does not work.
|
The Module will try to process all messages, which where not handled by other modules.<br><br>
|
||||||
The Module will try to process all messages, which where not handled by other modules.
|
Created devices / logfiles must be deleted manually after removing the protocol from the attribute <code> development</code>. (example: u40, y84)
|
||||||
|
|
||||||
</ul>
|
</ul>
|
||||||
<br>
|
<br>
|
||||||
|
|
||||||
<a name="SIGNALduino_unset"></a>
|
<a name="SIGNALduino_unset"></a>
|
||||||
<b>Set</b> <ul>N/A</ul><br>
|
<b>Set</b>
|
||||||
|
<ul>write "comment" - the user can put comments in the logfile which are arranged to his bits of the device<br>
|
||||||
|
(example: to write off the digital display of the thermometer at the time of reception or states of switches ...)</ul>
|
||||||
|
<br>
|
||||||
|
|
||||||
<a name="SIGNALduino_unget"></a>
|
<a name="SIGNALduino_unget"></a>
|
||||||
<b>Get</b> <ul>N/A</ul><br>
|
<b>Get</b> <ul>N/A</ul><br>
|
||||||
@ -417,9 +416,23 @@ SIGNALduino_un_binflip($)
|
|||||||
<a name="SIGNALduino_unattr"></a>
|
<a name="SIGNALduino_unattr"></a>
|
||||||
<b>Attributes</b>
|
<b>Attributes</b>
|
||||||
<ul>
|
<ul>
|
||||||
<li><a href="#verbose">Verbose</a></li>
|
<li><a href="#ignore">ignore</a></li>
|
||||||
|
<li><a href="#stateFormat">stateFormat</a></li>
|
||||||
|
<li><a href="#verbose">verbose</a></li>
|
||||||
|
</ul>
|
||||||
|
<br><br>
|
||||||
|
<a name="SIGNALduino_un_readings"></a>
|
||||||
|
<b>Generated readings</b>
|
||||||
|
<ul>
|
||||||
|
<li>bitCount (Length of the signal, binary)</li>
|
||||||
|
<li>bitCountLength (Length range of all received signals of the protocol)</li>
|
||||||
|
<li>bitMsg</li>
|
||||||
|
<li>bitMsg_invert (Message binary, inverted)</li>
|
||||||
|
<li>hexCount_or_nibble (Length of the signal, hexadecimal)</li>
|
||||||
|
<li>hexMsg</li>
|
||||||
|
<li>hexMsg_invert (Message hexadecimal, inverted)</li>
|
||||||
|
<li>lastInputDev (Device at the last reception)</li>
|
||||||
</ul>
|
</ul>
|
||||||
<br>
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
=end html
|
=end html
|
||||||
@ -429,22 +442,31 @@ SIGNALduino_un_binflip($)
|
|||||||
<a name="SIGNALduino_un"></a>
|
<a name="SIGNALduino_un"></a>
|
||||||
<h3>SIGNALduino_un</h3>
|
<h3>SIGNALduino_un</h3>
|
||||||
<ul>
|
<ul>
|
||||||
Das SIGNALduino_un module ist ein Hilfsmodul um unbekannte Nachrichten debuggen und analysieren zu koennen.
|
Das SIGNALduino_un Modul ist ein Hilfsmodul um unbekannte Nachrichten zu debuggen und analysieren zu können.<br><br>
|
||||||
Das Modul legt keinerlei Geräte oder ähnliches an.
|
Das Modul legt nur eine Hilfsgerät an mit Logfile der Bits sobald man das Attribut <code>development</code> im Empfänger Device auf das entsprechende unbekannte Protokoll setzt.<br>
|
||||||
|
Einen entsprechenden Hinweis erhalten Sie ab Verbose 4 im FHEM Log.<br>
|
||||||
|
<u>Beispiel:</u> <code>SIGNALduino_unknown sduino_dummy Protocol:40 | To help decode or debug, please add u40! (attr sduino_dummy development u40)</code>
|
||||||
<br><br>
|
<br><br>
|
||||||
|
|
||||||
<a name="SIGNALduino_undefine"></a>
|
<a name="SIGNALduino_undefine"></a>
|
||||||
<b>Define</b>
|
<b>Define</b>
|
||||||
|
<ul>
|
||||||
<code>define <name> SIGNALduino_un <code> </code> <br>
|
<code>define <name> SIGNALduino_un <code> </code> <br>
|
||||||
|
|
||||||
<br>
|
<br>
|
||||||
Es ist moeglich ein Geraet manuell zu definieren, aber damit passiert ueberhaupt nichts.
|
Es ist möglich ein Gerät manuell zu definieren, aber damit passiert überhaupt nichts.
|
||||||
Autocreate wird auch keinerlei Geraete aus diesem Modul anlegen.
|
|
||||||
<br>
|
<br>
|
||||||
Die einzgeste Funktion dieses Modules ist, ab Verbose 4 Logmeldungen über die Empfangene Nachricht ins Log zu schreiben. Dabei kann man sich leider nicht darauf verlassen, dass die Nachricht korrekt dekodiert wurde.<br>
|
Die einzigste Funktion dieses Modules ist, ab Verbose 4 Logmeldungen über die Empfangene Nachricht ins FHEM-Log zu schreiben oder in das Logfile des Hilfsgerätes.<br>
|
||||||
Dieses Modul wird alle Nachrichten verarbeiten, welche von anderen Modulen nicht verarbeitet wurden.
|
Dabei kann man sich leider nicht darauf verlassen, dass die Nachricht korrekt dekodiert wurde. Dieses Modul wird alle Nachrichten verarbeiten, welche von anderen Modulen nicht verarbeitet werden.<br>
|
||||||
|
<br>
|
||||||
|
Angelegte Geräte / Logfiles müssen manuell gelöscht werden nachdem aus dem Attribut <code>development</code> des SIGNALduinos das zu untersuchende Protokoll entfernt wurde. (Beispiel: u40,y84)
|
||||||
|
</ul>
|
||||||
|
<br>
|
||||||
<a name="SIGNALduino_unset"></a>
|
<a name="SIGNALduino_unset"></a>
|
||||||
<b>Set</b> <ul>N/A</ul><br>
|
<b>Set</b>
|
||||||
|
<ul>write "Kommentar" - somit kann der User in das Logfile des Hilfsgerät Kommentare setzen welche zeitlich zu seinen Bits des Gerätes eingeordnet werden<br>
|
||||||
|
(Beispiel: um die Digitalanzeige des Thermometers abzuschreiben zum Zeitpunkt des Empfangs oder Zustände von Schaltern ...)</ul>
|
||||||
|
<br>
|
||||||
|
|
||||||
<a name="SIGNALduino_unget"></a>
|
<a name="SIGNALduino_unget"></a>
|
||||||
<b>Get</b> <ul>N/A</ul><br>
|
<b>Get</b> <ul>N/A</ul><br>
|
||||||
@ -452,9 +474,23 @@ SIGNALduino_un_binflip($)
|
|||||||
<a name="SIGNALduino_unattr"></a>
|
<a name="SIGNALduino_unattr"></a>
|
||||||
<b>Attributes</b>
|
<b>Attributes</b>
|
||||||
<ul>
|
<ul>
|
||||||
<li><a href="#verbose">Verbose</a></li>
|
<li><a href="#ignore">ignore</a></li>
|
||||||
|
<li><a href="#stateFormat">stateFormat</a></li>
|
||||||
|
<li><a href="#verbose">verbose</a></li>
|
||||||
|
</ul>
|
||||||
|
<br><br>
|
||||||
|
<a name="SIGNALduino_un_readings"></a>
|
||||||
|
<b>Generierte Readings</b>
|
||||||
|
<ul>
|
||||||
|
<li>bitCount (Länge des Signals, binär)</li>
|
||||||
|
<li>bitCountLength (Längenbereich aller empfangen Signale des Protokolles)</li>
|
||||||
|
<li>bitMsg</li>
|
||||||
|
<li>bitMsg_invert (Nachricht binär, invertiert)</li>
|
||||||
|
<li>hexCount_or_nibble (Länge des Signals, hexadezimal)</li>
|
||||||
|
<li>hexMsg</li>
|
||||||
|
<li>hexMsg_invert (Nachricht hexadezimal, invertiert)</li>
|
||||||
|
<li>lastInputDev (Device beim letzten Empfang)</li>
|
||||||
</ul>
|
</ul>
|
||||||
<br>
|
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
=end html_DE
|
=end html_DE
|
||||||
|
2191
fhem/FHEM/lib/signalduino_protocols.hash
Normal file
2191
fhem/FHEM/lib/signalduino_protocols.hash
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
x
Reference in New Issue
Block a user