Selaa lähdekoodia

Merge 118cda5f79 into 2b095c8c77

pull/84/merge
Carl Allen GitHub 6 vuotta sitten
vanhempi
commit
8d595ed83d
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
1 muutettua tiedostoa jossa 15 lisäystä ja 11 poistoa
  1. +15
    -11
      modules/core/core.py

+ 15
- 11
modules/core/core.py Näytä tiedosto

@@ -18,6 +18,7 @@ from hardware import *

import time
import uuid
from os import popen, system


class NotificationAPI(object):
@@ -83,7 +84,7 @@ class SensorAPI(object):
def init_sensors(self):
'''
Initialize all sensors
:return:
:return:
'''

self.app.logger.info("Init Sensors")
@@ -108,15 +109,15 @@ class SensorAPI(object):
def init_sensor(self, id):
'''
initialize sensor by id
:param id:
:return:
:param id:
:return:
'''

def start_active_sensor(instance):
'''
start active sensors as background job
:param instance:
:return:
:param instance:
:return:
'''
instance.execute()

@@ -151,6 +152,9 @@ class SensorAPI(object):
filename = "./logs/%s_%s.log" % (prefix, str(id))
formatted_time = strftime("%Y-%m-%d %H:%M:%S", localtime())
msg = str(formatted_time) + "," +str(value) + "\n"
if popen("tail -n 2 "+ filename).read().count(","+ str(value)+ "\n") == 2:
# if the data was logged twice, delete the last logged data and write a new one
system("truncate -s -\"$(tail -n1 " + filename + " | wc -c)\" " + filename)

with open(filename, "a") as file:
file.write(msg)
@@ -447,7 +451,7 @@ class CraftBeerPi(ActorAPI, SensorAPI):
def run_init(self):
'''
call all initialziers after startup
:return:
:return:
'''
self.app.logger.info("Invoke Init")
self.cache["init"] = sorted(self.cache["init"], key=lambda k: k['order'])
@@ -461,10 +465,10 @@ class CraftBeerPi(ActorAPI, SensorAPI):

'''
Background Task Decorator
:param key:
:param interval:
:param config_parameter:
:return:
:param key:
:param interval:
:param config_parameter:
:return:
'''
def real_decorator(function):
self.cache["background"].append({"function": function, "key": key, "interval": interval, "config_parameter": config_parameter})
@@ -476,7 +480,7 @@ class CraftBeerPi(ActorAPI, SensorAPI):
def run_background_processes(self):
'''
call all background task after startup
:return:
:return:
'''
self.app.logger.info("Start Background")



Loading…
Peruuta
Tallenna