| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607 |
- #################################################################
- # $Id: 88_xs1Dev.pm 16598 2018-04-13 13:48:07Z HomeAuto_User $
- #################################################################
- # logisches Modul - einzelnes Gerät, über das mit physikalisches
- # Modul kommuniziert werden kann
- #
- # note / ToDo´s:
- # - PERL WARNING: Use of uninitialized value $_
- # - PERL WARNING: Use of uninitialized value $cmdList in string
- # - PERL WARNING: Use of uninitialized value $cmdList in concatenation
- #################################################################
- package main;
- # Laden evtl. abhängiger Perl- bzw. FHEM-Module
- use strict;
- use warnings; # Warnings
- use POSIX;
- use Time::Local;
- #use SetExtensions;
- sub xs1Dev_Initialize($) {
- my ($hash) = @_;
- $hash->{Match} = "[x][s][1][D][e][v][_][A][k][t][o][r]_[0-6][0-9].*|[x][s][1][D][e][v][_][S][e][n][s][o][r]_[0-6][0-9].*"; ## zum testen - https://regex101.com/
- $hash->{DefFn} = "xs1Dev_Define";
- $hash->{AttrFn} = "xs1Dev_Attr";
- $hash->{ParseFn} = "xs1Dev_Parse";
- $hash->{SetFn} = "xs1Dev_Set";
- $hash->{UndefFn} = "xs1Dev_Undef";
- $hash->{AttrList} = "debug:0,1 ".
- "IODev ".
- "useSetExtensions:0,1 ".
- $readingFnAttributes;
- $hash->{AutoCreate} = { "xs1Dev_Sensor_.*" => { GPLOT => "temp4hum4:Temp/Hum,", FILTER=>"%NAME", } };
-
- }
- sub xs1Dev_Define($$) {
- # $def --> Definition des Module
- # $hash --> ARRAY des Module
-
- my ($hash, $def) = @_;
- my @arg = split("[ \t][ \t]*", $def);
- #-----0------1------2----3----4
- return "Usage: define <NAME> xs1Dev <Typ> <ID> | wrong number of arguments" if( @arg != 4);
- return "Usage: define <NAME> xs1Dev <Typ> <ID> | wrong ID, must be 1-64" if ( $arg[3] <1 || $arg[3] >64);
- return "Usage: define <NAME> xs1Dev <Typ> <ID> | wrong Typ, must be A or S" if ( $arg[2] ne "A" && $arg[2] ne "S");
- splice( @arg, 1, 1 );
- my $iodev;
- my $i = 0;
- ############## !! ################ nicht genutzt derzeit ############# !! #################
- #### Schleife (Durchlauf der Argumente @arg) wo IODev= gefiltert wird aus define | Dispatch
- foreach my $param ( @arg ) {
- if( $param =~ m/IODev=([^\s]*)/ ) {
- $iodev = $1;
- splice( @arg, $i, 3 );
- last;
- }
- $i++;
- }
- ###########################################################################################
- my $name = $hash->{NAME}; ## Der Definitionsname, mit dem das Gerät angelegt wurde.
- my $typ = $hash->{TYPE}; ## Der Modulname, mit welchem die Definition angelegt wurde.
-
- #Log3 $name, 3, "$typ: Define arguments 0:$arg[0] | 1:$arg[1] | 2:$arg[2] | 3:$arg[3]";
- # Parameter Define
- my $xs1_ID = $arg[2]; ## Zusatzparameter 1 bei Define - ggf. nur in Sub
- my $xs1_typ1 = $arg[1]; ## A || S
-
- my $Device = $xs1_typ1.$xs1_ID; ## A02 || S05
- my $Device_count = 0;
- my $Device_exist;
-
- ### Check A02 || S05 bereits definiert
- foreach my $d (sort keys %defs) {
- if(defined($defs{$d}) && defined($defs{$d}{ID}) && $defs{$d}{ID} eq $Device) {
- $Device_count++;
- $Device_exist = $d;
- Log3 $name, 3, "$typ: $d $Device_count";
- }
- }
-
- return "The xs1 <ID> $Device is already definded: $Device_exist" if ($Device_count != 0);
- $hash->{ID} = $xs1_typ1.$xs1_ID; ## A02 || S05
- $modules{xs1Dev}{defptr}{$xs1_typ1.$xs1_ID} = $hash; ## !!! Adresse rückwärts dem Hash zuordnen (für ParseFn)
- my $debug = AttrVal($hash->{NAME},"debug",0);
- AttrVal($hash->{NAME},"useSetExtensions",0);
-
- $hash->{STATE} = "Defined"; ## Der Status des Modules nach Initialisierung.
- $hash->{TIME} = time(); ## Zeitstempel, derzeit vom anlegen des Moduls
- #$hash->{VERSION} = "1.17"; ## Version
-
- $hash->{xs1_name} = "undefined"; ## Aktor | Sensor Name welcher def. im xs1
- $hash->{xs1_typ} = "undefined"; ## xs1_Typ switch | hygrometer | temperature ...
-
- if ($xs1_typ1 eq "A"){
- $hash->{xs1_function1} = "undefined"; ## xs1_Funktion zugeordnete Funktion 1
- $hash->{xs1_function2} = "undefined"; ## xs1_Funktion zugeordnete Funktion 2
- $hash->{xs1_function3} = "undefined"; ## xs1_Funktion zugeordnete Funktion 3
- $hash->{xs1_function4} = "undefined"; ## xs1_Funktion zugeordnete Funktion 4
- }
- # Attribut gesetzt
- $attr{$name}{room} = "xs1" if( not defined( $attr{$name}{room} ) );
- AssignIoPort($hash,$iodev) if( !$hash->{IODev} ); ## sucht nach einem passenden IO-Gerät (physikalische Definition)
- # alles mit IODev erst NACH AssignIoPort nutzbar !!!
- $hash->{VERSION} = $hash->{IODev}->{VERSION}; ## Version
-
- if(defined($hash->{IODev}->{NAME})) {
- Log3 $name, 4, "xs1Dev: $name - I/O Device is " . $hash->{IODev}->{NAME};
- } else {
- Log3 $name, 3, "xs1Dev: $name - no I/O Device, Please delete and restart FHEM.";
- }
- #$iodev = $hash->{IODev}->{NAME};
- # if(defined($hash->{IODev}->{xs1_ip})) { ## IP von xs1Bridge - Device aus HASH
- # $hash->{xs1_ip} = $hash->{IODev}->{xs1_ip};
- # }
-
- return undef;
- }
- sub xs1Dev_Attr()
- {
- my ($cmd,$name,$attrName,$attrValue) = @_;
- my $hash = $defs{$name};
- my $typ = $hash->{TYPE};
- my $debug = AttrVal($hash->{NAME},"debug",0);
-
- #Debug " $name: Attr | Attributes $attrName = $attrValue" if($debug);
- }
- sub xs1Dev_Set ($$@)
- {
- my ( $hash, $name, @args ) = @_;
- my $xs1_ID = $hash->{ID};
- my $typ = $hash->{TYPE}; ## xs1Dev
- my $cmd = $args[0];
-
- my $debug = AttrVal($hash->{NAME},"debug",0);
- my $xs1_typ = $hash->{xs1_typ};
- my $Aktor_ID = substr($xs1_ID,1,2); ## A01 zu 01
- my $cmd2; ## notwendig für Switch Funktionsplatz xs1
- my $cmdFound;
-
- return "no set value specified" if(int(@args) < 1);
- my %xs1_function = (); ## Funktionen in ARRAY schreiben
- my %setList = (); ## Funktionen als Liste
- my %setListPos = (); ## Funktionen als Position|Funktion
-
- Debug " -------------- ERROR CHECK - START --------------" if($debug && $cmd ne "?");
- # http://192.168.2.5/control?callback=cname&cmd=set_state_actuator&number=7&function=1
-
- if (substr($xs1_ID,0,1) eq "A" && $xs1_typ ne "undefined") { ## nur bei Aktoren und nicht "undefined"
- for (my $d = 0; $d < 4; $d++) {
- if ($hash->{"xs1_function".($d+1)} ne "-") {
- if ($hash->{"xs1_function".($d+1)} eq "dim_up") { ## FHEM Mod xs1 dim_up -> FHEM dimup
- $xs1_function{"dimup:noArg"} = ($d+1);
- } elsif ($hash->{"xs1_function".($d+1)} eq "dim_down") { ## FHEM Mod xs1 dim_down -> FHEM dimdown
- $xs1_function{"dimdown:noArg"} = ($d+1);
- } elsif (exists $xs1_function{$hash->{"xs1_function".($d+1)}.":noArg"}){ ## CHECK ob Funktion bereits exists
- $xs1_function{$hash->{"xs1_function".($d+1)}."_".($d+1).":noArg"} = ($d+1);
- } else {
- $xs1_function{$hash->{"xs1_function".($d+1)}.":noArg"} = ($d+1); ## xs1 Standardbezeichnung Funktion
- }
- }
- }
-
- if ($xs1_typ eq "dimmer"){ #bei dimmer Typ, dim hinzufügen FHEM
- $xs1_function{"dim"} = (5);
- }
-
- while ( (my $k,my $v) = each %xs1_function ) {
- if ($v > 0 && $v < 7) {
- $setListPos{$v."|".$k} = $k;
- #Debug " $name: Set | $k|$v" if($debug && $cmd ne "?");
- }
- }
-
- my $setList = join(" ", keys %xs1_function);
- my $setListAll = join(" ", keys %setListPos);
-
- my $cmdFound = index($setListAll, $cmd.":"); ## check cmd in setListAll - Zuordnung Platz
- my $cmdFound2 = "";
-
- if ($cmdFound >= 0) { #$cmd für Sendebefehl anpassen
- $cmdFound2 = substr($setListAll,$cmdFound-2,1);
- $cmd2 = "function=".$cmdFound2;
- } else {
- $cmd2 = $cmd.$args[1] if (defined $args[1]);
- }
-
- ### dimmer - spezifisch dim hinzufügen FHEM + value Check
- if ($xs1_typ eq "dimmer" && $cmd eq "dim") {
- if (not defined $args[1]) {
- return "dim value arguments failed";
- } elsif ($args[1] !~ /[a-zA-Z]/ && $args[1] <= 1 || $args[1] !~ /[a-zA-Z]/ && $args[1] >= 99) {
- return "dim value must be 1 to 99";
- } elsif ($args[1] =~ /[a-zA-Z]/) {
- return "wrong dim value format! only value from 1 to 99";
- } else {
- $cmd = $cmd.$args[1]."%"; ## FHEM state mod --> anstatt nur dim --> dim47%
- }
- }
- Debug " $name: Set | xs1_typ=$xs1_typ cmd=$cmd setListAll=$setListAll cmdFound=$cmdFound cmdFound2=$cmdFound2" if($debug && $cmd ne "?");
-
- if(AttrVal($name,"useSetExtensions",undef) || AttrVal($name,"useSetExtensions","0")) {
- $cmd =~ s/([.?*])/\\$1/g;
- if($setList !~ m/\b$cmd\b/) {
- Debug " $name: Set | useSetExtensions check" if($debug && $cmd ne "?");
- unshift @args, $name;
- return SetExtensions($hash, $setList, $name, @args);
- }
- SetExtensionsCancel($hash);
- } else {
- return "Unknown argument ?, choose one of $setList" if($args[0] eq "?");
- }
- #Debug " $name: Set | xs1_typ=$xs1_typ (after mod) cmd=$cmd" if($debug && $cmd ne "?");
- if(defined($hash->{IODev}->{NAME})) {
- if ($xs1_typ eq "switch" || $xs1_typ eq "dimmer" || $xs1_typ eq "shutter" || $xs1_typ eq "timerswitch" && $cmd ne "?") {
- Debug " $name: Set IOWrite | xs1_ID=$xs1_ID xs1_typ=$xs1_typ cmd=$cmd cmd2=$cmd2" if($debug && $xs1_typ ne "temperature" && $xs1_typ ne "hygrometer");
- #Log3 $name, 3, "$name: Set IOWrite | xs1_ID=$xs1_ID xs1_typ=$xs1_typ cmd=$cmd cmd2=$cmd2 IODev=$hash->{IODev}->{NAME}";
- Log3 $name, 3, "$typ set $name $cmd";
-
- IOWrite($hash, $xs1_ID, $xs1_typ, $cmd, $cmd2);
- readingsSingleUpdate($hash, "state", $cmd , 1);
- }
- #else {
- #Log3 $name, 2, "$name: Device NOT SUPPORTED for Dispatch. In xs1 disabled.";
- #}
- } else {
- return "no IODev define. Please define xs1Bridge.";
- }
- #Debug " $name: Set | xs1_ID=$xs1_ID xs1_typ=$xs1_typ" if($debug);
- Debug " -------------- ERROR CHECK - END --------------" if($debug);
- }
- return undef;
- }
-
- sub xs1Dev_Parse($$) ## Input Data from 88_xs1Bridge
- {
- my ( $io_hash, $data) = @_; ## $io_hash = ezControl -> def. Name von xs1Bridge
- my ($xs1Dev,$xs1_readingsname,$xs1_ID,$xs1_typ2,$xs1_value,$xs1_f1,$xs1_f2,$xs1_f3,$xs1_f4,$xs1_name) = split("#", $data);
- my $xs1_typ1 = substr($xs1_readingsname,0,1); ## A || S
- my $def = $modules{xs1Dev}{defptr}{$xs1_typ1.$xs1_ID};
- $def = $modules{xs1Dev}{defptr}{$xs1_typ1.$xs1_ID} if(!$def); ## {xs1Dev}{defptr}{A02}
-
- my $hash = $def;
- $hash->{xs1_typ} = $xs1_typ2;
- $hash->{xs1_name} = $xs1_name;
- my $IODev = $io_hash->{NAME};
- my $name = $hash->{NAME}; ## xs1Dev_Aktor_01
- my $typ = $hash->{TYPE}; ## xs1Dev
- $typ = "xs1Dev" if (!$def); ## Erstanlegung
-
- ###### Define and values update ######
- #Log3 $typ, 3, "$typ: Parse | Data: $xs1Dev | $xs1_readingsname | $xs1_ID | $xs1_typ2 | $xs1_value | $xs1_typ1" if (!$def);
- #Log3 $typ, 3, "$typ: Parse | Data: $xs1Dev | $xs1_readingsname | $xs1_ID | $xs1_typ2 | $xs1_value | $xs1_typ1";
- if(!$def) {
- # "UNDEFINED xs1Dev_Aktor_12 xs1Dev A 12"
- Log3 $name, 3, "$typ: Unknown device ".$xs1Dev."_".$xs1_readingsname."_"."$xs1_ID $xs1_ID $xs1_typ1 , please define it";
- return "UNDEFINED xs1Dev"."_".$xs1_readingsname."_"."$xs1_ID xs1Dev $xs1_typ1 $xs1_ID";
- } else {
- #Log3 $name, 3, "$typ: device $xs1_readingsname"."_"."$xs1_ID xs1_value:$xs1_value xs1_typ2:$xs1_typ2";
-
- AssignIoPort($hash, $io_hash); ## sucht nach einem passenden IO-Gerät (physikalische Definition)
-
- if ($xs1_readingsname eq "Aktor") { ## zugeordnete xs1_Funktionen
- $hash->{xs1_function1} = $xs1_f1;
- $hash->{xs1_function2} = $xs1_f2;
- $hash->{xs1_function3} = $xs1_f3;
- $hash->{xs1_function4} = $xs1_f4;
- }
-
- #### Typ switch | on | off mod for FHEM Default
- if ($xs1_typ2 eq "switch") {
- if ($xs1_value == 0) { $xs1_value = "off"; }
- elsif ($xs1_value == 100) { $xs1_value = "on"; }
- readingsSingleUpdate($hash, "state", $xs1_value ,1); # Aktor | Sensor Update value
-
- ## RegEx devStateIcon da Symbole nicht gleich benannt -> dim_up | dim_down
- if ($hash->{xs1_function1} eq "dim_up" || $hash->{xs1_function2} eq "dim_up" || $hash->{xs1_function3} eq "dim_up" || $hash->{xs1_function4} eq "dim_up" ||
- $hash->{xs1_function1} eq "dim_down" || $hash->{xs1_function2} eq "dim_down" || $hash->{xs1_function3} eq "dim_down" || $hash->{xs1_function4} eq "dim_down" ) {
- $attr{$name}{devStateIcon} = "dim_up:dimup dim_down:dimdown" if( not defined( $attr{$name}{devStateIcon} ) );
- }
-
- }
- #### Typ temperature
- elsif ($xs1_typ2 eq "temperature") {
- my $xs1_value_new = "T: ".$xs1_value; ## temperature mod for FHEM Default
- readingsBeginUpdate($hash);
- readingsBulkUpdate($hash, "state", $xs1_value_new);
- readingsBulkUpdate($hash, "temperature", $xs1_value);
- readingsEndUpdate($hash, 1);
- }
- #### Typ hygrometer
- elsif ($xs1_typ2 eq "hygrometer") {
- my $xs1_value_new = "H: ".$xs1_value; ## hygrometer mod for FHEM Default
- readingsBeginUpdate($hash);
- readingsBulkUpdate($hash, "state", $xs1_value_new);
- readingsBulkUpdate($hash, "humidity", $xs1_value);
- readingsEndUpdate($hash, 1);
- }
- #### Typ dimmer
- elsif ($xs1_typ2 eq "dimmer") {
-
- ## RegEx devStateIcon da Symbole nicht durchweg von 0 - 100 | dim_up | dim_down
- $attr{$name}{devStateIcon} = "dim0[1-6]\\D%:dim06% dim[7-9]\\D|dim[1][0-2]%:dim12% dim[1][3-8]%:dim18% \n"
- ."dim[1][9]|dim[2][0-5]%:dim25% dim[2][6-9]|dim[3][0-1]%:dim31% dim[3][2-7]%:dim37% \n"
- ."dim[3][8-9]|dim[4][0-3]%:dim43% dim[4][4-9]|dim[5][0]%:dim50% dim[5][1-6]%:dim56% \n"
- ."dim[5][7-9]|dim[6][0-2]%:dim62% dim[6][3-8]%:dim68% dim[6][9]|dim[7][0-5]%:dim75% \n"
- ."dim[7][6-9]|dim[8][0-1]%:dim81% dim[8][2-7]%:dim87% dim[8][8-9]|dim[9][0-3]%:dim93% \n"
- ."dim[9][4-9]|dim[1][0][0]%:dim100% dim[_][u][p]:dimup dim[_][d][o]:dimdown" if( not defined( $attr{$name}{devStateIcon} ) );
- if ($xs1_value ne "0.0") {
- $xs1_value = "dim".sprintf("%02d", $xs1_value)."%";
- } elsif ($xs1_value eq "0.0") {
- $xs1_value = "off";
- }
-
- readingsSingleUpdate($hash, "state", $xs1_value ,1);
- }
- #### Typ shutter | on | off mod for FHEM Default
- elsif ($xs1_typ2 eq "shutter") {
- if ($xs1_value == 0) { $xs1_value = "off"; }
- elsif ($xs1_value == 100) { $xs1_value = "on"; }
- readingsSingleUpdate($hash, "state", $xs1_value ,1);
- }
- #### Typ timerswitch | on | off mod for FHEM Default
- elsif ($xs1_typ2 eq "timerswitch") {
- if ($xs1_value == 0) { $xs1_value = "off"; }
- elsif ($xs1_value == 100) { $xs1_value = "on"; }
- readingsSingleUpdate($hash, "state", $xs1_value ,1);
- }
- elsif ($xs1_typ2 eq "barometer") {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "pressure", $xs1_value ,1);
- readingsSingleUpdate($hash, "state", "P: ".$xs1_value ,1);
- readingsEndUpdate($hash, 1);
- }
- elsif ($xs1_typ2 eq "rain") {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "rain", $xs1_value ,1);
- readingsSingleUpdate($hash, "state", "R: ".$xs1_value ,1);
- readingsEndUpdate($hash, 1);
- }
- elsif ($xs1_typ2 eq "rain_1h") {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "rain_calc_h", $xs1_value ,1);
- readingsSingleUpdate($hash, "state", "R: ".$xs1_value ,1);
- readingsEndUpdate($hash, 1);
- }
- elsif ($xs1_typ2 eq "rain_24h") {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "rain_calc_d", $xs1_value ,1);
- readingsSingleUpdate($hash, "state", "R: ".$xs1_value ,1);
- readingsEndUpdate($hash, 1);
- }
- elsif ($xs1_typ2 eq "winddirection") {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "Winddirection", $xs1_value ,1);
- readingsSingleUpdate($hash, "state", "D: ".$xs1_value ,1);
- readingsEndUpdate($hash, 1);
- }
- elsif ($xs1_typ2 eq "windspeed") {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "Windspeed", $xs1_value ,1);
- readingsSingleUpdate($hash, "state", "W: ".$xs1_value ,1);
- readingsEndUpdate($hash, 1);
- }
- elsif ($xs1_typ2 eq "counter" || $xs1_typ2 eq "counterdiff" || $xs1_typ2 eq "fencedetector" || $xs1_typ2 eq "gas_consump" || $xs1_typ2 eq "gas_peak" ||
- $xs1_typ2 eq "light" || $xs1_typ2 eq "motion" || $xs1_typ2 eq "other" || $xs1_typ2 eq "rainintensity" || $xs1_typ2 eq "remotecontrol" ||
- $xs1_typ2 eq "uv_index" || $xs1_typ2 eq "waterdetector" || $xs1_typ2 eq "waterlevel" || $xs1_typ2 eq "windgust" || $xs1_typ2 eq "windvariance" ||
- $xs1_typ2 eq "wtr_consump" || $xs1_typ2 eq "wtr_peak") {
- readingsSingleUpdate($hash, "state", $xs1_value ,1);
- }
- ### Fenstermelder = windowopen | Tuermelder = dooropen --> 0 zu / 100 offen | mod for FHEM Default
- elsif ($xs1_typ2 eq "dooropen" || $xs1_typ2 eq "windowopen") {
- if ($xs1_value == 0.0) { $xs1_value = "closed";} elsif ($xs1_value == 100.0) { $xs1_value = "Open"; }
- readingsBeginUpdate($hash);
- if ($xs1_typ2 eq "windowopen") {
- readingsSingleUpdate($hash, "Window", $xs1_value ,1);
- }
- if ($xs1_typ2 eq "dooropen") {
- readingsSingleUpdate($hash, "Door", $xs1_value ,1);
- }
- my $value = Value($name);
- my $OldValue = OldValue($name);
- if ($value ne $OldValue) {
- readingsSingleUpdate($hash, "Previous", $xs1_value ,0);
- }
- readingsSingleUpdate($hash, "state", $xs1_value ,0);
- readingsEndUpdate($hash, 1);
- ### alles andere ...
- } else {
- readingsBeginUpdate($hash);
- readingsSingleUpdate($hash, "state", $xs1_value ,0);
- readingsEndUpdate($hash, 1);
- }
- }
-
- return $name;
- }
- sub xs1Dev_Undef($$)
- {
- my ( $hash, $name) = @_;
- my $typ = $hash->{TYPE};
-
- delete($modules{xs1Dev}{defptr}{$hash->{ID}});
- Log3 $name, 3, "$typ: Device with Name $name delete";
- return undef;
- }
- # Eval-Rückgabewert für erfolgreiches
- # Laden des Moduls
- 1;
- # Beginn der Commandref
- =pod
- =item summary Control of the devices which defined in xs1
- =item summary_DE Steuerung des Geräte welche im xs1 definiert sind
- =begin html
- <a name="xs1Dev"></a>
- <h3>xs1Dev</h3>
- <ul>
- This module works with the xs1Bridge module. (The <code>xs1_control</code> attribute in the xs1Bridge module must be set to 1!) <br>
- It communicates with this and creates all actuators of the xs1 as a device in FHEM. So you can control the actuators of the xs1 from the FHEM. <br><br>
- The module was developed based on the firmware version v4-Beta of the xs1. There may be errors due to different adjustments within the manufacturer's firmware.
- <br>
-
- <br><ul>
- <u>Currently implemented types of xs1 for processing: </u><br>
- <li>Aktor: dimmer, switch, shutter, timerswitch</li>
- <li>Sensor: barometer, counter, counterdiff, light, motion, other, rain, rain_1h, rain_24h, rainintensity, remotecontrol, uv_index, waterdetector, winddirection, windgust, windspeed, windvariance</li>
- </ul><br><br>
- <a name="xs1Dev_define"></a>
- <b>Define</b><br>
- <ul>
- <code>define <name> xs1Dev <Typ> <ID> IODev=<NAME></code>
- <br><br>
- It is not possible to create the module without specifying type and ID of xs1.
- <ul>
- <li><code><ID></code> is internal id in xs1.</li>
- </ul>
- <ul>
- <li><code><Typ></code> is the abbreviation A for actuators or S for sensors.</li>
- </ul><br>
- example:
- <ul>
- define xs1Dev_Aktor_02 xs1Dev A 02 IODev=ezControl
- </ul>
- </ul><br>
- <b>Set</b>
- <ul><code>set <name> <value> </code></ul><br>
- in which <code>value</code> one of the following values:<br>
- <ul><code>
- on<br>
- off<br>
- dimup<br>
- dimupdown<br>
- toggle<br>
- on, wait, off<br>
- absolut<br>
- wait<br>
- long on<br>
- long off<br>
- Stopp<br>
- on, wait, on<br>
- off, wait, off<br>
- impuls<br>
- </code></ul><br>
- <b>Get</b><br>
- <ul>N/A</ul><br>
- <a name="xs1_attr"></a>
- <b>Attributes</b>
- <ul>
- <li>debug (0,1)<br>
- This brings the module into a very detailed debug output in the logfile. Thus, program parts can be controlled and errors can be checked.<br>
- (Default, debug 0)
- </li>
- <li>useSetExtensions (0,1)<br>
- Toggles the SetExtensions on or off.<br>
- (Default, useSetExtensions 0)
- </li>
- </ul><br>
- <b>Explanation:</b>
- <ul>
- <li>abstract Internals:</li>
- <ul>
- xs1_function(1-4): defined function in the device<br>
- xs1_name: defined name in the device<br>
- xs1_typ: defined type in the device<br>
- </ul><br>
- </ul>
- </ul>
- =end html
- =begin html_DE
- <a name="xs1Dev"></a>
- <h3>xs1Dev</h3>
- <ul>
- Dieses Modul arbeitet mit dem Modul xs1Bridge zusammen. (Das Attribut <code>xs1_control</code> im Modul xs1Bridge muss auf 1 gestellt sein!) <br>
- Es kommuniziert mit diesem und legt sämtliche Aktoren des xs1 als Device im FHEM an. So kann man vom FHEM aus, die Aktoren der xs1 steuern.
- <br><br>
- Das Modul wurde entwickelt basierend auf dem Firmwarestand v4-Beta des xs1. Es kann aufgrund von unterschiedlichen Anpassungen innerhalb der Firmware des Herstellers zu Fehlern kommen.<br>
-
- <br><ul>
- <u>Derzeit implementierte Typen des xs1 zur Verarbeitung: </u><br>
- <li>Aktor: dimmer, switch, shutter, timerswitch</li>
- <li>Sensor: barometer, counter, counterdiff, light, motion, other, rain, rain_1h, rain_24h, rainintensity, remotecontrol, uv_index, waterdetector, winddirection, windgust, windspeed, windvariance</li>
- </ul><br><br>
- <a name="xs1Dev_define"></a>
- <b>Define</b><br>
- <ul>
- <code>define <name> xs1Dev <Typ> <ID> IODev=<NAME></code>
- <br><br>
- Ein anlegen des Modules ohne Angabe des Typ und der ID vom xs1 ist nicht möglich.
- <ul>
- <li><code><ID></code> ist interne ID im xs1.</li>
- </ul>
- <ul>
- <li><code><Typ></code> ist der Kürzel A für Aktoren oder S für Sensoren.</li>
- </ul><br>
- Beispiel:
- <ul>
- define xs1Dev_Aktor_02 xs1Dev A 02 IODev=ezControl
- </ul>
- </ul><br>
- <b>Set</b>
- <ul><code>set <name> <value> </code></ul><br>
- Wobei <code>value</code> der in der xs1 definierten Funktion entspricht. Bsp:<br>
- <ul><code>
- an<br>
- aus<br>
- dimup<br>
- dimupdown<br>
- umschalten<br>
- an, warten, aus<br>
- absolut<br>
- warten<br>
- langes AN<br>
- langes AUS<br>
- Stopp<br>
- an, warten, an<br>
- aus, warten, aus<br>
- Impuls<br>
- </code></ul><br>
- <b>Get</b><br>
- <ul>N/A</ul><br>
- <a name="xs1_attr"></a>
- <b>Attribute</b>
- <ul>
- <li>debug (0,1)<br>
- Dies bringt das Modul in eine sehr ausführliche Debug-Ausgabe im Logfile. Somit lassen sich Programmteile kontrollieren und Fehler überprüfen.<br>
- (Default, debug 0)
- </li>
- <li>useSetExtensions (0,1)<br>
- Schaltet die SetExtensions ein bzw. aus.<br>
- (Default, useSetExtensions 0)
- </li>
- </ul><br>
- <b>Erläuterung:</b>
- <ul>
- <li>Auszug Internals:</li>
- <ul>
- xs1_function(1-4): definierte Funktion im Gerät<br>
- xs1_name: definierter Name im Gerät<br>
- xs1_typ: definierter Typ im Gerät<br>
- </ul><br>
- </ul>
-
- </ul>
- =end html_DE
- =cut
|