Bessere Variante zur HTTP Headeranalyse, Code aufgeräumt
This commit is contained in:
parent
3cdceffc41
commit
c4f2b57c31
49
74_AMAD.pm
49
74_AMAD.pm
@ -35,7 +35,7 @@ use Time::HiRes qw(gettimeofday);
|
|||||||
use HttpUtils;
|
use HttpUtils;
|
||||||
use TcpServerUtils;
|
use TcpServerUtils;
|
||||||
|
|
||||||
my $version = "0.9.1";
|
my $version = "0.9.2";
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -894,7 +894,19 @@ sub AMAD_CommBridge_Read($) {
|
|||||||
###
|
###
|
||||||
|
|
||||||
my @data = split( '\R\R', $buf );
|
my @data = split( '\R\R', $buf );
|
||||||
my $chash = undef;
|
my $chash;
|
||||||
|
my $fhemdev;
|
||||||
|
|
||||||
|
|
||||||
|
my @fhemdev = split( '\R', $data[0] );
|
||||||
|
foreach my $ret( @fhemdev ) {
|
||||||
|
if( $ret =~ /FHEMDEVICE: (.*)/ ) {
|
||||||
|
$fhemdev = $1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$chash = $defs{$fhemdev};
|
||||||
|
|
||||||
|
|
||||||
if ( $data[0] =~ /FHEMCMD: setreading\b/ ) {
|
if ( $data[0] =~ /FHEMCMD: setreading\b/ ) {
|
||||||
my $tv = $data[1];
|
my $tv = $data[1];
|
||||||
@ -915,10 +927,6 @@ sub AMAD_CommBridge_Read($) {
|
|||||||
my $t;
|
my $t;
|
||||||
my $v;
|
my $v;
|
||||||
|
|
||||||
if( $data[2] =~ /FHEMDEVICE:/ ) {
|
|
||||||
|
|
||||||
$data[2] =~ s/FHEMDEVICE: //;
|
|
||||||
|
|
||||||
while( ( $t, $v ) = each %buffer ) {
|
while( ( $t, $v ) = each %buffer ) {
|
||||||
$v =~ s/null//g;
|
$v =~ s/null//g;
|
||||||
|
|
||||||
@ -929,21 +937,6 @@ sub AMAD_CommBridge_Read($) {
|
|||||||
readingsBulkUpdate( $chash, "lastStatusRequestState", "statusRequest_done" );
|
readingsBulkUpdate( $chash, "lastStatusRequestState", "statusRequest_done" );
|
||||||
readingsEndUpdate( $chash, 1 );
|
readingsEndUpdate( $chash, 1 );
|
||||||
|
|
||||||
} else {
|
|
||||||
$data[3] =~ s/FHEMDEVICE: //;
|
|
||||||
|
|
||||||
while( ( $t, $v ) = each %buffer ) {
|
|
||||||
$v =~ s/null//g;
|
|
||||||
|
|
||||||
readingsBeginUpdate( $chash );
|
|
||||||
readingsBulkUpdate( $chash, $t, $v ) if( defined( $v ) );
|
|
||||||
}
|
|
||||||
|
|
||||||
readingsBulkUpdate( $chash, "lastStatusRequestState", "statusRequest_done" );
|
|
||||||
readingsEndUpdate( $chash, 1 );
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
### End Response Processing
|
### End Response Processing
|
||||||
|
|
||||||
return;
|
return;
|
||||||
@ -969,22 +962,8 @@ sub AMAD_CommBridge_Read($) {
|
|||||||
|
|
||||||
elsif ( $data[0] =~ /FHEMCMD: statusrequest\b/ ) {
|
elsif ( $data[0] =~ /FHEMCMD: statusrequest\b/ ) {
|
||||||
|
|
||||||
@data = split( '\R', $data[0] );
|
|
||||||
|
|
||||||
if( $data[2] =~ /FHEMDEVICE:/ ) {
|
|
||||||
|
|
||||||
$data[2] =~ s/FHEMDEVICE: //;
|
|
||||||
my $chash = $defs{$data[2]};
|
|
||||||
Log3 $name, 4, "AMAD ($name) - AMAD_CommBridge: Call statusRequest";
|
Log3 $name, 4, "AMAD ($name) - AMAD_CommBridge: Call statusRequest";
|
||||||
return AMAD_GetUpdateLocal( $chash );
|
return AMAD_GetUpdateLocal( $chash );
|
||||||
|
|
||||||
} else {
|
|
||||||
$data[3] =~ s/FHEMDEVICE: //;
|
|
||||||
my $chash = $defs{$data[3]};
|
|
||||||
Log3 $name, 4, "AMAD ($name) - AMAD_CommBridge: Call statusRequest";
|
|
||||||
return AMAD_GetUpdateLocal( $chash );
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user