From f8d545b33a205f730b9ce89326cd8a353796a6af Mon Sep 17 00:00:00 2001 From: Josef 'veloc1ty' Stautner Date: Thu, 14 Jan 2016 20:43:32 +0100 Subject: [PATCH 1/2] Added function setValueForMemberFromArray --- hue.php | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) diff --git a/hue.php b/hue.php index 7da4773..da00623 100755 --- a/hue.php +++ b/hue.php @@ -45,6 +45,30 @@ public function __construct( $parent, $lightid, $json ) } } + /** + * This function searches the value of a key from an array. + * If no value is found on the first try the subarray 'state' is searched + * if present. + * + * @param $member ref The member function to be set when a value is found + * @param $array array The array to be searched + * @param $key string The key which should be searched in the array + * @return bool true if value was found, false if not + **/ + private function setValueForMemberFromArray(&$member, &$array, $key) { + if ( array_key_exists($key, $array) ) { + $member = $array[$key]; + } + else if ( array_key_exists('state', $array) && + array_key_exists($key, $array['state']) ) { + $member = $array['state'][$key]; + } + else { + return false; + } + + return true; + } public function id() { From bcb7533946d97fd5bd31a02bfcde15f68399b84b Mon Sep 17 00:00:00 2001 From: Josef 'veloc1ty' Stautner Date: Thu, 14 Jan 2016 20:46:37 +0100 Subject: [PATCH 2/2] Implemented function setValueForMemberFromArray in constructor --- hue.php | 32 +++++++++++++++++++------------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/hue.php b/hue.php index da00623..9e9730c 100755 --- a/hue.php +++ b/hue.php @@ -29,19 +29,25 @@ public function __construct( $parent, $lightid, $json ) if ( isset( $data["state"] ) ) { $this->id = $lightid; - $this->name = $data["name"]; - $this->type = $data["type"]; - $this->modelid = $data["modelid"]; - $this->swversion = $data["swversion"]; - $this->state = $data["state"]["on"]; - $this->reachable = $data["state"]["reachable"]; - $this->bri = $data["state"]["bri"]; - $this->hue = $data["state"]["hue"]; - $this->sat = $data["state"]["sat"]; - $this->ct = $data["state"]["ct"]; - $this->alert = $data["state"]["alert"]; - $this->effect = $data["state"]["effect"]; - $this->colormode = $data["state"]["colormode"]; + + $this->setValueForMemberFromArray($this->name, $data, 'name'); + $this->setValueForMemberFromArray($this->type, $data, 'type'); + $this->setValueForMemberFromArray($this->modelid, $data, + 'modelid'); + $this->setValueForMemberFromArray($this->swversion, $data, + 'swversion'); + $this->setValueForMemberFromArray($this->state, $data, 'on'); + $this->setValueForMemberFromArray($this->reachable, $data, + 'reachable'); + $this->setValueForMemberFromArray($this->bri, $data, 'bri'); + # Field $data['state']['hue'] does not exist. Remove this? + $this->setValueForMemberFromArray($this->hue, $data, 'hue'); + $this->setValueForMemberFromArray($this->sat, $data, 'sat'); + $this->setValueForMemberFromArray($this->ct, $data, 'ct'); + $this->setValueForMemberFromArray($this->alert, $data, 'alert'); + $this->setValueForMemberFromArray($this->effect, $data, 'effect'); + $this->setValueForMemberFromArray($this->colormode, $data, + 'colormode'); } }