code-cleaning #2

Merged
marko merged 2 commits from code-cleaning into devel 2021-04-29 08:51:05 +02:00
1 changed files with 50 additions and 75 deletions

View File

@ -2,7 +2,7 @@
# #
# Developed with Kate # Developed with Kate
# #
# (c) 2017-2020 Copyright: Marko Oldenburg (leongaultier at gmail dot com) # (c) 2017-2021 Copyright: Marko Oldenburg (fhemdevelopment at cooltux dot net)
# All rights reserved # All rights reserved
# #
# Special thanks goes to comitters: # Special thanks goes to comitters:
@ -134,39 +134,6 @@ if ($@) {
} }
} }
# Declare functions
sub LGTV_WebOS_Initialize($);
sub LGTV_WebOS_Define($$);
sub LGTV_WebOS_Undef($$);
sub LGTV_WebOS_Set($@);
sub LGTV_WebOS_Open($);
sub LGTV_WebOS_Close($);
sub LGTV_WebOS_Read($);
sub LGTV_WebOS_Write($@);
sub LGTV_WebOS_Attr(@);
sub LGTV_WebOS_Handshake($);
sub LGTV_WebOS_ResponseProcessing($$);
sub LGTV_WebOS_Header2Hash($);
sub LGTV_WebOS_Pairing($);
sub LGTV_WebOS_CreateSendCommand($$$;$);
sub LGTV_WebOS_Hybi10Encode($;$$);
sub LGTV_WebOS_WriteReadings($$);
sub LGTV_WebOS_GetCurrentChannel($);
sub LGTV_WebOS_GetForgroundAppInfo($);
sub LGTV_WebOS_GetAudioStatus($);
sub LGTV_WebOS_TimerStatusRequest($);
sub LGTV_WebOS_GetExternalInputList($);
sub LGTV_WebOS_ProcessRead($$);
sub LGTV_WebOS_ParseMsg($$);
sub LGTV_WebOS_Get3DStatus($);
sub LGTV_WebOS_GetChannelProgramInfo($);
sub LGTV_WebOS_FormartStartEndTime($);
sub LGTV_WebOS_Presence($);
sub LGTV_WebOS_PresenceRun($);
sub LGTV_WebOS_PresenceDone($);
sub LGTV_WebOS_PresenceAborted($);
sub LGTV_WebOS_WakeUp_Udp($@);
my %lgCommands = ( my %lgCommands = (
"getServiceList" => ["ssap://api/getServiceList"], "getServiceList" => ["ssap://api/getServiceList"],
@ -232,11 +199,17 @@ my %openApps = (
'Spotify' => 'spotify-beehive', 'Spotify' => 'spotify-beehive',
'DuplexIPTV' => 'com.duplexiptv.app', 'DuplexIPTV' => 'com.duplexiptv.app',
'Disney+' => 'com.disney.disneyplus-prod', 'Disney+' => 'com.disney.disneyplus-prod',
'Smart-IPTV' => 'siptv',
'AppleTV' => 'com.apple.appletv',
'Joyn' => 'joyn',
'YouTube-Kids' => 'youtube.leanback.kids.v4',
'DAZN' => 'dazn',
'SkyQ' => 'com.skygo.app.de.q',
); );
my %openAppsPackageName = reverse %openApps; my %openAppsPackageName = reverse %openApps;
sub LGTV_WebOS_Initialize($) { sub LGTV_WebOS_Initialize {
my ($hash) = @_; my ($hash) = @_;
@ -261,7 +234,7 @@ sub LGTV_WebOS_Initialize($) {
return FHEM::Meta::InitMod( __FILE__, $hash ); return FHEM::Meta::InitMod( __FILE__, $hash );
} }
sub LGTV_WebOS_Define($$) { sub LGTV_WebOS_Define {
my ( $hash, $def ) = @_; my ( $hash, $def ) = @_;
@ -306,7 +279,7 @@ sub LGTV_WebOS_Define($$) {
return undef; return undef;
} }
sub LGTV_WebOS_Undef($$) { sub LGTV_WebOS_Undef {
my ( $hash, $arg ) = @_; my ( $hash, $arg ) = @_;
@ -323,7 +296,7 @@ sub LGTV_WebOS_Undef($$) {
return undef; return undef;
} }
sub LGTV_WebOS_Attr(@) { sub LGTV_WebOS_Attr {
my ( $cmd, $name, $attrName, $attrVal ) = @_; my ( $cmd, $name, $attrName, $attrVal ) = @_;
my $hash = $defs{$name}; my $hash = $defs{$name};
@ -360,7 +333,7 @@ sub LGTV_WebOS_Attr(@) {
return undef; return undef;
} }
sub LGTV_WebOS_TimerStatusRequest($) { sub LGTV_WebOS_TimerStatusRequest {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -440,7 +413,7 @@ sub LGTV_WebOS_TimerStatusRequest($) {
$hash ); $hash );
} }
sub LGTV_WebOS_Set($@) { sub LGTV_WebOS_Set {
my ( $hash, $name, $cmd, @args ) = @_; my ( $hash, $name, $cmd, @args ) = @_;
my ( $arg, @params ) = @args; my ( $arg, @params ) = @args;
@ -673,7 +646,7 @@ sub LGTV_WebOS_Set($@) {
LGTV_WebOS_CreateSendCommand( $hash, $uri, \%payload ); LGTV_WebOS_CreateSendCommand( $hash, $uri, \%payload );
} }
sub LGTV_WebOS_Open($) { sub LGTV_WebOS_Open {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -703,7 +676,7 @@ sub LGTV_WebOS_Open($) {
} }
sub LGTV_WebOS_Close($) { sub LGTV_WebOS_Close {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -720,7 +693,7 @@ sub LGTV_WebOS_Close($) {
Log3 $name, 4, "LGTV_WebOS ($name) - Socket Disconnected"; Log3 $name, 4, "LGTV_WebOS ($name) - Socket Disconnected";
} }
sub LGTV_WebOS_Write($@) { sub LGTV_WebOS_Write {
my ( $hash, $string ) = @_; my ( $hash, $string ) = @_;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -735,7 +708,7 @@ sub LGTV_WebOS_Write($@) {
return undef; return undef;
} }
sub LGTV_WebOS_Read($) { sub LGTV_WebOS_Read {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -784,7 +757,7 @@ sub LGTV_WebOS_Read($) {
} }
} }
sub LGTV_WebOS_ProcessRead($$) { sub LGTV_WebOS_ProcessRead {
my ( $hash, $data ) = @_; my ( $hash, $data ) = @_;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -853,7 +826,7 @@ sub LGTV_WebOS_ProcessRead($$) {
Log3 $name, 5, "LGTV_WebOS ($name) - PARTIAL: " . $hash->{PARTIAL}; Log3 $name, 5, "LGTV_WebOS ($name) - PARTIAL: " . $hash->{PARTIAL};
} }
sub LGTV_WebOS_Handshake($) { sub LGTV_WebOS_Handshake {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -882,7 +855,7 @@ sub LGTV_WebOS_Handshake($) {
Log3 $name, 4, "LGTV_WebOS ($name) - start pairing routine"; Log3 $name, 4, "LGTV_WebOS ($name) - start pairing routine";
} }
sub LGTV_WebOS_ResponseProcessing($$) { sub LGTV_WebOS_ResponseProcessing {
my ( $hash, $response ) = @_; my ( $hash, $response ) = @_;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -964,7 +937,7 @@ sub LGTV_WebOS_ResponseProcessing($$) {
Log3 $name, 4, "LGTV_WebOS ($name) - no Match found"; Log3 $name, 4, "LGTV_WebOS ($name) - no Match found";
} }
sub LGTV_WebOS_WriteReadings($$) { sub LGTV_WebOS_WriteReadings {
my ( $hash, $decode_json ) = @_; my ( $hash, $decode_json ) = @_;
@ -1255,7 +1228,7 @@ sub LGTV_WebOS_WriteReadings($$) {
readingsEndUpdate( $hash, 1 ); readingsEndUpdate( $hash, 1 );
} }
sub LGTV_WebOS_Pairing($) { sub LGTV_WebOS_Pairing {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1336,7 +1309,7 @@ sub LGTV_WebOS_Pairing($) {
Log3 $name, 4, "LGTV_WebOS ($name) - Send pairing informations"; Log3 $name, 4, "LGTV_WebOS ($name) - Send pairing informations";
} }
sub LGTV_WebOS_CreateSendCommand($$$;$) { sub LGTV_WebOS_CreateSendCommand {
my ( $hash, $uri, $payload, $type ) = @_; my ( $hash, $uri, $payload, $type ) = @_;
@ -1364,12 +1337,12 @@ sub LGTV_WebOS_CreateSendCommand($$$;$) {
return undef; return undef;
} }
sub LGTV_WebOS_Hybi10Encode($;$$) { sub LGTV_WebOS_Hybi10Encode {
my ( $payload, $type, $masked ) = @_; my $payload = shift;
my $type = shift // 'text';
my $masked = shift // 1;
$type //= "text";
$masked //= 1;
my @frameHead; my @frameHead;
my $frame = ""; my $frame = "";
@ -1465,7 +1438,7 @@ sub LGTV_WebOS_Hybi10Encode($;$$) {
return $frame; return $frame;
} }
sub LGTV_WebOS_GetAudioStatus($) { sub LGTV_WebOS_GetAudioStatus {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1476,7 +1449,7 @@ sub LGTV_WebOS_GetAudioStatus($) {
if ( $hash->{helper}{device}{runsetcmd} == 0 ); if ( $hash->{helper}{device}{runsetcmd} == 0 );
} }
sub LGTV_WebOS_GetCurrentChannel($) { sub LGTV_WebOS_GetCurrentChannel {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1488,7 +1461,7 @@ sub LGTV_WebOS_GetCurrentChannel($) {
if ( $hash->{helper}{device}{runsetcmd} == 0 ); if ( $hash->{helper}{device}{runsetcmd} == 0 );
} }
sub LGTV_WebOS_GetForgroundAppInfo($) { sub LGTV_WebOS_GetForgroundAppInfo {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1501,7 +1474,7 @@ sub LGTV_WebOS_GetForgroundAppInfo($) {
if ( $hash->{helper}{device}{runsetcmd} == 0 ); if ( $hash->{helper}{device}{runsetcmd} == 0 );
} }
sub LGTV_WebOS_GetExternalInputList($) { sub LGTV_WebOS_GetExternalInputList {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1514,7 +1487,7 @@ sub LGTV_WebOS_GetExternalInputList($) {
if ( $hash->{helper}{device}{runsetcmd} == 0 ); if ( $hash->{helper}{device}{runsetcmd} == 0 );
} }
sub LGTV_WebOS_Get3DStatus($) { sub LGTV_WebOS_Get3DStatus {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1526,7 +1499,7 @@ sub LGTV_WebOS_Get3DStatus($) {
if ( $hash->{helper}{device}{runsetcmd} == 0 ); if ( $hash->{helper}{device}{runsetcmd} == 0 );
} }
sub LGTV_WebOS_GetChannelProgramInfo($) { sub LGTV_WebOS_GetChannelProgramInfo {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1541,9 +1514,10 @@ sub LGTV_WebOS_GetChannelProgramInfo($) {
############################################# #############################################
### my little Helper ### my little Helper
sub LGTV_WebOS_ParseMsg($$) { sub LGTV_WebOS_ParseMsg {
my ( $hash, $buffer ) = @_; my $hash = shift;
my $buffer = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
my $open = 0; my $open = 0;
@ -1593,7 +1567,7 @@ sub LGTV_WebOS_ParseMsg($$) {
return ( $msg, $tail ); return ( $msg, $tail );
} }
sub LGTV_WebOS_Header2Hash($) { sub LGTV_WebOS_Header2Hash {
my $string = shift; my $string = shift;
my %hash = (); my %hash = ();
@ -1609,7 +1583,7 @@ sub LGTV_WebOS_Header2Hash($) {
return \%hash; return \%hash;
} }
sub LGTV_WebOS_FormartStartEndTime($) { sub LGTV_WebOS_FormartStartEndTime {
my $string = shift; my $string = shift;
@ -1620,7 +1594,7 @@ sub LGTV_WebOS_FormartStartEndTime($) {
} }
############ Presence Erkennung Begin ################# ############ Presence Erkennung Begin #################
sub LGTV_WebOS_Presence($) { sub LGTV_WebOS_Presence {
my $hash = shift; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1631,7 +1605,7 @@ sub LGTV_WebOS_Presence($) {
unless ( exists( $hash->{helper}{RUNNING_PID} ) ); unless ( exists( $hash->{helper}{RUNNING_PID} ) );
} }
sub LGTV_WebOS_PresenceRun($) { sub LGTV_WebOS_PresenceRun {
my $string = shift; my $string = shift;
my ( $name, $host ) = split( "\\|", $string ); my ( $name, $host ) = split( "\\|", $string );
@ -1665,9 +1639,9 @@ sub LGTV_WebOS_PresenceRun($) {
return $response; return $response;
} }
sub LGTV_WebOS_PresenceDone($) { sub LGTV_WebOS_PresenceDone {
my ($string) = @_; my $string = shift;
my ( $name, $response ) = split( "\\|", $string ); my ( $name, $response ) = split( "\\|", $string );
my $hash = $defs{$name}; my $hash = $defs{$name};
@ -1686,9 +1660,9 @@ sub LGTV_WebOS_PresenceDone($) {
Log3 $name, 4, "Sub LGTV_WebOS_PresenceDone ($name) - presence done"; Log3 $name, 4, "Sub LGTV_WebOS_PresenceDone ($name) - presence done";
} }
sub LGTV_WebOS_PresenceAborted($) { sub LGTV_WebOS_PresenceAborted {
my ($hash) = @_; my $hash = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
delete( $hash->{helper}{RUNNING_PID} ); delete( $hash->{helper}{RUNNING_PID} );
@ -1698,9 +1672,10 @@ sub LGTV_WebOS_PresenceAborted($) {
"Sub LGTV_WebOS_PresenceAborted ($name) - The BlockingCall Process terminated unexpectedly. Timedout!"; "Sub LGTV_WebOS_PresenceAborted ($name) - The BlockingCall Process terminated unexpectedly. Timedout!";
} }
sub LGTV_WebOS_SocketClosePresenceAbsent($$) { sub LGTV_WebOS_SocketClosePresenceAbsent {
my ( $hash, $presence ) = @_; my $hash = shift;
my $presence = shift;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -1710,7 +1685,7 @@ sub LGTV_WebOS_SocketClosePresenceAbsent($$) {
# Sobald pingPresence absent meldet und der Socket noch steht soll er geschlossen werden, da sonst FHEM nach 4-6 min für 10 min blockiert # Sobald pingPresence absent meldet und der Socket noch steht soll er geschlossen werden, da sonst FHEM nach 4-6 min für 10 min blockiert
} }
sub LGTV_WebOS_WakeUp_Udp($@) { sub LGTV_WebOS_WakeUp_Udp {
my ( $hash, $mac_addr, $host, $port ) = @_; my ( $hash, $mac_addr, $host, $port ) = @_;
my $name = $hash->{NAME}; my $name = $hash->{NAME};
@ -2009,9 +1984,9 @@ sub LGTV_WebOS_WakeUp_Udp($@) {
], ],
"release_status": "stable", "release_status": "stable",
"license": "GPL_2", "license": "GPL_2",
"version": "v3.2.4", "version": "v3.3.0",
"author": [ "author": [
"Marko Oldenburg <leongaultier@gmail.com>" "Marko Oldenburg <fhemdevelopment@cooltux.net>"
], ],
"x_fhem_maintainer": [ "x_fhem_maintainer": [
"CoolTux" "CoolTux"