PHP_SMART_HOME_V3/class/AutomationManager.php

128 lines
4.0 KiB
PHP
Raw Normal View History

2019-08-23 11:39:42 +00:00
<?php
class AutomationManager{
public static $automation;
public function remove($automationId) {
return Db::command ('DELETE FROM automation WHERE automation_id=?', array ($automationId));
}
public function deactive($automationId) {
$automation = Db::loadOne ("SELECT * FROM automation WHERE automation_id=?" , array ($automationId));
$flipedValue = ($automation['active'] == 1 ? 0 : 1);
return Db::command ('UPDATE automation SET active = ? WHERE automation_id=?', array ($flipedValue,$automationId));
}
public function create ($name, $onDays, $doCode, $ifCode) {
$scene = array (
'name' => $name,
'on_days' => $onDays,
2019-08-24 11:07:07 +00:00
'if_something' => $ifCode,
'do_something' => $doCode,
2019-08-23 11:39:42 +00:00
);
try {
Db::add ('automation', $scene);
} catch(PDOException $error) {
echo $error->getMessage();
die();
}
}
public function getAll(){
return Db::loadAll ("SELECT * FROM automation");
}
public function executeAll(){
2019-08-24 11:07:07 +00:00
$dateTimeOffset;
2019-08-23 11:39:42 +00:00
$automations = Db::loadAll ("SELECT * FROM automation");
$dayNameNow = strtolower (date('D', time()));
2019-08-24 11:07:07 +00:00
2019-08-23 11:39:42 +00:00
foreach ($automations as $automation) {
2019-08-24 11:07:07 +00:00
$onValue = json_decode($automation['if_something'], true);
2019-08-23 11:39:42 +00:00
$sceneDoJson = $automation['do_something'];
$actionDays = json_decode($automation['on_days'], true);
$value = time();
2019-08-23 12:20:58 +00:00
$run = false;
$restart = false;
2019-08-23 11:39:42 +00:00
if ($automation['active'] != 0){
if (in_array($dayNameNow, $actionDays)){
2019-08-24 11:07:07 +00:00
if (in_array($onValue['type'], ['sunSet','time','now'])) {
if ($onValue['type'] == 'sunSet') {
2019-08-23 12:20:58 +00:00
$value = date_sunset($value, SUNFUNCS_RET_TIMESTAMP, 50.0755381 , 14.4378005, 90, $dateTimeOffset);
2019-08-24 11:07:07 +00:00
} else if ($onValue['type'] == 'sunRise') {
2019-08-23 12:20:58 +00:00
$value = date_sunrise($value, SUNFUNCS_RET_TIMESTAMP, 50.0755381 , 14.4378005, 90, $dateTimeOffset);
2019-08-24 11:07:07 +00:00
} else if ($onValue['type'] == 'time') {
$onValue = explode(':',$onValue['value']);
2019-08-23 12:20:58 +00:00
$today = date_create('now');
$onValue = $today->setTime($onValue[0], $onValue[1]);
$value = $today->getTimestamp();
}
2019-08-23 11:39:42 +00:00
2019-08-24 11:07:07 +00:00
/*
Echo "Spouštění Automatizace";
echo "Aktual" . date( "HH:mm", strtotime(time()));
echo "Run At" . date( "HH:mm", strtotime($value));
*/
2019-08-23 12:20:58 +00:00
if (time() > $value){
if ($automation['executed'] == 0){
$run = true;
} else if (time() < $value && $automation['executed'] = 1) { //recovery realowing of automation
$restart = true;
2019-08-23 11:39:42 +00:00
}
}
} else if ($onValue['type'] == 'outHome') {
2019-08-23 12:20:58 +00:00
} else if ($onValue['type'] == 'inHome') {
2019-08-23 12:20:58 +00:00
} else if ($onValue['type'] == 'noOneHome') {
$users = UserManager::getUsers();
$membersHome = 0;
foreach ($users as $key => $user) {
if ($user['at_home'] == 'true'){
$membersHome++;
}
}
if ($membersHome == 0 && $automation['executed'] == 0) {
$run = true;
} else if ($membersHome > 0 && $automation['executed'] == 1){
$restart = true;
}
} else if ($onValue['type'] == 'someOneHome') {
$users = UserManager::getUsers();
$membersHome = 0;
foreach ($users as $key => $user) {
if ($user['at_home'] == 'true'){
$membersHome++;
}
}
2019-08-26 15:32:54 +00:00
if ($membersHome == 0 && $automation['executed'] == 1) {
$restart = true;
2019-08-26 15:32:54 +00:00
} else if ($membersHome > 0 && $automation['executed'] == 0){
$run = true;
}
/*echo "Someone Home". '<br>';
echo "at home" . $membersHome. '<br>';
echo "run" . $run. '<br>';
echo "restart" . $restart. '<br>';*/
2019-08-23 12:20:58 +00:00
}
//finalization
if ($run) {
$sceneDoArray = json_decode($sceneDoJson);
foreach ($sceneDoArray as $deviceId => $deviceState) {
RecordManager::create($deviceId, 'on/off', $deviceState);
}
Db::edit('automation', array('executed' => 1), 'WHERE automation_id = ?', array($automation['automation_id']));
} else if ($restart) {
2019-08-23 11:39:42 +00:00
Db::edit('automation', array('executed' => 0), 'WHERE automation_id = ?', array($automation['automation_id']));
}
}
}
}
}
2019-08-24 11:07:07 +00:00
}