requireAuth(); $obj = $this->input; //variables Definition $command = "null"; //Log $logManager = new LogManager('../logs/api/'. date("Y-m-d").'.log'); $logManager->setLevel(LOGLEVEL); //Token Checks if ($obj['token'] == null || !isset($obj['token'])) { $this->response([ 'state' => 'unsuccess', 'errorMSG' => "Missing Value Token in JSON payload", ], 401); die(); } //Vstupní Checky if (!DeviceManager::registeret($obj['token'])) { //Notification data setup $notificationMng = new NotificationManager; $notificationData = [ 'title' => 'Info', 'body' => 'New device Detected Found', 'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', ]; //Subdevice Registration $device = DeviceManager::create($obj['token'], $obj['token']); foreach ($obj['values'] as $key => $value) { if (!SubDeviceManager::getSubDeviceByMaster($device['device_id'], $key)) { SubDeviceManager::create($device['device_id'], $key, UNITS[$key]); } } //Notification for newly added Device if ($notificationData != []) { $subscribers = $notificationMng::getSubscription(); foreach ($subscribers as $key => $subscriber) { $logManager->write("[NOTIFICATION] SENDING TO" . $subscriber['id'] . " ", LogRecordTypes::INFO); $notificationMng::sendSimpleNotification(SERVERKEY, $subscriber['token'], $notificationData); } } $logManager->write("[API] Registering Device", LogRecordTypes::INFO); $this->response([ 'state' => 'unsuccess', 'errorMSG' => "Device not registeret", ], 401); } if (!DeviceManager::approved($obj['token'])) { $this->response([ 'state' => 'unsuccess', 'errorMSG' => "Unaproved Device", ], 401); } $device = DeviceManager::getDeviceByToken($obj['token']); //Diagnostic if (isset($obj['settings'])){ $data = ['mac' => $obj['settings']["network"]["mac"], 'ip_address' => $obj['settings']["network"]["ip"]]; if (array_key_exists("firmware_hash", $obj['settings'])) { $data['firmware_hash'] = $obj['settings']["firmware_hash"]; } DeviceManager::editByToken($obj['token'], $data); } //Log Data Save if (isset($obj['logs'])){ foreach ($obj['logs'] as $log) { $deviceLogManager = new LogManager('../logs/devices/'. date("Y-m-d").'.log'); $deviceLogManager->setLevel(LOGLEVEL); $deviceLogManager->write("[Device Log Msg] Device_ID " . $device['device_id'] . "->" . $log, LogRecordTypes::ERROR); unset($deviceLogManager); } $this->response([ 'state' => 'succes', 'command' => $command, ], 200); die(); } // Issuing command if ($command == "null"){ $deviceCommand = $device["command"]; if ($deviceCommand != '' && $deviceCommand != null && $deviceCommand != "null") { $command = $deviceCommand; $data = [ 'command'=>'null' ]; DeviceManager::editByToken($obj['token'], $data); $logManager->write("[API] Device_ID " . $device['device_id'] . " executing command " . $command, LogRecordTypes::INFO); } } $jsonAnswer = []; $subDeviceLastReordValue = []; if (isset($obj['values'])) { //ZAPIS foreach ($obj['values'] as $key => $value) { if (!SubDeviceManager::getSubDeviceByMaster($device['device_id'], $key)) { SubDeviceManager::create($device['device_id'], $key, UNITS[$key]); } $subDeviceLastReordValue[$key] = $value['value']; RecordManager::create($device['device_id'], $key, round($value['value'],3)); $logManager->write("[API] Device_ID " . $device['device_id'] . " writed value " . $key . ' ' . $value['value'], LogRecordTypes::INFO); //notification if ($key == 'door' || $key == 'water') { $notificationMng = new NotificationManager; $notificationData = []; switch ($key) { case 'door': $notificationData = [ 'title' => 'Info', 'body' => 'Someone just open up '.$device['name'], 'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', ]; break; case 'water': $notificationData = [ 'title' => 'Alert', 'body' => 'Wather leak detected by '.$device['name'], 'icon' => BASEDIR . '/app/templates/images/icon-192x192.png', ]; break; } if (DEBUGMOD) $notificationData['body'] .= ' value='.$value['value']; if ($notificationData != []) { $subscribers = $notificationMng::getSubscription(); foreach ($subscribers as $key => $subscriber) { $logManager->write("[NOTIFICATION] SENDING TO" . $subscriber['id'] . " ", LogRecordTypes::INFO); $notificationMng::sendSimpleNotification(SERVERKEY, $subscriber['token'], $notificationData); } } } } //upravit format na setings-> netvork etc $subDevicesTypeList = SubDeviceManager::getSubDeviceSTypeForMater($device['device_id']); if (!in_array($subDevicesTypeList, ['on/off', 'door', 'water'])) { $jsonAnswer['device']['sleepTime'] = $device['sleep_time']; } } else { if (count(SubDeviceManager::getAllSubDevices($device['device_id'])) == 0) { //SubDeviceManager::create($device['device_id'], 'on/off', UNITS[$key]); //RecordManager::create($device['device_id'], 'on/off', 0); } $subDevicesData = SubDeviceManager::getAllSubDevices($device['device_id']); foreach ($subDevicesData as $key => $subDeviceData) { $subDeviceId = $subDeviceData['subdevice_id']; $subDeviceLastReord = RecordManager::getLastRecord($subDeviceId); if (!empty ($subDeviceLastReord)) { $subDeviceLastReordValue[$subDeviceData['type']] = $subDeviceLastReord['value']; if ($subDeviceLastReord['execuded'] == 0){ $logManager->write("[API] subDevice_ID " . $subDeviceId . " executed comand with value " . json_encode($subDeviceLastReordValue) . " executed " . $subDeviceLastReord['execuded'], LogRecordTypes::INFO); RecordManager::setExecuted($subDeviceLastReord['record_id']); } } } } $hostname = ""; $hostname = strtolower($device['name']); $hostname = str_replace(' ', '_', $hostname); $jsonAnswer['device']['hostname'] = $hostname; $jsonAnswer['state'] = 'succes'; $jsonAnswer['values'] = $subDeviceLastReordValue; $jsonAnswer['command'] = $command; $this->response($jsonAnswer); // this method returns response as json //unset($logManager); //TODO: Opravit die(); } }