2017-01-24 13:29:30 +00:00
|
|
|
###############################################################################
|
|
|
|
#
|
|
|
|
# Developed with Kate
|
|
|
|
#
|
2017-02-02 21:56:39 +00:00
|
|
|
# (c) 2017 Copyright: Marko Oldenburg (leongaultier at gmail dot com)
|
2017-01-24 13:29:30 +00:00
|
|
|
# All rights reserved
|
|
|
|
#
|
|
|
|
# This script is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; either version 2 of the License, or
|
|
|
|
# any later version.
|
|
|
|
#
|
|
|
|
# The GNU General Public License can be found at
|
|
|
|
# http://www.gnu.org/copyleft/gpl.html.
|
|
|
|
# A copy is found in the textfile GPL.txt and important notices to the license
|
|
|
|
# from the author is found in LICENSE.txt distributed with these scripts.
|
|
|
|
#
|
|
|
|
# This script is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
#
|
|
|
|
# $Id$
|
|
|
|
#
|
|
|
|
###############################################################################
|
|
|
|
|
|
|
|
|
|
|
|
package main;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
use JSON;
|
|
|
|
|
|
|
|
|
2017-02-02 21:56:39 +00:00
|
|
|
my $version = "0.1.43";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Declare functions
|
|
|
|
sub HEOSPlayer_Initialize($);
|
|
|
|
sub HEOSPlayer_Define($$);
|
|
|
|
sub HEOSPlayer_Undef($$);
|
|
|
|
sub HEOSPlayer_Attr(@);
|
|
|
|
sub HEOSPlayer_Parse($$);
|
|
|
|
sub HEOSPlayer_WriteReadings($$);
|
|
|
|
sub HEOSPlayer_Set($$@);
|
2017-01-26 13:53:29 +00:00
|
|
|
sub HEOSPlayer_PreProcessingReadings($$);
|
2017-01-27 21:22:30 +00:00
|
|
|
sub HEOSPlayer_GetPlayerInfo($);
|
|
|
|
sub HEOSPlayer_GetPlayState($);
|
|
|
|
sub HEOSPlayer_GetNowPlayingMedia($);
|
2017-02-02 08:43:45 +00:00
|
|
|
sub HEOSPlayer_GetPlayMode($);
|
2017-01-27 21:22:30 +00:00
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
sub HEOSPlayer_Initialize($) {
|
|
|
|
|
|
|
|
my ($hash) = @_;
|
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
$hash->{Match} = '.*{"command":."player.*|.*{"command":."event/player.*|.*{"command":."event\/repeat_mode_changed.*|.*{"command":."event\/shuffle_mode_changed.*';
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
# Provider
|
|
|
|
$hash->{SetFn} = "HEOSPlayer_Set";
|
|
|
|
$hash->{DefFn} = "HEOSPlayer_Define";
|
|
|
|
$hash->{UndefFn} = "HEOSPlayer_Undef";
|
|
|
|
$hash->{AttrFn} = "HEOSPlayer_Attr";
|
|
|
|
$hash->{ParseFn} = "HEOSPlayer_Parse";
|
|
|
|
|
|
|
|
$hash->{AttrList} = "IODev ".
|
|
|
|
"disable:1 ".
|
|
|
|
$readingFnAttributes;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach my $d(sort keys %{$modules{HEOSPlayer}{defptr}}) {
|
|
|
|
my $hash = $modules{HEOSPlayer}{defptr}{$d};
|
|
|
|
$hash->{VERSION} = $version;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_Define($$) {
|
|
|
|
|
|
|
|
my ( $hash, $def ) = @_;
|
|
|
|
|
|
|
|
my @a = split( "[ \t]+", $def );
|
|
|
|
splice( @a, 1, 1 );
|
|
|
|
my $iodev;
|
|
|
|
my $i = 0;
|
|
|
|
|
|
|
|
foreach my $param ( @a ) {
|
|
|
|
if( $param =~ m/IODev=([^\s]*)/ ) {
|
|
|
|
$iodev = $1;
|
|
|
|
splice( @a, $i, 3 );
|
|
|
|
last;
|
|
|
|
}
|
|
|
|
|
|
|
|
$i++;
|
|
|
|
}
|
|
|
|
|
|
|
|
return "too few parameters: define <name> HEOSPlayer <pid>" if( @a < 2 );
|
|
|
|
|
|
|
|
my ($name,$pid) = @a;
|
|
|
|
|
|
|
|
$hash->{PID} = $pid;
|
|
|
|
$hash->{VERSION} = $version;
|
2017-02-02 08:43:45 +00:00
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
AssignIoPort($hash,$iodev) if( !$hash->{IODev} );
|
|
|
|
|
|
|
|
if(defined($hash->{IODev}->{NAME})) {
|
|
|
|
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - I/O device is " . $hash->{IODev}->{NAME};
|
|
|
|
} else {
|
|
|
|
|
|
|
|
Log3 $name, 1, "HEOSPlayer ($name) - no I/O device";
|
|
|
|
}
|
|
|
|
|
|
|
|
$iodev = $hash->{IODev}->{NAME};
|
|
|
|
|
|
|
|
|
|
|
|
my $code = abs($pid);
|
|
|
|
$code = $iodev."-".$code if( defined($iodev) );
|
|
|
|
my $d = $modules{HEOSPlayer}{defptr}{$code};
|
|
|
|
return "HEOSPlayer device $hash->{pid} on HEOSMaster $iodev already defined as $d->{NAME}."
|
|
|
|
if( defined($d)
|
|
|
|
&& $d->{IODev} == $hash->{IODev}
|
|
|
|
&& $d->{NAME} ne $name );
|
|
|
|
|
|
|
|
$modules{HEOSPlayer}{defptr}{$code} = $hash;
|
|
|
|
|
|
|
|
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - defined with Code: $code";
|
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
$attr{$name}{room} = "HEOS" if( !defined( $attr{$name}{room} ) );
|
|
|
|
$attr{$name}{devStateIcon} = "on:10px-kreis-gruen off:10px-kreis-rot" if( !defined( $attr{$name}{devStateIcon} ) );
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
if( $init_done ) {
|
2017-02-02 08:43:45 +00:00
|
|
|
InternalTimer( gettimeofday()+int(rand(5)), "HEOSPlayer_GetPlayerInfo", $hash, 0 );
|
|
|
|
InternalTimer( gettimeofday()+int(rand(10)), "HEOSPlayer_GetPlayState", $hash, 0 );
|
|
|
|
InternalTimer( gettimeofday()+int(rand(15)), "HEOSPlayer_GetNowPlayingMedia", $hash, 0 );
|
|
|
|
InternalTimer( gettimeofday()+int(rand(20)), "HEOSPlayer_GetPlayMode", $hash, 0 );
|
2017-01-26 13:53:29 +00:00
|
|
|
} else {
|
2017-02-02 08:43:45 +00:00
|
|
|
InternalTimer( gettimeofday()+15+int(rand(5)), "HEOSPlayer_GetPlayerInfo", $hash, 0 );
|
|
|
|
InternalTimer( gettimeofday()+15+int(rand(10)), "HEOSPlayer_GetPlayState", $hash, 0 );
|
|
|
|
InternalTimer( gettimeofday()+15+int(rand(15)), "HEOSPlayer_GetNowPlayingMedia", $hash, 0 );
|
|
|
|
InternalTimer( gettimeofday()+15+int(rand(20)), "HEOSPlayer_GetPlayMode", $hash, 0 );
|
2017-01-24 13:29:30 +00:00
|
|
|
}
|
2017-02-02 08:43:45 +00:00
|
|
|
|
|
|
|
readingsBeginUpdate($hash);
|
|
|
|
readingsBulkUpdate($hash, 'state','Initialized');
|
|
|
|
readingsBulkUpdate($hash, 'volumeUp', 5);
|
|
|
|
readingsBulkUpdate($hash, 'volumeDown', 5);
|
|
|
|
readingsEndUpdate($hash, 1);
|
|
|
|
|
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
return undef;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_Undef($$) {
|
|
|
|
|
|
|
|
my ( $hash, $arg ) = @_;
|
|
|
|
|
|
|
|
my $pid = $hash->{PID};
|
|
|
|
my $name = $hash->{NAME};
|
|
|
|
|
|
|
|
|
|
|
|
RemoveInternalTimer($hash);
|
|
|
|
|
|
|
|
my $code = abs($pid);
|
|
|
|
$code = $hash->{IODev}->{NAME} ."-". $code if( defined($hash->{IODev}->{NAME}) );
|
|
|
|
delete($modules{HEOSPlayer}{defptr}{$code});
|
2017-01-27 21:22:30 +00:00
|
|
|
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - device $name deleted with Code: $code";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
return undef;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_Attr(@) {
|
|
|
|
|
|
|
|
my ( $cmd, $name, $attrName, $attrVal ) = @_;
|
|
|
|
my $hash = $defs{$name};
|
|
|
|
my $token = $hash->{IODev}->{TOKEN};
|
|
|
|
|
|
|
|
if( $attrName eq "disable" ) {
|
|
|
|
if( $cmd eq "set" and $attrVal eq "1" ) {
|
|
|
|
readingsSingleUpdate ( $hash, "state", "disabled", 1 );
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - disabled";
|
|
|
|
}
|
|
|
|
|
|
|
|
elsif( $cmd eq "del" ) {
|
|
|
|
readingsSingleUpdate ( $hash, "state", "active", 1 );
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - enabled";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if( $attrName eq "disabledForIntervals" ) {
|
|
|
|
if( $cmd eq "set" ) {
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - enable disabledForIntervals";
|
|
|
|
readingsSingleUpdate ( $hash, "state", "Unknown", 1 );
|
|
|
|
}
|
|
|
|
|
|
|
|
elsif( $cmd eq "del" ) {
|
|
|
|
readingsSingleUpdate ( $hash, "state", "active", 1 );
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - delete disabledForIntervals";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_Set($$@) {
|
|
|
|
|
|
|
|
my ($hash, $name, @aa) = @_;
|
|
|
|
my ($cmd, @args) = @aa;
|
2017-01-26 13:53:29 +00:00
|
|
|
|
|
|
|
my $pid = $hash->{PID};
|
2017-01-24 13:29:30 +00:00
|
|
|
my $action;
|
|
|
|
my $heosCmd;
|
2017-02-02 08:43:45 +00:00
|
|
|
my $rvalue;
|
2017-01-26 13:53:29 +00:00
|
|
|
my $string = "pid=$pid";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
if( $cmd eq 'getPlayerInfo' ) {
|
|
|
|
return "usage: getPlayerInfo" if( @args != 0 );
|
2017-01-24 13:29:30 +00:00
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
$heosCmd = $cmd;
|
2017-01-26 13:53:29 +00:00
|
|
|
|
2017-01-26 20:53:39 +00:00
|
|
|
} elsif( $cmd eq 'getPlayState' ) {
|
|
|
|
return "usage: getPlayState" if( @args != 0 );
|
2017-01-26 13:53:29 +00:00
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
$heosCmd = $cmd;
|
|
|
|
|
|
|
|
} elsif( $cmd eq 'getPlayMode' ) {
|
|
|
|
return "usage: getPlayMode" if( @args != 0 );
|
|
|
|
|
|
|
|
$heosCmd = $cmd;
|
2017-01-26 13:53:29 +00:00
|
|
|
|
|
|
|
} elsif( $cmd eq 'getNowPlayingMedia' ) {
|
|
|
|
return "usage: getNowPlayingMedia" if( @args != 0 );
|
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
$heosCmd = $cmd;
|
|
|
|
|
|
|
|
} elsif( $cmd eq 'repeat' ) {
|
|
|
|
return "usage: repeat" if( @args != 1 );
|
|
|
|
|
|
|
|
$heosCmd = 'setPlayMode';
|
|
|
|
|
|
|
|
if($args[0] eq 'all') {
|
|
|
|
|
|
|
|
$rvalue = 'on_all';
|
|
|
|
|
|
|
|
} elsif($args[0] eq 'one') {
|
|
|
|
|
|
|
|
$rvalue = 'on_one';
|
|
|
|
}
|
|
|
|
|
|
|
|
$action = "repeat=$rvalue&shuffle=" . ReadingsVal($name,'shuffle','off');
|
|
|
|
|
|
|
|
} elsif( $cmd eq 'shuffle' ) {
|
|
|
|
return "usage: shuffle" if( @args != 1 );
|
|
|
|
|
|
|
|
$heosCmd = 'setPlayMode';
|
|
|
|
|
|
|
|
if(ReadingsVal($name,'repeat','off') eq 'all') {
|
|
|
|
|
|
|
|
$rvalue = 'on_all';
|
|
|
|
|
|
|
|
} elsif(ReadingsVal($name,'repeat','off') eq 'one') {
|
|
|
|
|
|
|
|
$rvalue = 'on_one';
|
|
|
|
}
|
|
|
|
|
|
|
|
$action = "repeat=$rvalue&shuffle=$args[0]";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
} elsif( $cmd eq 'play' ) {
|
|
|
|
return "usage: play" if( @args != 0 );
|
|
|
|
|
|
|
|
$heosCmd = 'setPlayState';
|
2017-01-27 21:22:30 +00:00
|
|
|
$action = "state=$cmd";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
} elsif( $cmd eq 'stop' ) {
|
|
|
|
return "usage: stop" if( @args != 0 );
|
|
|
|
|
|
|
|
$heosCmd = 'setPlayState';
|
2017-01-27 21:22:30 +00:00
|
|
|
$action = "state=$cmd";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
} elsif( $cmd eq 'pause' ) {
|
|
|
|
return "usage: pause" if( @args != 0 );
|
|
|
|
|
|
|
|
$heosCmd = 'setPlayState';
|
2017-01-27 21:22:30 +00:00
|
|
|
$action = "state=$cmd";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
} elsif( $cmd eq 'mute' ) {
|
|
|
|
return "usage: mute on/off" if( @args != 1 );
|
|
|
|
|
|
|
|
$heosCmd = 'setMute';
|
|
|
|
$action = "state=$args[0]";
|
|
|
|
|
|
|
|
} elsif( $cmd eq 'volume' ) {
|
|
|
|
return "usage: volume 0-100" if( @args != 1 );
|
|
|
|
|
|
|
|
$heosCmd = 'setVolume';
|
|
|
|
$action = "level=$args[0]";
|
2017-02-02 08:43:45 +00:00
|
|
|
|
|
|
|
} elsif( $cmd eq 'volumeUp' ) {
|
|
|
|
return "usage: volumeUp 0-10" if( @args != 1 );
|
|
|
|
|
|
|
|
$heosCmd = 'volumeUp';
|
|
|
|
$action = "step=$args[0]";
|
|
|
|
|
|
|
|
} elsif( $cmd eq 'volumeDown' ) {
|
|
|
|
return "usage: volumeDown 0-10" if( @args != 1 );
|
|
|
|
|
|
|
|
$heosCmd = 'volumeDown';
|
|
|
|
$action = "step=$args[0]";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
} else {
|
2017-02-02 08:43:45 +00:00
|
|
|
my $list = "getPlayerInfo:noArg getPlayState:noArg getNowPlayingMedia:noArg getPlayMode:noArg play:noArg stop:noArg pause:noArg mute:on,off volume:slider,0,5,100 volumeUp:slider,0,1,10 volumeDown:slider,0,1,10 repeat:one,all,off shuffle:on,off";
|
2017-01-24 13:29:30 +00:00
|
|
|
return "Unknown argument $cmd, choose one of $list";
|
|
|
|
}
|
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
|
|
|
|
$string .= "&$action" if( defined($action));
|
|
|
|
|
|
|
|
IOWrite($hash,"$heosCmd","$string");
|
2017-02-02 08:43:45 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - IOWrite: $heosCmd $string IODevHash=$hash->{IODev}";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
return undef;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_Parse($$) {
|
|
|
|
|
|
|
|
my ($io_hash,$json) = @_;
|
|
|
|
my $name = $io_hash->{NAME};
|
|
|
|
my $pid;
|
|
|
|
my $decode_json;
|
|
|
|
|
|
|
|
|
|
|
|
$decode_json = decode_json($json);
|
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - ParseFn wurde aufgerufen";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if( defined($decode_json->{pid}) ) {
|
|
|
|
|
|
|
|
$pid = $decode_json->{pid};
|
|
|
|
my $code = abs($pid);
|
|
|
|
$code = $io_hash->{NAME} ."-". $code if( defined($io_hash->{NAME}) );
|
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
if( my $hash = $modules{HEOSPlayer}{defptr}{$code} ) {
|
2017-02-02 08:43:45 +00:00
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
my $name = $hash->{NAME};
|
2017-01-28 16:18:40 +00:00
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
#IOWrite($hash,'getPlayerInfo',"pid=$hash->{PID}");
|
|
|
|
#IOWrite($hash,'getPlayState',"pid=$hash->{PID}"); Erst mal schauen ob es ohne das geht, wenn nicht wieder aktivieren
|
|
|
|
#IOWrite($hash,'getNowPlayingMedia',"pid=$hash->{PID}");
|
2017-01-28 16:18:40 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - find logical device: $hash->{NAME}";
|
2017-02-02 08:43:45 +00:00
|
|
|
Log3 $name, 5, "HEOSPlayer ($name) - PID direkt im root von decode_json gefunden";
|
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
return $hash->{NAME};
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
my $devname = "HEOSPlayer".abs($pid);
|
|
|
|
return "UNDEFINED $devname HEOSPlayer $pid IODev=$name";
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
#return Log3 $name, 3, "result not success"
|
|
|
|
#unless($decode_json->{heos}{result} eq "success"); # Klappt bei Events nicht!! Lieber Fehlermeldung im Reading
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
if( defined($decode_json->{payload}{pid}) ) {
|
|
|
|
$pid = $decode_json->{payload}{pid};
|
|
|
|
|
|
|
|
} elsif ( $decode_json->{heos}{message} =~ /^pid=/ ) {
|
2017-02-02 08:43:45 +00:00
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
my @pid = split('&', $decode_json->{heos}{message});
|
|
|
|
$pid = substr($pid[0],4);
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - PID[0]: $pid[0] and PID: $pid";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
my $code = abs($pid);
|
|
|
|
$code = $io_hash->{NAME} ."-". $code if( defined($io_hash->{NAME}) );
|
|
|
|
|
|
|
|
if( my $hash = $modules{HEOSPlayer}{defptr}{$code} ) {
|
|
|
|
my $name = $hash->{NAME};
|
|
|
|
HEOSPlayer_WriteReadings($hash,$decode_json);
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - find logical device: $hash->{NAME}";
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
return $hash->{NAME};
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
my $devname = "HEOSPlayer".abs($pid);
|
|
|
|
return "UNDEFINED $devname HEOSPlayer $pid IODev=$name";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_WriteReadings($$) {
|
|
|
|
|
|
|
|
my ($hash,$decode_json) = @_;
|
|
|
|
my $name = $hash->{NAME};
|
|
|
|
|
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - processing data to write readings";
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
############################
|
2017-01-26 13:53:29 +00:00
|
|
|
#### Aufbereiten der Daten soweit nötig (bei Events zum Beispiel)
|
2017-01-24 13:29:30 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
my $readingsHash = HEOSPlayer_PreProcessingReadings($hash,$decode_json)
|
2017-01-26 13:53:29 +00:00
|
|
|
if( $decode_json->{heos}{message} =~ /^pid=/ );
|
|
|
|
|
|
|
|
|
|
|
|
############################
|
|
|
|
#### schreiben der Readings
|
|
|
|
|
|
|
|
readingsBeginUpdate($hash);
|
2017-01-26 20:53:39 +00:00
|
|
|
|
|
|
|
### Event Readings
|
2017-01-28 16:06:00 +00:00
|
|
|
if( ref($readingsHash) eq "HASH" ) {
|
2017-01-26 20:53:39 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - response json Hash back from HEOSPlayer_PreProcessingReadings";
|
2017-01-26 20:53:39 +00:00
|
|
|
|
|
|
|
my $t;
|
|
|
|
my $v;
|
2017-01-27 21:22:30 +00:00
|
|
|
while( ( $t, $v ) = each $readingsHash ) {
|
2017-01-26 20:53:39 +00:00
|
|
|
if( defined( $v ) ) {
|
|
|
|
|
|
|
|
readingsBulkUpdate( $hash, $t, $v );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-01-24 13:29:30 +00:00
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
### PlayerInfos
|
2017-01-24 13:29:30 +00:00
|
|
|
readingsBulkUpdate( $hash, 'name', $decode_json->{payload}{name} );
|
|
|
|
readingsBulkUpdate( $hash, 'gid', $decode_json->{payload}{gid} );
|
|
|
|
readingsBulkUpdate( $hash, 'model', $decode_json->{payload}{model} );
|
|
|
|
readingsBulkUpdate( $hash, 'version', $decode_json->{payload}{version} );
|
|
|
|
readingsBulkUpdate( $hash, 'network', $decode_json->{payload}{network} );
|
|
|
|
readingsBulkUpdate( $hash, 'lineout', $decode_json->{payload}{lineout} );
|
|
|
|
readingsBulkUpdate( $hash, 'control', $decode_json->{payload}{control} );
|
|
|
|
readingsBulkUpdate( $hash, 'ip-address', $decode_json->{payload}{ip} );
|
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
### playing Infos
|
2017-01-27 21:22:30 +00:00
|
|
|
readingsBulkUpdate( $hash, 'currentMedia', $decode_json->{payload}{type} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentTitle', $decode_json->{payload}{song} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentAlbum', $decode_json->{payload}{album} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentArtist', $decode_json->{payload}{artist} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentImageUrl', $decode_json->{payload}{image_url} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentMid', $decode_json->{payload}{mid} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentQid', $decode_json->{payload}{qid} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentSid', $decode_json->{payload}{sid} );
|
|
|
|
readingsBulkUpdate( $hash, 'currentStation', $decode_json->{payload}{station} );
|
|
|
|
|
|
|
|
|
|
|
|
readingsBulkUpdate( $hash, 'state', 'on' );
|
2017-01-26 13:53:29 +00:00
|
|
|
readingsEndUpdate( $hash, 1 );
|
2017-01-24 13:29:30 +00:00
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
Log3 $name, 5, "HEOSPlayer ($name) - readings set for $name";
|
2017-01-24 13:29:30 +00:00
|
|
|
return undef;
|
|
|
|
}
|
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
###############
|
2017-01-27 21:22:30 +00:00
|
|
|
### my little Helpers
|
2017-01-26 13:53:29 +00:00
|
|
|
|
|
|
|
sub HEOSPlayer_PreProcessingReadings($$) {
|
|
|
|
|
|
|
|
my ($hash,$decode_json) = @_;
|
|
|
|
my $name = $hash->{NAME};
|
|
|
|
|
|
|
|
my $reading;
|
2017-01-27 21:22:30 +00:00
|
|
|
my %buffer;
|
2017-01-26 13:53:29 +00:00
|
|
|
|
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - preprocessing readings";
|
2017-01-26 13:53:29 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
if ( $decode_json->{heos}{command} =~ /play_state/ or $decode_json->{heos}{command} =~ /player_state_changed/ ) {
|
2017-01-26 13:53:29 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
my @value = split('&', $decode_json->{heos}{message});
|
|
|
|
$buffer{'playStatus'} = substr($value[1],6);
|
2017-01-26 20:53:39 +00:00
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
} elsif ( $decode_json->{heos}{command} =~ /volume_changed/ or $decode_json->{heos}{command} =~ /set_volume/ ) {
|
2017-01-26 13:53:29 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
my @value = split('&', $decode_json->{heos}{message});
|
|
|
|
$buffer{'volume'} = substr($value[1],6);
|
2017-02-02 08:43:45 +00:00
|
|
|
$buffer{'mute'} = substr($value[2],5) if( $decode_json->{heos}{command} =~ /volume_changed/ );
|
2017-01-26 20:53:39 +00:00
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
} elsif ( $decode_json->{heos}{command} =~ /play_mode/ ) {
|
2017-01-26 13:53:29 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
my @value = split('&', $decode_json->{heos}{message});
|
2017-02-02 08:43:45 +00:00
|
|
|
if(substr($value[1],7) eq 'on_all') {
|
|
|
|
|
|
|
|
$buffer{'repeat'} = 'all';
|
|
|
|
|
|
|
|
} elsif (substr($value[1],7) eq 'on_one') {
|
|
|
|
|
|
|
|
$buffer{'repeat'} = 'one';
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$buffer{'repeat'} = substr($value[1],7);
|
|
|
|
}
|
|
|
|
|
|
|
|
$buffer{'shuffle'} = substr($value[2],8);
|
|
|
|
|
|
|
|
} elsif ( $decode_json->{heos}{command} =~ /volume_up/ or $decode_json->{heos}{command} =~ /volume_down/ ) {
|
|
|
|
|
|
|
|
my @value = split('&', $decode_json->{heos}{message});
|
|
|
|
$buffer{'volumeUp'} = substr($value[1],5) if( $decode_json->{heos}{command} =~ /volume_up/ );
|
|
|
|
$buffer{'volumeDown'} = substr($value[1],5) if( $decode_json->{heos}{command} =~ /volume_down/ );
|
|
|
|
|
|
|
|
} elsif ( $decode_json->{heos}{command} =~ /repeat_mode_changed/ ) {
|
|
|
|
|
|
|
|
my @value = split('&', $decode_json->{heos}{message});
|
|
|
|
|
|
|
|
if(substr($value[1],7) eq 'on_all') {
|
|
|
|
|
|
|
|
$buffer{'repeat'} = 'all';
|
|
|
|
|
|
|
|
} elsif (substr($value[1],7) eq 'on_one') {
|
|
|
|
|
|
|
|
$buffer{'repeat'} = 'one';
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
$buffer{'repeat'} = substr($value[1],7);
|
|
|
|
}
|
|
|
|
|
|
|
|
} elsif ( $decode_json->{heos}{command} =~ /shuffle_mode_changed/ ) {
|
|
|
|
|
|
|
|
my @value = split('&', $decode_json->{heos}{message});
|
|
|
|
$buffer{'shuffle'} = substr($value[1],8);
|
2017-01-27 21:22:30 +00:00
|
|
|
|
|
|
|
} elsif ( $decode_json->{heos}{command} =~ /player_now_playing_changed/ ) {
|
2017-01-26 20:53:39 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
IOWrite($hash,'getNowPlayingMedia',"pid=$hash->{PID}");
|
2017-01-26 13:53:29 +00:00
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
Log3 $name, 3, "HEOSPlayer ($name) - no match found";
|
2017-02-02 08:43:45 +00:00
|
|
|
return undef;
|
2017-01-26 13:53:29 +00:00
|
|
|
}
|
|
|
|
|
2017-01-26 20:53:39 +00:00
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
Log3 $name, 4, "HEOSPlayer ($name) - Match found for decode_json";
|
|
|
|
return \%buffer;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_GetPlayerInfo($) {
|
|
|
|
|
|
|
|
my $hash = shift;
|
|
|
|
|
|
|
|
RemoveInternalTimer($hash,'HEOSPlayer_GetPlayerInfo');
|
|
|
|
IOWrite($hash,'getPlayerInfo',"pid=$hash->{PID}");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
sub HEOSPlayer_GetPlayState($) {
|
|
|
|
|
|
|
|
my $hash = shift;
|
|
|
|
|
|
|
|
RemoveInternalTimer($hash,'HEOSPlayer_GetPlayState');
|
|
|
|
IOWrite($hash,'getPlayState',"pid=$hash->{PID}");
|
|
|
|
|
2017-01-26 13:53:29 +00:00
|
|
|
}
|
|
|
|
|
2017-02-02 08:43:45 +00:00
|
|
|
sub HEOSPlayer_GetPlayMode($) {
|
|
|
|
|
|
|
|
my $hash = shift;
|
|
|
|
|
|
|
|
RemoveInternalTimer($hash,'HEOSPlayer_GetPlayMode');
|
|
|
|
IOWrite($hash,'getPlayMode',"pid=$hash->{PID}");
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-01-27 21:22:30 +00:00
|
|
|
sub HEOSPlayer_GetNowPlayingMedia($) {
|
|
|
|
|
|
|
|
my $hash = shift;
|
|
|
|
|
|
|
|
RemoveInternalTimer($hash,'HEOSPlayer_GetNowPlayingMedia');
|
|
|
|
IOWrite($hash,'getNowPlayingMedia',"pid=$hash->{PID}");
|
|
|
|
|
|
|
|
}
|
2017-01-24 13:29:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1;
|