Compare commits
8 Commits
feature/co
...
64b50ead9f
Author | SHA1 | Date | |
---|---|---|---|
|
64b50ead9f | ||
|
a3a87d39d2 | ||
|
c4f36235ab | ||
daa0e0a2c5 | |||
|
464f229a16 | ||
|
fe72097d75 | ||
|
98efb779b1 | ||
30045b9f65 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -2,6 +2,7 @@
|
||||
.ftpconfig
|
||||
.ftpconfig2
|
||||
*.log
|
||||
*.bin
|
||||
config.php
|
||||
|
||||
_nemazat/index.html
|
||||
|
@@ -53,6 +53,7 @@ $router->any('/api/HA', 'GoogleHomeApi@response');
|
||||
$router->post('/api/endpoint/', 'EndpointsApi@default');
|
||||
$router->any('/api/update/', 'UpdatesApi@default');
|
||||
$router->any('/api/users/status', 'UsersApi@status');
|
||||
$router->any('/api/users/subscribe', 'UsersApi@subscribe');
|
||||
|
||||
// examples
|
||||
$router->any('/api/example', 'ExampleApi@example');
|
||||
|
@@ -12,6 +12,11 @@ class CronApi extends ApiController
|
||||
$backupWorker = new DatabaseBackup();
|
||||
$backupWorker->purge(5);
|
||||
|
||||
//Old Records Cleanup
|
||||
foreach (SubDeviceManager::getAllSubDevices() as $key => $value) {
|
||||
RecordManager::setHistory($value['subdevice_id']);
|
||||
}
|
||||
|
||||
$this->response(['Value' => 'OK']);
|
||||
}
|
||||
|
||||
|
@@ -34,4 +34,13 @@ class UsersApi extends ApiController{
|
||||
}
|
||||
$this->response(['value'=>'OK']);
|
||||
}
|
||||
|
||||
public function subscribe(){
|
||||
//$this->requireAuth();
|
||||
|
||||
$subscriptionToken = $this->input['token'];
|
||||
$subscriptionUserId = $this->input['user_id'];
|
||||
NotificationManager::addSubscriber($subscriptionUserId, $subscriptionToken);
|
||||
$this->response(['value'=>'OK']);
|
||||
}
|
||||
}
|
||||
|
@@ -21,13 +21,24 @@ if (isset($_POST) && !empty($_POST)){
|
||||
|
||||
$ga = new PHPGangsta_GoogleAuthenticator();
|
||||
$checkResult = $ga->verifyCode($otaSecret, $otaCode, 2); // 2 = 2*30sec clock tolerance
|
||||
if ($checkResult) {
|
||||
$userManager->setOta($otaCode, $otaSecret);
|
||||
}
|
||||
if ($checkResult) {
|
||||
$userManager->setOta($otaCode, $otaSecret);
|
||||
}
|
||||
header('Location: ' . BASEURL . 'setting');
|
||||
die();
|
||||
} else if (isset ($_POST['userPermission']) && !empty ($_POST['userID'])) {
|
||||
$userManager->setUserDataAdmin("permission", $_POST['userPermission'], $_POST['userID']);
|
||||
header('Location: ' . BASEURL . 'setting');
|
||||
die();
|
||||
} else {
|
||||
foreach ($_POST as $key => $value) {
|
||||
if ($key == 'submit') continue;
|
||||
$settingMng = new SettingsManager();
|
||||
if ($settingMng->getByName($key)) {
|
||||
$settingMng->update($key, $value);
|
||||
}
|
||||
}
|
||||
|
||||
header('Location: ' . BASEURL . 'setting');
|
||||
die();
|
||||
}
|
||||
|
@@ -26,7 +26,7 @@ class GoogleHome {
|
||||
}
|
||||
}
|
||||
|
||||
if ($traids < 0){
|
||||
if ($traids < 1){
|
||||
continue;
|
||||
}
|
||||
|
||||
|
@@ -102,7 +102,7 @@ class RecordManager{
|
||||
|
||||
public static function clean ($day) {
|
||||
if (isset($day)) {
|
||||
Db::command ('DELETE FROM records WHERE `time` < ADDDATE(NOW(), INTERVAL -? DAY);', array($day));
|
||||
Db::command ('DELETE FROM records WHERE `time` < ADDDATE(NOW(), INTERVAL ? DAY);', array($day));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -110,5 +110,10 @@ class RecordManager{
|
||||
public static function cleanSubdeviceRecords ($subDeviceId) {
|
||||
Db::command ('DELETE FROM records WHERE subdevice_id = ?);', array($subDeviceId));
|
||||
}
|
||||
|
||||
public static function setHistory($subDeviceId){
|
||||
$history = SubDeviceManager::getSubDevice($subDeviceId)['history'];
|
||||
if ($history > 0) self::clean(-abs($history));
|
||||
}
|
||||
}
|
||||
?>
|
||||
|
@@ -14,21 +14,23 @@ class SettingsManager{
|
||||
}
|
||||
|
||||
public static function create ($name, $value, $type = '') {
|
||||
$setting = array (
|
||||
'name' => $name,
|
||||
'value' => $value,
|
||||
'type' => $type,
|
||||
);
|
||||
try {
|
||||
Db::add ('settings', $setting);
|
||||
} catch(PDOException $error) {
|
||||
echo $error->getMessage();
|
||||
die();
|
||||
if (!self::getByName($name)){
|
||||
$setting = array (
|
||||
'name' => $name,
|
||||
'value' => $value,
|
||||
'type' => $type,
|
||||
);
|
||||
try {
|
||||
Db::add ('settings', $setting);
|
||||
} catch(PDOException $error) {
|
||||
echo $error->getMessage();
|
||||
die();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static function update ($name, $value, $type = '') {
|
||||
if (self::getByName($name)){
|
||||
if (!self::getByName($name)){
|
||||
self::create($name, $value, $type);
|
||||
} else {
|
||||
try {
|
||||
|
@@ -9,6 +9,14 @@ class AirQuality extends VirtualDeviceManager
|
||||
|
||||
function make()
|
||||
{
|
||||
//Register the settings
|
||||
$settingMng = new SettingsManager();
|
||||
if (!($settingField = $settingMng->getByName("airquality"))) {
|
||||
$settingMng->create("token", "", "airquality");
|
||||
} else {
|
||||
$app_id = $settingField['value'];
|
||||
}
|
||||
|
||||
try {
|
||||
if (DeviceManager::registeret($this->virtual_device_name)) {
|
||||
$deviceId = DeviceManager::getDeviceByToken($this->virtual_device_name)['device_id'];
|
||||
|
@@ -33,4 +33,8 @@ class OpenWeatherMap extends VirtualDeviceManager
|
||||
return 'exception: ' . $e->getMessage();
|
||||
}
|
||||
}
|
||||
|
||||
function enable(){
|
||||
(new SettingsManager)->create('open_weather_api_token', '', 'open_weather');
|
||||
}
|
||||
}
|
||||
|
@@ -70,6 +70,8 @@ class Setting extends Template
|
||||
$result = $settingsManager->getSettingGroup($plugins[$key]['slug']);
|
||||
if (count ($result) > 0) {
|
||||
$plugins[$key]['settings'] = $result;
|
||||
} else {
|
||||
unset($plugins[$key]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@@ -202,7 +202,23 @@ $partial = new Partial('head');
|
||||
</form>
|
||||
</div>
|
||||
|
||||
|
||||
<!--Plugins Settings-->
|
||||
<?php foreach ($PLUGINSSETTINGS as $key => $pluginSeting) { ?>
|
||||
<div class="col-12 col-sm-9 mx-auto mt-4">
|
||||
<h4 class="mb-4"><?php echo $pluginSeting['name'] ?></h4>
|
||||
<form method="post">
|
||||
<?php foreach ($pluginSeting['settings'] as $key => $pluginSetingField) { ?>
|
||||
<div class="field">
|
||||
<div class="label"><?php echo $pluginSetingField['name'] ?>:</div>
|
||||
<input type="text" class="input" name="<?php echo $pluginSetingField['name'] ?>" value="<?php echo $pluginSetingField['value'] ?>">
|
||||
</div>
|
||||
<?php } ?>
|
||||
<div class="field">
|
||||
<input type="submit" name="submitPlugins<?php echo $pluginSeting['name'] ?>Settings" class="button" value="<?php $LANGMNG->echo('b_save') ?>">
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
<?php } ?>
|
||||
</div>
|
||||
|
||||
|
||||
|
Reference in New Issue
Block a user