Compare commits
	
		
			5 Commits
		
	
	
		
			135dfcb666
			...
			remasterin
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 0045bdeb84 | ||
|  | 9c565d90fa | ||
|  | f80b9a6b43 | ||
|  | 49f2354908 | ||
|  | 541ea0002f | 
| @@ -18,5 +18,6 @@ RewriteRule (.*) ./public/$1 [L] | |||||||
|  |  | ||||||
| # serve all other request as query parameters | # serve all other request as query parameters | ||||||
| RewriteRule (.*) ./public/index.php?url=$1 [L,QSA] | RewriteRule (.*) ./public/index.php?url=$1 [L,QSA] | ||||||
|  | #RewriteRule ^(.*?\.php)/([^/]*)/([^/]*)(/.+)? ./public/index.php?url=$1&$2&$3 [NC,N,QSA] | ||||||
|  |  | ||||||
| AddType application/x-httpd-php .php .phtml | AddType application/x-httpd-php .php .phtml | ||||||
|   | |||||||
| @@ -3,6 +3,8 @@ | |||||||
| error_reporting(E_ALL); | error_reporting(E_ALL); | ||||||
| ini_set( 'display_errors','1'); | ini_set( 'display_errors','1'); | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
| //setup | //setup | ||||||
| parse_str($_SERVER['QUERY_STRING'], $params); | parse_str($_SERVER['QUERY_STRING'], $params); | ||||||
| if (defined ("BASEDIR")) { | if (defined ("BASEDIR")) { | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ $router->setDefault(function(){ | |||||||
| 	unset($logManager); | 	unset($logManager); | ||||||
| }); | }); | ||||||
|  |  | ||||||
|  |  | ||||||
| //Pages | //Pages | ||||||
| $router->any('/', 'Log'); | $router->any('/', 'Log'); | ||||||
| $router->any('/log', 'Log'); | $router->any('/log', 'Log'); | ||||||
| @@ -46,6 +47,7 @@ $router->get('/api/server/log', 'ServerApi@logStatus'); | |||||||
| $router->post('/api/widgets/{widgetId}/run', 'WidgetApi@run'); | $router->post('/api/widgets/{widgetId}/run', 'WidgetApi@run'); | ||||||
| $router->get('/api/widgets/{widgetId}/detail', 'WidgetApi@detail'); | $router->get('/api/widgets/{widgetId}/detail', 'WidgetApi@detail'); | ||||||
| $router->get('/api/widgets/{widgetId}/detail/{period}', 'WidgetApi@detail'); | $router->get('/api/widgets/{widgetId}/detail/{period}', 'WidgetApi@detail'); | ||||||
|  | $router->post('/api/widgets/{widgetId}/edit', 'WidgetApi@edit'); | ||||||
|  |  | ||||||
| //Vue APP - Automations Endpoints | //Vue APP - Automations Endpoints | ||||||
| $router->get('/api/automations', 'AutomationsApi@default'); | $router->get('/api/automations', 'AutomationsApi@default'); | ||||||
| @@ -61,8 +63,10 @@ $router->post('/cron/automations', 'CronApi@automations'); | |||||||
|  |  | ||||||
|  |  | ||||||
| //Google Home - API | //Google Home - API | ||||||
| $router->any('/api/HA/auth', 'Oauth'); | $router->any('/api/HA/auth', 'Oauth@default'); | ||||||
|  | $router->any('/api/HA/token', 'Oauth@token'); | ||||||
| $router->any('/api/HA', 'GoogleHomeApi@response'); | $router->any('/api/HA', 'GoogleHomeApi@response'); | ||||||
|  | $router->any('/api/HA/', 'GoogleHomeApi@response'); | ||||||
|  |  | ||||||
|  |  | ||||||
| //Endpoints API | //Endpoints API | ||||||
| @@ -71,6 +75,9 @@ $router->any('/api/update/', 'UpdatesApi@default'); | |||||||
| $router->any('/api/users/status', 'UsersApi@status'); | $router->any('/api/users/status', 'UsersApi@status'); | ||||||
| $router->any('/api/users/subscribe', 'UsersApi@subscribe'); | $router->any('/api/users/subscribe', 'UsersApi@subscribe'); | ||||||
|  |  | ||||||
|  | //Endpoints API - V2 | ||||||
|  | $router->post('/api/v2/endpoint/', 'EndpointsApi@default_v2'); | ||||||
|  | $router->post('/api/v2/endpoint/cofiguration', 'EndpointsApi@cofiguration_v2'); | ||||||
|  |  | ||||||
| // examples | // examples | ||||||
| $router->any('/api/example', 'ExampleApi@example'); | $router->any('/api/example', 'ExampleApi@example'); | ||||||
|   | |||||||
| @@ -1,6 +1,8 @@ | |||||||
| <?php | <?php | ||||||
| class EndpointsApi extends ApiController{ | class EndpointsApi extends ApiController | ||||||
| 	public function default(){ | { | ||||||
|  | 	public function default() | ||||||
|  | 	{ | ||||||
| 		// $this->requireAuth(); | 		// $this->requireAuth(); | ||||||
| 		$obj = $this->input; | 		$obj = $this->input; | ||||||
|  |  | ||||||
| @@ -8,7 +10,7 @@ class EndpointsApi extends ApiController{ | |||||||
| 		$command = "null"; | 		$command = "null"; | ||||||
|  |  | ||||||
| 		//Log | 		//Log | ||||||
| 		$logManager = new LogManager('../logs/api/'. date("Y-m-d").'.log'); | 		$logManager = new LogManager('../logs/api/' . date("Y-m-d") . '.log'); | ||||||
| 		$logManager->setLevel(LOGLEVEL); | 		$logManager->setLevel(LOGLEVEL); | ||||||
|  |  | ||||||
| 		//Token Checks | 		//Token Checks | ||||||
| @@ -65,7 +67,7 @@ class EndpointsApi extends ApiController{ | |||||||
| 		DeviceManager::setHeartbeat($device['device_id']); | 		DeviceManager::setHeartbeat($device['device_id']); | ||||||
|  |  | ||||||
| 		//Diagnostic | 		//Diagnostic | ||||||
| 		if (isset($obj['settings'])){ | 		if (isset($obj['settings'])) { | ||||||
| 			$data = ['mac' => $obj['settings']["network"]["mac"], 'ip_address' => $obj['settings']["network"]["ip"]]; | 			$data = ['mac' => $obj['settings']["network"]["mac"], 'ip_address' => $obj['settings']["network"]["ip"]]; | ||||||
| 			if (array_key_exists("firmware_hash", $obj['settings'])) { | 			if (array_key_exists("firmware_hash", $obj['settings'])) { | ||||||
| 				$data['firmware_hash'] = $obj['settings']["firmware_hash"]; | 				$data['firmware_hash'] = $obj['settings']["firmware_hash"]; | ||||||
| @@ -74,11 +76,11 @@ class EndpointsApi extends ApiController{ | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		//Log Data Save | 		//Log Data Save | ||||||
| 		if (isset($obj['logs'])){ | 		if (isset($obj['logs'])) { | ||||||
| 			foreach ($obj['logs'] as $log) { | 			foreach ($obj['logs'] as $log) { | ||||||
| 				$deviceLogManager = new LogManager('../logs/devices/'. date("Y-m-d").'.log'); | 				$deviceLogManager = new LogManager('../logs/devices/' . date("Y-m-d") . '.log'); | ||||||
| 				$deviceLogManager->setLevel(LOGLEVEL); | 				$deviceLogManager->setLevel(LOGLEVEL); | ||||||
| 				if ($log != 'HTTP_UPDATE_FAILD code-102 messageFile Not Found (404)'){ | 				if ($log != 'HTTP_UPDATE_FAILD code-102 messageFile Not Found (404)') { | ||||||
| 					$deviceLogManager->write("[Device Log Msg] Device_ID " . $device['device_id'] . "->" . $log, LogRecordTypes::ERROR); | 					$deviceLogManager->write("[Device Log Msg] Device_ID " . $device['device_id'] . "->" . $log, LogRecordTypes::ERROR); | ||||||
| 				} | 				} | ||||||
| 				unset($deviceLogManager); | 				unset($deviceLogManager); | ||||||
| @@ -91,13 +93,12 @@ class EndpointsApi extends ApiController{ | |||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		// Issuing command | 		// Issuing command | ||||||
| 		if ($command == "null"){ | 		if ($command == "null") { | ||||||
| 			$deviceCommand = $device["command"]; | 			$deviceCommand = $device["command"]; | ||||||
| 			if ($deviceCommand != '' && $deviceCommand != null && $deviceCommand != "null") | 			if ($deviceCommand != '' && $deviceCommand != null && $deviceCommand != "null") { | ||||||
| 			{ |  | ||||||
| 				$command = $deviceCommand; | 				$command = $deviceCommand; | ||||||
| 				$data = [ | 				$data = [ | ||||||
| 					'command'=>'null' | 					'command' => 'null' | ||||||
| 				]; | 				]; | ||||||
| 				DeviceManager::editByToken($obj['token'], $data); | 				DeviceManager::editByToken($obj['token'], $data); | ||||||
| 				$logManager->write("[API] Device_ID " . $device['device_id'] . " executing command " . $command, LogRecordTypes::INFO); | 				$logManager->write("[API] Device_ID " . $device['device_id'] . " executing command " . $command, LogRecordTypes::INFO); | ||||||
| @@ -115,7 +116,7 @@ class EndpointsApi extends ApiController{ | |||||||
| 				} | 				} | ||||||
|  |  | ||||||
| 				$subDeviceLastReordValue[$key] = $value['value']; | 				$subDeviceLastReordValue[$key] = $value['value']; | ||||||
| 				RecordManager::create($device['device_id'], $key, round($value['value'],3), 'device'); | 				RecordManager::create($device['device_id'], $key, round($value['value'], 3), 'device'); | ||||||
| 				$logManager->write("[API] Device_ID " . $device['device_id'] . " writed value " . $key . ' ' . $value['value'], LogRecordTypes::INFO); | 				$logManager->write("[API] Device_ID " . $device['device_id'] . " writed value " . $key . ' ' . $value['value'], LogRecordTypes::INFO); | ||||||
|  |  | ||||||
| 				//notification | 				//notification | ||||||
| @@ -127,7 +128,7 @@ class EndpointsApi extends ApiController{ | |||||||
| 						case 'door': | 						case 'door': | ||||||
| 							$notificationData = [ | 							$notificationData = [ | ||||||
| 								'title' => 'Info', | 								'title' => 'Info', | ||||||
| 								'body' => 'Someone just open up '.$device['name'], | 								'body' => 'Someone just open up ' . $device['name'], | ||||||
| 								'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', | 								'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', | ||||||
| 							]; | 							]; | ||||||
|  |  | ||||||
| @@ -135,12 +136,12 @@ class EndpointsApi extends ApiController{ | |||||||
| 						case 'water': | 						case 'water': | ||||||
| 							$notificationData = [ | 							$notificationData = [ | ||||||
| 								'title' => 'Alert', | 								'title' => 'Alert', | ||||||
| 								'body' => 'Wather leak detected by '.$device['name'], | 								'body' => 'Wather leak detected by ' . $device['name'], | ||||||
| 								'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', | 								'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', | ||||||
| 							]; | 							]; | ||||||
| 							break; | 							break; | ||||||
| 					} | 					} | ||||||
| 					if (DEBUGMOD) $notificationData['body'] .= ' value='.$value['value']; | 					if (DEBUGMOD) $notificationData['body'] .= ' value=' . $value['value']; | ||||||
| 					if ($notificationData != []) { | 					if ($notificationData != []) { | ||||||
| 						$subscribers = $notificationMng::getSubscription(); | 						$subscribers = $notificationMng::getSubscription(); | ||||||
| 						foreach ($subscribers as $key => $subscriber) { | 						foreach ($subscribers as $key => $subscriber) { | ||||||
| @@ -169,9 +170,9 @@ class EndpointsApi extends ApiController{ | |||||||
| 			foreach ($subDevicesData as $key => $subDeviceData) { | 			foreach ($subDevicesData as $key => $subDeviceData) { | ||||||
| 				$subDeviceId = $subDeviceData['subdevice_id']; | 				$subDeviceId = $subDeviceData['subdevice_id']; | ||||||
| 				$subDeviceLastReord = RecordManager::getLastRecord($subDeviceId); | 				$subDeviceLastReord = RecordManager::getLastRecord($subDeviceId); | ||||||
| 				if (!empty ($subDeviceLastReord)) { | 				if (!empty($subDeviceLastReord)) { | ||||||
| 					$subDeviceLastReordValue[$subDeviceData['type']] = $subDeviceLastReord['value']; | 					$subDeviceLastReordValue[$subDeviceData['type']] = $subDeviceLastReord['value']; | ||||||
| 					if ($subDeviceLastReord['execuded'] == 0){ | 					if ($subDeviceLastReord['execuded'] == 0) { | ||||||
| 						$logManager->write("[API] subDevice_ID " . $subDeviceId . " executed comand with value " . json_encode($subDeviceLastReordValue) . " executed " . $subDeviceLastReord['execuded'], LogRecordTypes::INFO); | 						$logManager->write("[API] subDevice_ID " . $subDeviceId . " executed comand with value " . json_encode($subDeviceLastReordValue) . " executed " . $subDeviceLastReord['execuded'], LogRecordTypes::INFO); | ||||||
| 						RecordManager::setExecuted($subDeviceLastReord['record_id']); | 						RecordManager::setExecuted($subDeviceLastReord['record_id']); | ||||||
| 					} | 					} | ||||||
| @@ -193,4 +194,77 @@ class EndpointsApi extends ApiController{ | |||||||
| 		//unset($logManager); //TODO: Opravit | 		//unset($logManager); //TODO: Opravit | ||||||
| 		die(); | 		die(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	protected function requireAuth() | ||||||
|  | 	{ | ||||||
|  | 		if (isset($_SERVER['HTTP_AUTHORIZATION'])) { | ||||||
|  | 			// TODO: call appropriate class/method | ||||||
|  | 			$deviceManager = new DeviceManager(); | ||||||
|  | 			list($type, $hash) = explode(' ', $_SERVER['HTTP_AUTHORIZATION']); | ||||||
|  | 			$this->authenticated = $deviceManager->approved($hash); | ||||||
|  | 			return $hash; | ||||||
|  | 			if (!$this->authenticated) { | ||||||
|  | 				throw new Exception("Authorization required", 401); | ||||||
|  | 			} | ||||||
|  | 		} else { | ||||||
|  | 			throw new Exception("Authorization required", 401); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public function default_v2() | ||||||
|  | 	{ | ||||||
|  | 		$token = $this->requireAuth(); | ||||||
|  | 		$obj = $this->input; | ||||||
|  | 		$response = []; | ||||||
|  |  | ||||||
|  | 		$device = DeviceManager::getDeviceByToken($token); | ||||||
|  | 		DeviceManager::setHeartbeat($device['device_id']); | ||||||
|  |  | ||||||
|  | 		// Issue command | ||||||
|  | 		$deviceCommand = $device["command"]; | ||||||
|  | 		if ($deviceCommand != '' && $deviceCommand != null && $deviceCommand != "null") { | ||||||
|  | 			$response['command'] = $deviceCommand; | ||||||
|  | 			DeviceManager::editByToken($obj['token'], ['command' => 'null']); | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		$subDevicesData = SubDeviceManager::getAllSubDevices($device['device_id']); | ||||||
|  | 		if (count($subDevicesData) > 0) { | ||||||
|  | 			foreach ($subDevicesData as $key => $subDeviceData) { | ||||||
|  | 				$subDeviceId = $subDeviceData['subdevice_id']; | ||||||
|  | 				$subDeviceLastReord = RecordManager::getLastRecord($subDeviceId); | ||||||
|  | 				if (!empty($subDeviceLastReord)) { | ||||||
|  | 					$response['values'][$subDeviceData['type']] = $subDeviceLastReord['value']; | ||||||
|  | 					if ($subDeviceLastReord['execuded'] == 0) { | ||||||
|  | 						RecordManager::setExecuted($subDeviceLastReord['record_id']); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		$this->response($response, 200); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	public function cofiguration_v2() | ||||||
|  | 	{ | ||||||
|  | 		$token = $this->requireAuth(); | ||||||
|  | 		$response = []; | ||||||
|  |  | ||||||
|  | 		$device = DeviceManager::getDeviceByToken($token); | ||||||
|  | 		DeviceManager::setHeartbeat($device['device_id']); | ||||||
|  |  | ||||||
|  | 		if (!empty($device["name"]) && isset($device["name"])) $response["nettwork"]['hostname'] = $this->nameToHostname($device["name"]); | ||||||
|  | 		if (!empty($device["ip_address"]) && isset($device["ip_address"])) $response["nettwork"]['ip'] = $device["ip_address"]; | ||||||
|  | 		if (!empty($device["gateway"]) && isset($device["gateway"])) $response["nettwork"]['gateway'] = $device["gateway"]; | ||||||
|  | 		if (!empty($device["dns"]) && isset($device["dns"])) $response["nettwork"]['dns'] = $device["dns"]; | ||||||
|  | 		if (!empty($device["sleep_time"]) && isset($device["sleep_time"])) $response["sleep"] = $device["sleep_time"]; | ||||||
|  |  | ||||||
|  | 		$this->response($response, 200); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	private function nameToHostname(string $name = null) | ||||||
|  | 	{ | ||||||
|  | 		$hostname = ""; | ||||||
|  | 		$hostname = strtolower($name); | ||||||
|  | 		return str_replace(' ', '_', $hostname); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -28,11 +28,18 @@ class RoomsApi extends ApiController | |||||||
|  |  | ||||||
| 				//Connection Error Creation | 				//Connection Error Creation | ||||||
| 				$connectionError = true; | 				$connectionError = true; | ||||||
| 				$LastRecordTime = new DateTime($subDevicesData[$subDeviceKey][$key]['time']); | 				$LastRecordTime = new DateTime($subDevicesData[$subDeviceKey][$key]['heartbeat']); | ||||||
| 				$interval = $LastRecordTime->diff(new DateTime()); | 				$interval = $LastRecordTime->diff(new DateTime()); | ||||||
| 				$lastSeen = ($interval->format('%h') * 60 + $interval->format('%i')); |  | ||||||
|  |  | ||||||
| 				if ($subDevicesData[$subDeviceKey][$key]['sleep_time'] == NULL || $subDevicesData[$subDeviceKey][$key]['sleep_time'] == 0 || $lastSeen < $subDevicesData[$subDeviceKey][$key]['sleep_time']) { |  | ||||||
|  | 				$lastSeen = $interval->days * 24 * 60; | ||||||
|  | 				$lastSeen += $interval->h * 60; | ||||||
|  | 				$lastSeen += $interval->i; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | 				//$lastSeen = ($interval->format('%h') * 60 + $interval->format('%i')); | ||||||
|  |  | ||||||
|  | 				if ($lastSeen < ($subDevicesData[$subDeviceKey][$key]['sleep_time'] == 0 ? 15 : $subDevicesData[$subDeviceKey][$key]['sleep_time'])) { | ||||||
| 					$connectionError = false; | 					$connectionError = false; | ||||||
| 				} | 				} | ||||||
| 				$subDevicesData[$subDeviceKey][$key]['connection_error'] = $connectionError; | 				$subDevicesData[$subDeviceKey][$key]['connection_error'] = $connectionError; | ||||||
|   | |||||||
| @@ -134,4 +134,30 @@ class WidgetApi extends ApiController | |||||||
| 		} | 		} | ||||||
| 		return RANGES['']; | 		return RANGES['']; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public function edit($subDeviceId) | ||||||
|  | 	{ | ||||||
|  | 		$this->requireAuth(); | ||||||
|  | 		$allow = ["icon", "name"]; | ||||||
|  |  | ||||||
|  | 		$response = null; | ||||||
|  | 		$obj = $this->input; | ||||||
|  |  | ||||||
|  | 		foreach ($obj as $key => $value) { | ||||||
|  | 			if (!in_array($key, $allow)){ | ||||||
|  | 				unset($obj[$key]); | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
|  | 		echo $subDeviceId; | ||||||
|  | 		echo SubDeviceManager::edit($subDeviceId, $obj); | ||||||
|  |  | ||||||
|  | 		$response = [ | ||||||
|  | 			"value" => "OK" | ||||||
|  | 		]; | ||||||
|  | 		 | ||||||
|  | 		$this->response($response); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |  | ||||||
| } | } | ||||||
|   | |||||||
| @@ -14,19 +14,33 @@ if ( | |||||||
| 	$state = $_POST["state"]; | 	$state = $_POST["state"]; | ||||||
| 	$clientId = $_POST["clientId"]; | 	$clientId = $_POST["clientId"]; | ||||||
| 	$ota = $userManager->haveOtaEnabled($userName); | 	$ota = $userManager->haveOtaEnabled($userName); | ||||||
|  |  | ||||||
| 	if ($ota == "") { | 	if ($ota == "") { | ||||||
| 		$token = (new AuthManager)->getToken($userName,$userPassword, $clientId); | 		$token = (new AuthManager)->getToken($userName,$userPassword, $clientId); | ||||||
| 		if (!$token) { | 		if (!$token) { | ||||||
| 			throw new Exception("Auth failed", 401); | 			throw new Exception("Auth failed", 401); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
|  | 		$get=[]; | ||||||
|  | 		if ($_POST['response_type'] = 'code') { | ||||||
|  | 			$get = [ | ||||||
|  | 				"state"=>$state, | ||||||
|  | 				"code"=>$token, | ||||||
|  | 				"state"=>$state, | ||||||
|  | 			]; | ||||||
|  | 		} else { | ||||||
| 			$get = [ | 			$get = [ | ||||||
| 				"access_token"=>$token, | 				"access_token"=>$token, | ||||||
| 				"token_type"=>"Bearer", | 				"token_type"=>"Bearer", | ||||||
| 				"state"=>$state, | 				"state"=>$state, | ||||||
| 			]; | 			]; | ||||||
|  | 		} | ||||||
| 		 | 		 | ||||||
| 		header('Location: ' . $_POST["redirectUrl"] . '#' . http_build_query($get)); | 		//Log | ||||||
|  | 		$logManager = new LogManager(__DIR__ . '/../../logs/auth/' . date("Y-m-d") . '.log'); | ||||||
|  | 		$logManager->setLevel(LOGLEVEL); | ||||||
|  | 		$logManager->write("[OAUTH] Response  " . $_POST["redirectUrl"] . '?' . http_build_query($get), LogRecordTypes::WARNING); | ||||||
|  | 		header('Location: ' . $_POST["redirectUrl"] . '?' . http_build_query($get)); | ||||||
| 		die(); | 		die(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,5 @@ | |||||||
| <?php | <?php | ||||||
|  | https://console.cloud.google.com/logs/query;cursorTimestamp=2021-04-11T07:51:16.567357750Z?project=simple-home-79188 | ||||||
| class GoogleHome | class GoogleHome | ||||||
| { | { | ||||||
| 	static function sync($requestId) | 	static function sync($requestId) | ||||||
| @@ -42,7 +43,10 @@ class GoogleHome | |||||||
| 					], | 					], | ||||||
|  |  | ||||||
| 					'willReportState' => false, | 					'willReportState' => false, | ||||||
| 					'roomHint' => $roomData['name'] | 					'roomHint' => $roomData['name'], | ||||||
|  | 					"otherDeviceIds" => [ | ||||||
|  | 						["deviceId" => "SH#".(string) $deviceData['device_id']] | ||||||
|  | 					] | ||||||
| 				]; | 				]; | ||||||
| 				if ($tempDevice['attributes'] == null) unset($tempDevice['attributes']); | 				if ($tempDevice['attributes'] == null) unset($tempDevice['attributes']); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ | |||||||
| class LogManager | class LogManager | ||||||
| { | { | ||||||
| 	private $logFile; | 	private $logFile; | ||||||
|  | 	private $filePath = null; | ||||||
| 	private $logLevel = 1; | 	private $logLevel = 1; | ||||||
|  |  | ||||||
| 	public function __construct($fileName = "") | 	public function __construct($fileName = "") | ||||||
| @@ -15,12 +16,13 @@ class LogManager | |||||||
| 		if ($fileName == ""){ | 		if ($fileName == ""){ | ||||||
| 			$fileName = '../logs/'. date("Y-m-d").'.log'; | 			$fileName = '../logs/'. date("Y-m-d").'.log'; | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		if(!is_dir("../logs/")) | 		if(!is_dir("../logs/")) | ||||||
| 		{ | 		{ | ||||||
| 			mkdir("../logs/"); | 			mkdir("../logs/"); | ||||||
| 		} | 		} | ||||||
|  |  | ||||||
| 		$this->logFile = fopen($fileName, "a") or die("Unable to open file!"); | 		$this->filePath = $fileName; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function setLevel($type = LogRecordTypess::WARNING){ | 	public function setLevel($type = LogRecordTypess::WARNING){ | ||||||
| @@ -28,6 +30,10 @@ class LogManager | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	public function write($value, $type = LogRecordTypess::ERROR){ | 	public function write($value, $type = LogRecordTypess::ERROR){ | ||||||
|  | 		if ($this->logFile == null) { | ||||||
|  | 			$this->logFile = fopen($this->filePath, "a") or die("Unable to open file!"); | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		if ($type['level'] <= $this->logLevel) { | 		if ($type['level'] <= $this->logLevel) { | ||||||
| 			$record = "[".date("H:m:s")."][".$type['identifier']."]" . $value . "\n"; | 			$record = "[".date("H:m:s")."][".$type['identifier']."]" . $value . "\n"; | ||||||
| 			fwrite($this->logFile, $record); | 			fwrite($this->logFile, $record); | ||||||
|   | |||||||
| @@ -66,6 +66,20 @@ class SubDeviceManager | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	public static function edit($subDeviceId, $values) | ||||||
|  | 	{ | ||||||
|  | 		$record = []; | ||||||
|  | 		foreach ($values as $key => $value) { | ||||||
|  | 			$record[$key] = $value; | ||||||
|  | 		} | ||||||
|  | 		try { | ||||||
|  | 			Db::edit('subdevices', $record, 'WHERE subdevice_id = ?', array ($subDeviceId)); | ||||||
|  | 		} catch (PDOException $error) { | ||||||
|  | 			echo $error->getMessage(); | ||||||
|  | 			die(); | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	public static function remove($subDeviceId) | 	public static function remove($subDeviceId) | ||||||
| 	{ | 	{ | ||||||
| 		RecordManager::cleanSubdeviceRecords($subDeviceId); | 		RecordManager::cleanSubdeviceRecords($subDeviceId); | ||||||
| @@ -78,7 +92,7 @@ class SubDeviceManager | |||||||
|  |  | ||||||
| 		//TODO: @Patrik Check line 89 | 		//TODO: @Patrik Check line 89 | ||||||
| 		$rows = Db::loadAll(" | 		$rows = Db::loadAll(" | ||||||
| 			SELECT d.room_id, d.sleep_time, sd.subdevice_id, sd.device_id, d.icon, d.name, sd.type, sd.unit, r.value, r.time FROM subdevices sd | 			SELECT d.room_id, d.sleep_time, d.heartbeat, sd.subdevice_id, sd.device_id, COALESCE(sd.icon, d.icon) AS icon, COALESCE(sd.name, d.name) AS name, sd.type, sd.unit, r.value, r.time FROM subdevices sd | ||||||
| 			JOIN devices d ON sd.device_id = d.device_id | 			JOIN devices d ON sd.device_id = d.device_id | ||||||
| 			JOIN records r ON r.subdevice_id = sd.subdevice_id | 			JOIN records r ON r.subdevice_id = sd.subdevice_id | ||||||
| 			WHERE d.room_id IN (" . str_repeat("?,", count($roomIds) - 1) . "?) | 			WHERE d.room_id IN (" . str_repeat("?,", count($roomIds) - 1) . "?) | ||||||
|   | |||||||
| @@ -1,5 +1,6 @@ | |||||||
| <?php | <?php | ||||||
| class GoogleHomeDeviceTypes { | class GoogleHomeDeviceTypes | ||||||
|  | { | ||||||
| 	/*const AirConditioningUnit	   = 'action.devices.types.AC_UNIT'; | 	/*const AirConditioningUnit	   = 'action.devices.types.AC_UNIT'; | ||||||
| 	const AirFreshener 			   = 'action.devices.types.AIRFRESHENER'; | 	const AirFreshener 			   = 'action.devices.types.AIRFRESHENER'; | ||||||
| 	const AirPurifier             = 'action.devices.types.AIRPURIFIER'; | 	const AirPurifier             = 'action.devices.types.AIRPURIFIER'; | ||||||
| @@ -107,7 +108,7 @@ class GoogleHomeDeviceTypes { | |||||||
| 			'commandOnlyOnOff' => false, | 			'commandOnlyOnOff' => false, | ||||||
| 		], | 		], | ||||||
| 		'temp_cont' 				=> [ | 		'temp_cont' 				=> [ | ||||||
| 			'availableThermostatModes' => 'off,heat', | 			'availableThermostatModes' => ['off', 'heat'], | ||||||
| 			'thermostatTemperatureUnit' => 'C', | 			'thermostatTemperatureUnit' => 'C', | ||||||
| 		], | 		], | ||||||
| 		'vol_cont' 				=> [ | 		'vol_cont' 				=> [ | ||||||
| @@ -117,7 +118,7 @@ class GoogleHomeDeviceTypes { | |||||||
| 			'levelStepSize' => 2, | 			'levelStepSize' => 2, | ||||||
| 			'commandOnlyVolume' => false, | 			'commandOnlyVolume' => false, | ||||||
| 		], | 		], | ||||||
| 		'media_cont'=> [ | 		'media_cont' => [ | ||||||
| 			'transportControlSupportedCommands' => [ | 			'transportControlSupportedCommands' => [ | ||||||
| 				"NEXT", | 				"NEXT", | ||||||
| 				"PREVIOUS", | 				"PREVIOUS", | ||||||
| @@ -127,7 +128,7 @@ class GoogleHomeDeviceTypes { | |||||||
| 				"CAPTION_CONTROL" | 				"CAPTION_CONTROL" | ||||||
| 			], | 			], | ||||||
| 		], | 		], | ||||||
| 		'media_status'=> [ | 		'media_status' => [ | ||||||
| 			'supportActivityState' => true, | 			'supportActivityState' => true, | ||||||
| 			'supportPlaybackState' => true, | 			'supportPlaybackState' => true, | ||||||
| 		], | 		], | ||||||
| @@ -159,27 +160,32 @@ class GoogleHomeDeviceTypes { | |||||||
| 		], | 		], | ||||||
| 	]; | 	]; | ||||||
|  |  | ||||||
| 	static function getAction($deviceType){ | 	static function getAction($deviceType) | ||||||
|  | 	{ | ||||||
| 		if (!isset(self::$actionWordBook[$deviceType])) return; | 		if (!isset(self::$actionWordBook[$deviceType])) return; | ||||||
| 		return self::$actionWordBook[$deviceType]; | 		return self::$actionWordBook[$deviceType]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	static function getTraid($subDeviceType){ | 	static function getTraid($subDeviceType) | ||||||
|  | 	{ | ||||||
| 		if (!isset(self::$traidWordBook[$subDeviceType])) return; | 		if (!isset(self::$traidWordBook[$subDeviceType])) return; | ||||||
| 		return self::$traidWordBook[$subDeviceType]; | 		return self::$traidWordBook[$subDeviceType]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	static function getType($subDeviceCommand){ | 	static function getType($subDeviceCommand) | ||||||
|  | 	{ | ||||||
| 		if (!isset(self::$commandWordBook[$subDeviceCommand])) return; | 		if (!isset(self::$commandWordBook[$subDeviceCommand])) return; | ||||||
| 		return self::$commandWordBook[$subDeviceCommand]; | 		return self::$commandWordBook[$subDeviceCommand]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	static function getAttribute($subDeviceType){ | 	static function getAttribute($subDeviceType) | ||||||
|  | 	{ | ||||||
| 		if (!isset(self::$attributeWordBook[$subDeviceType])) return; | 		if (!isset(self::$attributeWordBook[$subDeviceType])) return; | ||||||
| 		return self::$attributeWordBook[$subDeviceType]; | 		return self::$attributeWordBook[$subDeviceType]; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	static function getQueryJson($deviceType, $type){ | 	static function getQueryJson($deviceType, $type) | ||||||
|  | 	{ | ||||||
| 		return self::$wordBook[$type]; | 		return self::$wordBook[$type]; | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,9 +1,19 @@ | |||||||
| <?php | <?php | ||||||
| class Oauth extends Template | //https://developers.google.com/oauthplayground/ | ||||||
|  | //https://developer.okta.com/blog/2018/04/10/oauth-authorization-code-grant-type | ||||||
|  |  | ||||||
|  | class Oauth | ||||||
| { | { | ||||||
| 	function __construct() | 	function default() | ||||||
| 	{ | 	{ | ||||||
| 		$userManager = new UserManager (); | 		//Log | ||||||
|  | 		$logManager = new LogManager(__DIR__ . '/../../logs/auth/' . date("Y-m-d") . '.log'); | ||||||
|  | 		$logManager->setLevel(LOGLEVEL); | ||||||
|  | 		$logManager->write("[OAUTH] GET  " . json_encode($_GET), LogRecordTypes::WARNING); | ||||||
|  | 		$logManager->write("[OAUTH] DATA " . file_get_contents('php://input'), LogRecordTypes::WARNING); | ||||||
|  | 		$logManager->write("[OAUTH] URL  " . $_SERVER['REQUEST_URI'], LogRecordTypes::WARNING); | ||||||
|  |  | ||||||
|  | 		$userManager = new UserManager(); | ||||||
| 		$langMng = new LanguageManager('en'); | 		$langMng = new LanguageManager('en'); | ||||||
|  |  | ||||||
| 		$template = new Template('oauth'); | 		$template = new Template('oauth'); | ||||||
| @@ -11,6 +21,13 @@ class Oauth extends Template | |||||||
| 		$template->prepare('baseUrl', BASEURL); | 		$template->prepare('baseUrl', BASEURL); | ||||||
| 		$template->prepare('title', 'Simple Home - Oauth'); | 		$template->prepare('title', 'Simple Home - Oauth'); | ||||||
|  |  | ||||||
|  | 		if (isset($_GET['response_type']) && $_GET['response_type'] == 'code') { | ||||||
|  | 			$template->prepare('responseType', $_GET['response_type']); | ||||||
|  | 			$template->prepare('redirectUrl', $_GET['redirect_uri']); | ||||||
|  | 			$template->prepare('clientId', $_GET['client_id']); | ||||||
|  | 			$template->prepare('scope', $_GET['scope']); | ||||||
|  | 			$template->prepare('state', $_GET['state']); | ||||||
|  | 		} else { | ||||||
| 			if (isset($_GET['redirect_uri'])) { | 			if (isset($_GET['redirect_uri'])) { | ||||||
| 				$template->prepare('responseType', $_GET['response_type']); | 				$template->prepare('responseType', $_GET['response_type']); | ||||||
| 				$template->prepare('redirectUrl', $_GET['redirect_uri']); | 				$template->prepare('redirectUrl', $_GET['redirect_uri']); | ||||||
| @@ -22,7 +39,38 @@ class Oauth extends Template | |||||||
| 				$template->prepare('clientId', $_POST['clientId']); | 				$template->prepare('clientId', $_POST['clientId']); | ||||||
| 				$template->prepare('state', $_POST['state']); | 				$template->prepare('state', $_POST['state']); | ||||||
| 			} | 			} | ||||||
|  | 		} | ||||||
|  |  | ||||||
| 		$template->render(); | 		$template->render(); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	function token() | ||||||
|  | 	{ | ||||||
|  | 		//Log | ||||||
|  | 		$logManager = new LogManager(__DIR__ . '/../../logs/auth/' . date("Y-m-d") . '.log'); | ||||||
|  | 		$logManager->setLevel(LOGLEVEL); | ||||||
|  | 		$logManager->write("[OAUTH] GET  " . json_encode($_GET), LogRecordTypes::WARNING); | ||||||
|  | 		$logManager->write("[OAUTH] POST " . json_encode($_POST), LogRecordTypes::WARNING); | ||||||
|  | 		$logManager->write("[OAUTH] DATA " . file_get_contents('php://input'), LogRecordTypes::WARNING); | ||||||
|  | 		$logManager->write("[OAUTH] URL  " . $_SERVER['REQUEST_URI'], LogRecordTypes::WARNING); | ||||||
|  |  | ||||||
|  | 		// $template = new Template('oauth'); | ||||||
|  | 		// $template->prepare('baseDir', BASEDIR); | ||||||
|  | 		// $template->prepare('baseUrl', BASEURL); | ||||||
|  | 		// $template->prepare('title', 'Simple Home - Oauth'); | ||||||
|  | 		// $template->render(); | ||||||
|  |  | ||||||
|  | 		$token =  $_POST["code"]; | ||||||
|  | 		$get = [ | ||||||
|  | 			"access_token" => $token, | ||||||
|  | 			"token_type" => "Bearer", | ||||||
|  | 			"refresh_token" => $token, | ||||||
|  | 			"scope" => 'user', | ||||||
|  | 			//"expires_in" => 63113851, | ||||||
|  | 		]; | ||||||
|  |  | ||||||
|  | 		$logManager->write("[OAUTH] Response  " . json_encode($get), LogRecordTypes::WARNING); | ||||||
|  | 		echo json_encode($get); | ||||||
|  | 		die(); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -4,6 +4,7 @@ | |||||||
| 	<?php | 	<?php | ||||||
| 	$partial = new Partial('head'); | 	$partial = new Partial('head'); | ||||||
| 	$partial->prepare('baseDir',$BASEDIR); | 	$partial->prepare('baseDir',$BASEDIR); | ||||||
|  | 	$partial->prepare('baseUrl',$BASEURL); | ||||||
| 	$partial->render(); | 	$partial->render(); | ||||||
| 	?> | 	?> | ||||||
| 	<title><?php echo $TITLE ?></title> | 	<title><?php echo $TITLE ?></title> | ||||||
|   | |||||||
| @@ -7,10 +7,12 @@ class Template{ | |||||||
|  |  | ||||||
| 	function __construct($path = "", $debug = false) { | 	function __construct($path = "", $debug = false) { | ||||||
| 		$this->debug = $debug; | 		$this->debug = $debug; | ||||||
| 		if (!empty('../app/views/templates/' . $path . '.phtml') && file_exists('../app/views/templates/' . $path . '.phtml')) { |  | ||||||
|  | 		if (!empty(__DIR__ . '/../app/views/templates/' . $path . '.phtml') && file_exists(__DIR__ . '/../app/views/templates/' . $path . '.phtml')) { | ||||||
| 			$this->path = $path; | 			$this->path = $path; | ||||||
| 		} else { | 		} else { | ||||||
| 			echo '<pre>'; | 			echo '<pre>'; | ||||||
|  | 			echo __DIR__ . '/../app/views/templates/' . $path . '.phtml</br>'; | ||||||
| 			echo 'PHTML: Template File ' . $path . ' not found'; | 			echo 'PHTML: Template File ' . $path . ' not found'; | ||||||
| 			echo '</pre>'; | 			echo '</pre>'; | ||||||
| 			die(); | 			die(); | ||||||
| @@ -26,9 +28,9 @@ class Template{ | |||||||
|  |  | ||||||
| 	function render() { | 	function render() { | ||||||
| 		extract($this->assignedValues); | 		extract($this->assignedValues); | ||||||
| 		if (!empty('../app/controllers/' . $this->path . 'Controller.php') && file_exists('../app/controllers/' . $this->path . 'Controller.php')) { | 		if (!empty(__DIR__ . '/../app/controllers/' . $this->path . 'Controller.php') && file_exists(__DIR__ . '/../app/controllers/' . $this->path . 'Controller.php')) { | ||||||
| 			include('../app/controllers/' . $this->path . 'Controller.php'); | 			include(__DIR__ . '/../app/controllers/' . $this->path . 'Controller.php'); | ||||||
| 		} | 		} | ||||||
| 		require_once('../app/views/templates/' . $this->path . '.phtml'); | 		require_once(__DIR__ . '/../app/views/templates/' . $this->path . '.phtml'); | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ RewriteCond %{REQUEST_FILENAME} !-f | |||||||
| RewriteCond %{REQUEST_FILENAME} !-d | RewriteCond %{REQUEST_FILENAME} !-d | ||||||
| RewriteCond %{REQUEST_FILENAME} !.css | RewriteCond %{REQUEST_FILENAME} !.css | ||||||
| RewriteCond %{REQUEST_FILENAME} !.js | RewriteCond %{REQUEST_FILENAME} !.js | ||||||
| RewriteRule (.*) ./index.php?url=$1#$2 [QSA,L] | RewriteRule (.*) ./index.php?url=$1 [QSA,L] | ||||||
|  |  | ||||||
| #token to HTTP_AUTHORIZATION | #token to HTTP_AUTHORIZATION | ||||||
| RewriteCond %{HTTP:Authorization} ^(.*) | RewriteCond %{HTTP:Authorization} ^(.*) | ||||||
|   | |||||||
| @@ -1,3 +1,4 @@ | |||||||
| <?php | <?php | ||||||
|  |  | ||||||
|  |  | ||||||
| require_once __DIR__ . '/../app/Bootstrap.php'; | require_once __DIR__ . '/../app/Bootstrap.php'; | ||||||
		Reference in New Issue
	
	Block a user