Pārlūkot izejas kodu

Some services added

master
Dirk Alders 4 gadus atpakaļ
vecāks
revīzija
bc4808b313
1 mainītis faili ar 70 papildinājumiem un 20 dzēšanām
  1. 70
    20
      __init__.py

+ 70
- 20
__init__.py Parādīt failu

@@ -6,17 +6,21 @@ import logging
6 6
 import socket_protocol
7 7
 import time
8 8
 
9
+from helpers import continues_statistic
9 10
 from rpi_envsens.dht import dht_22
10 11
 from rpi_envsens.bmp import bmp_180
11 12
 
12 13
 logger = logging.getLogger('APP')
13 14
 
14 15
 
15
-
16
-
17 16
 class my_base_protocol_tcp(socket_protocol.pure_json_protocol):
18 17
     # EXECUTE_REQUESTs
19 18
     CURRENT_ENVDATA = 0
19
+    TODAYS_STATISTIC_ENVDATA = 1
20
+    YESTERDAYS_STATISTIC_ENVDATA = 2
21
+    BUFFERED_TEMPERATURE = 3
22
+    BUFFERED_HUMIDITY = 4
23
+    BUFFERED_PRESSURE = 5
20 24
 
21 25
 
22 26
 class my_server_protocol_tcp(my_base_protocol_tcp):
@@ -24,24 +28,57 @@ class my_server_protocol_tcp(my_base_protocol_tcp):
24 28
         socket_protocol.pure_json_protocol.__init__(self, comm_instance, secret)
25 29
         self.dht_data = dht_data
26 30
         self.bmp_data = bmp_data
27
-        self.register_callback(self.SID_READ_REQUEST, self.CURRENT_ENVDATA, self.current_envdata)
31
+        self.register_callback(self.SID_READ_REQUEST, None, self.read_request)
28 32
 
29 33
     def data_age_okay(self, dd, bd):
30 34
         MAX_AGE = 60.
31 35
         tm = time.time()
32 36
         return dd[dht_22.KEY_TIME] + MAX_AGE >= tm and bd[bmp_180.KEY_TIME] + MAX_AGE >= tm 
33 37
 
34
-    def current_envdata(self, msg):
35
-        dd = self.dht_data.current
36
-        bd = self.bmp_data.current
37
-        if self.data_age_okay(bd, dd):
38
-            rv = {}
39
-            rv[dht_22.KEY_TEMPERATURE] = dd[dht_22.KEY_TEMPERATURE]
40
-            rv[dht_22.KEY_HUMIDITY] = dd[dht_22.KEY_HUMIDITY]
41
-            rv[bmp_180.KEY_PRESSURE] = bd[bmp_180.KEY_PRESSURE]
38
+    def read_request(self, msg):
39
+        did = msg.get_data_id()
40
+        if did == self.CURRENT_ENVDATA:
41
+            dd = self.dht_data.current
42
+            bd = self.bmp_data.current
43
+            if dd is not None and bd is not None:
44
+                if self.data_age_okay(bd, dd):
45
+                    rv = {}
46
+                    rv[dht_22.KEY_TEMPERATURE] = dd[dht_22.KEY_TEMPERATURE]
47
+                    rv[dht_22.KEY_HUMIDITY] = dd[dht_22.KEY_HUMIDITY]
48
+                    rv[bmp_180.KEY_PRESSURE] = bd[bmp_180.KEY_PRESSURE]
49
+                    return self.STATUS_OKAY, rv
50
+            return self.STATUS_OPERATION_NOT_PERMITTED, None
51
+        elif did in [self.TODAYS_STATISTIC_ENVDATA, self.YESTERDAYS_STATISTIC_ENVDATA]:
52
+            if did == self.TODAYS_STATISTIC_ENVDATA:
53
+                dd = self.dht_data.todays_statistic
54
+                bd = self.bmp_data.todays_statistic
55
+            else:
56
+                dd = self.dht_data.yesterdays_statistic
57
+                bd = self.bmp_data.yesterdays_statistic
58
+            if dd is None or bd is None:
59
+                return self.STATUS_OPERATION_NOT_PERMITTED, None
60
+            else:
61
+                rv = {}
62
+                rv[dht_22.KEY_TEMPERATURE] = dd[dht_22.KEY_TEMPERATURE]
63
+                rv[dht_22.KEY_HUMIDITY] = dd[dht_22.KEY_HUMIDITY]
64
+                rv[bmp_180.KEY_PRESSURE] = bd[bmp_180.KEY_PRESSURE]
65
+                return self.STATUS_OKAY, rv
66
+        elif did in [self.BUFFERED_HUMIDITY, self.BUFFERED_PRESSURE, self.BUFFERED_TEMPERATURE]:
67
+            if did == self.BUFFERED_HUMIDITY:
68
+                db = self.dht_data.databuffer
69
+                key = dht_22.KEY_HUMIDITY
70
+            elif did == self.BUFFERED_PRESSURE:
71
+                db = self.bmp_data.databuffer
72
+                key = bmp_180.KEY_PRESSURE
73
+            else:
74
+                db = self.dht_data.databuffer
75
+                key = dht_22.KEY_TEMPERATURE
76
+            rv = []
77
+            for entry in db:
78
+                rv.append((entry[dht_22.KEY_TIME], entry[key]))
42 79
             return self.STATUS_OKAY, rv
43 80
         else:
44
-            return self.STATUS_OPERATION_NOT_PERMITTED, None
81
+            return self.STATUS_SERVICE_OR_DATA_UNKNOWN, None
45 82
 
46 83
 
47 84
 class my_client_protocol_tcp(my_base_protocol_tcp):
@@ -49,7 +86,7 @@ class my_client_protocol_tcp(my_base_protocol_tcp):
49 86
 
50 87
     def __init__(self, comm_instance, secret=None):
51 88
         socket_protocol.pure_json_protocol.__init__(self, comm_instance, secret)
52
-        self.register_callback(self.SID_READ_RESPONSE, self.CURRENT_ENVDATA, self.read_current_envdata)
89
+        self.register_callback(self.SID_READ_RESPONSE, None, self.print_read_response)
53 90
 
54 91
     def __authentificate_process_feedback__(self, msg):
55 92
         if msg.get_data() is True:
@@ -58,14 +95,27 @@ class my_client_protocol_tcp(my_base_protocol_tcp):
58 95
             print("AUTHENTIFICATION ERROR")
59 96
         return my_base_protocol_tcp.__authentificate_process_feedback__(self, msg)
60 97
 
61
-    def read_current_envdata(self, msg):
98
+    def print_read_response(self, msg):
62 99
         if msg.get_status() == self.STATUS_OKAY:
63
-            env_data = msg.get_data()
64
-            print("Temperature: %6.1f °C" % env_data[dht_22.KEY_TEMPERATURE])
65
-            print("Humidity:    %6.1f %%" % env_data[dht_22.KEY_HUMIDITY])
66
-            print("Pressure:    %6.1f mbar" % env_data[bmp_180.KEY_PRESSURE])
100
+            did = msg.get_data_id()
101
+            data = msg.get_data()
102
+            if did == self.CURRENT_ENVDATA:
103
+                print("Temperature: %6.1f °C" % data[dht_22.KEY_TEMPERATURE])
104
+                print("Humidity:    %6.1f %%" % data[dht_22.KEY_HUMIDITY])
105
+                print("Pressure:    %6.1f mbar" % data[bmp_180.KEY_PRESSURE])
106
+            elif did in [self.TODAYS_STATISTIC_ENVDATA, self.YESTERDAYS_STATISTIC_ENVDATA]:
107
+                print(continues_statistic(**data))
108
+            elif did in [self.BUFFERED_HUMIDITY, self.BUFFERED_PRESSURE, self.BUFFERED_TEMPERATURE]:
109
+                if did == self.BUFFERED_HUMIDITY:
110
+                    print("Humidity:")
111
+                elif did == self.BUFFERED_PRESSURE:
112
+                    print("Pressure:")
113
+                else:
114
+                    print("Temperature:")
115
+                print(data)
116
+            else:
117
+                return self.STATUS_SERVICE_OR_DATA_UNKNOWN, None
67 118
             return self.STATUS_OKAY, None
68 119
         else:
69
-            print('No environmental data received!')
120
+            print('No data received!')
70 121
             return self.STATUS_SERVICE_OR_DATA_UNKNOWN, None
71
-

Notiek ielāde…
Atcelt
Saglabāt