1
0

modified init and some debugging

This commit is contained in:
2022-01-06 13:03:26 +01:00
parent 85a7fd7ed9
commit 004c6aa572
10 changed files with 178 additions and 34 deletions

View File

@ -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);
}
}