modified init and some debugging
This commit is contained in:
		@@ -3,17 +3,22 @@
 | 
			
		||||
class rdc_sdb_eclairage
 | 
			
		||||
{
 | 
			
		||||
	public $hookName = "rdc_sdb_eclairage";
 | 
			
		||||
	public $active = false;
 | 
			
		||||
	public $active = true;
 | 
			
		||||
 | 
			
		||||
	// list of devices we are listening to
 | 
			
		||||
	// 0x00158d0003f0f3b4	douche mvmnt
 | 
			
		||||
	// 0x842e14fffe1c0cd1	plafond mvmnt
 | 
			
		||||
	// 0x00124b0022ec05dc	mvmnt
 | 
			
		||||
	// 0x00158d0005c1a998	module commutateur => state_l1
 | 
			
		||||
	private $devicelist = array("0x00158d0003f0f3b4", "0x842e14fffe1c0cd1", "0x00124b0022ec05dc");
 | 
			
		||||
	private $devicelist = array(
 | 
			
		||||
		"0x00158d0003f0f3b4" => "occupancy",
 | 
			
		||||
		"0x842e14fffe1c0cd1" => "occupancy",
 | 
			
		||||
		"0x00124b0022ec05dc" => "occupancy",
 | 
			
		||||
		RDC_SDB_WC_ECLAIRAGE => "state_l1"
 | 
			
		||||
	);
 | 
			
		||||
 | 
			
		||||
	public $delay = 3;				// amount of time in $timeunit
 | 
			
		||||
	public $delayManual = 15;		// amount of time in $timeunit for manual mode
 | 
			
		||||
	public $delayManual = 10;		// amount of time in $timeunit for manual mode
 | 
			
		||||
	public $timeUnit = "minute";	// unit of time for delay, second, minute, day, week, month, year
 | 
			
		||||
 | 
			
		||||
	function __construct()
 | 
			
		||||
@@ -23,18 +28,19 @@ class rdc_sdb_eclairage
 | 
			
		||||
		// assigne the function to the sensors devices
 | 
			
		||||
		if ($this->active === true)
 | 
			
		||||
		{
 | 
			
		||||
			foreach ($this->devicelist as $ieeeAddress => $param)
 | 
			
		||||
			foreach ($this->devicelist as $ieeeAddress => $property)
 | 
			
		||||
			{
 | 
			
		||||
				$indexDevices[$ieeeAddress]->$param["functions"][] = array($this,"callback");
 | 
			
		||||
				$indexDevices[$ieeeAddress]->$property["functions"][] = array($this,"callback");
 | 
			
		||||
				print_r($indexDevices[$ieeeAddress]);
 | 
			
		||||
			}
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	// callback fonction. Is called with these 4 parameters
 | 
			
		||||
	public function callBack(&$device, $param, $value)
 | 
			
		||||
	public function callBack(&$device, $property, $value)
 | 
			
		||||
	{
 | 
			
		||||
		global $devices, $indexDevices;
 | 
			
		||||
		switch($param)
 | 
			
		||||
		switch($property)
 | 
			
		||||
		{
 | 
			
		||||
			case "occupancy":
 | 
			
		||||
				if ($value == ON)
 | 
			
		||||
@@ -47,7 +53,6 @@ class rdc_sdb_eclairage
 | 
			
		||||
			case "state_l1":
 | 
			
		||||
				if ($value == ON)
 | 
			
		||||
				{
 | 
			
		||||
					$this->send("ON");
 | 
			
		||||
					setDelay($device, $this->delayManual, $this->timeUnit, "state_l1", "OFF", true);
 | 
			
		||||
					$device->method = MANUAL;
 | 
			
		||||
				}elseif ($value = OFF)
 | 
			
		||||
@@ -56,7 +61,7 @@ class rdc_sdb_eclairage
 | 
			
		||||
				}
 | 
			
		||||
				break;
 | 
			
		||||
		}
 | 
			
		||||
		logger (INFO, _("%s: notification received from MQTT from %s => parameter: %s value: %s"), $this->hookName, $device->friendlyName, $param, $value);
 | 
			
		||||
		logger (INFO, _("%s: notification received from MQTT from %s => parameter: %s value: %s"), $this->hookName, $device->friendlyName, $property, $value);
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	private function send($state)
 | 
			
		||||
@@ -67,7 +72,6 @@ class rdc_sdb_eclairage
 | 
			
		||||
		logger(INFO, sprintf(_("publishing message: %s to %s"), $msg, $device->friendlyName));
 | 
			
		||||
		$device->payload = $msg;
 | 
			
		||||
		$device->set(null);
 | 
			
		||||
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user