2
0
mirror of https://github.com/fhem/fhem-mirror.git synced 2025-03-10 09:16:53 +00:00

autodiscovery added

git-svn-id: https://svn.fhem.de/fhem/trunk@2485 2b470e98-0d58-463d-a4d8-8e2adae1ed80
This commit is contained in:
mfr69bs 2013-01-12 04:24:14 +00:00
parent 5c21a31910
commit a883ad8cdc

View File

@ -3,8 +3,9 @@
#
# Copyright notice
#
# (c) 2012 Copyright: Dr. Boris Neubert
# omega at online dot de
# (c) 2012 Copyright: Dr. Boris Neubert & Martin Fischer
# e-mail: omega at online dot de
# e-mail: m_fischer at gmx dot de
#
# This file is part of fhem.
#
@ -32,6 +33,29 @@ use warnings;
# the version at CPAN is outdated and malfunctioning as at 2012-12-19
use lib::OWNet;
use vars qw(%owfamily);
# 1-Wire devices (order by family code)
# http://owfs.sourceforge.net/family.html
%owfamily = (
"01" => qw(DS2401 DS1990A),
"05" => qw(DS2405),
"10" => qw(DS18S20 DS1920),
"12" => qw(DS2406 DS2507),
"1B" => qw(DS2436),
"1D" => qw(DS2436),
"20" => qw(DS2450),
"22" => qw(DS1822),
"24" => qw(DS2415 DS1904),
"26" => qw(DS2438),
"27" => qw(DS2417),
"28" => qw(DS18B20),
"29" => qw(DS2408),
"3A" => qw(DS2413),
"3B" => qw(DS1825),
"81" => qw(DS1420),
"FF" => qw(LCD),
);
#####################################
sub
OWServer_Initialize($)
@ -46,6 +70,7 @@ OWServer_Initialize($)
# Consumer
$hash->{DefFn} = "OWServer_Define";
$hash->{NotifyFn}= "OWServer_Notify";
$hash->{UndefFn} = "OWServer_Undef";
$hash->{GetFn} = "OWServer_Get";
$hash->{SetFn} = "OWServer_Set";
@ -135,6 +160,27 @@ OWServer_OpenDev($)
return $owserver
}
#####################################
sub
OWServer_Notify($$)
{
my ($hash,$dev) = @_;
my $name = $hash->{NAME};
my $type = $hash->{TYPE};
return if($dev->{NAME} ne "global" ||
!grep(m/^INITIALIZED$/, @{$dev->{CHANGED}}));
return if($attr{$name} && $attr{$name}{disable});
delete $modules{OWServer}{NotifyFn};
delete $hash->{NTFY_ORDER} if($hash->{NTFY_ORDER});
OWServer_DoInit($hash);
return undef;
}
#####################################
sub
OWServer_DoInit($)
@ -143,6 +189,7 @@ OWServer_DoInit($)
my $name = $hash->{NAME};
$hash->{STATE} = "Initialized" if(!$hash->{STATE});
OWServer_Autodiscovery($hash) if($init_done);
return undef;
}
@ -176,6 +223,54 @@ OWServer_Dir($@)
return $hash->{fhem}{owserver}->dir($path);
}
#####################################
sub
OWServer_Autodiscovery($)
{
my ($hash)= @_;
my $name = $hash->{NAME};
my $owserver= $hash->{fhem}{owserver};
my @dir= split(",", $owserver->dir());
my @devices= grep { m/^\/[0-9a-f]{2}.[0-9a-f]{12}$/i } @dir;
for my $device (@devices) {
my $address= substr($device,1);
my $family= substr($address,0,2);
if(!defined($owfamily{$family})) {
next;
} else {
my $type= $owserver->read($device . "/type");
if($type !~ m/$owfamily{$family}/) {
Log 2, "$name: Autodiscovery: type '$type' unknown";
next;
} else {
foreach my $d (keys %defs) {
next if($defs{$d}{TYPE} eq "OWDevice" &&
defined($defs{$d}{fhem}) &&
defined($defs{$d}{fhem}{address}) && $defs{$d}{fhem}{address} eq $address);
my $id= substr($address,3);
my $devname= $type . "_" . $id;
if(defined($defs{$devname})) {
next;
} else {
my $interval= ($family eq "81") ? "" : " 60";
my $define= "$devname OWDevice $address" . $interval;
my $cmdret;
$cmdret= CommandDefine(undef,$define);
if($cmdret) {
Log 1, "$name: An error occurred while creating device for address '$address': $cmdret";
} else {
$cmdret= CommandAttr(undef,"$devname room OWDevice");
}
}
}
}
}
}
return undef;
}
#####################################
sub