This repository has been archived by the owner on Apr 5, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathsensor.py
155 lines (120 loc) · 4.51 KB
/
sensor.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
#!/usr/bin/env python3
import sys
import errno
import os
import iio
import json
import time
from http.server import HTTPServer, BaseHTTPRequestHandler
import paho.mqtt.client as mqtt
import socket
import threading
import requests
import idetect
from reading import IIO_READER
from information import Information
def mqtt_detect():
# Use the supervisor api to get services
# See https://www.balena.io/docs/reference/supervisor/supervisor-api/
address = os.getenv('BALENA_SUPERVISOR_ADDRESS', '')
api_key = os.getenv('BALENA_SUPERVISOR_API_KEY', '')
app_name = os.getenv('BALENA_APP_NAME', '')
url = "{0}/v2/applications/state?apikey={1}".format(address, api_key)
try:
r = requests.get(url).json()
except Exception as e:
print("Error looking for MQTT service: {0}".format(str(e)))
return False
else:
services = r[app_name]['services'].keys()
if "mqtt" in services:
return True
else:
return False
class balenaSense():
readfrom = 'unset'
def __init__(self):
print("Initializing sensors...")
# First, use iio to detect supported sensors
self.device_count = idetect.detect_iio_sensors()
if self.device_count > 0:
self.readfrom = "iio_sensors"
self.context = _create_context()
self.sensor = IIO_READER()
# Print the iio info
information = Information(self.context)
information.write_information()
# More sensor types can be added here
# make sure to change the value of self.readfrom
# If this is still unset, no sensors were found; quit!
if self.readfrom == 'unset':
print('No suitable sensors found! Exiting.')
sys.exit()
def sample(self):
if self.readfrom == 'sense-hat':
return self.apply_offsets(self.sense_hat_reading())
elif self.readfrom == 'iio_sensors':
return self.sensor.get_readings(self.context)
else:
return self.sensor.get_readings(self.sensor)
def _create_context():
return iio.Context()
# Simple webserver
def background_web(server_socket):
balenasense = balenaSense()
while True:
# Wait for client connections
client_connection, client_address = server_socket.accept()
# Get the client request
request = client_connection.recv(1024).decode()
print(request)
# Send HTTP response
response = 'HTTP/1.0 200 OK\n\n'+ json.dumps(balenasense.sample())
client_connection.sendall(response.encode())
client_connection.close()
if __name__ == "__main__":
mqtt_address = os.getenv('MQTT_ADDRESS', 'none')
use_httpserver = os.getenv('ALWAYS_USE_HTTPSERVER', 0)
publish_interval = os.getenv('MQTT_PUB_INTERVAL', '8')
publish_topic = os.getenv('MQTT_PUB_TOPIC', 'sensors')
try:
interval = float(publish_interval)
except Exception as e:
print("Error converting MQTT_PUB_INTERVAL: Must be integer or float! Using default.")
interval = 8
if use_httpserver == "1":
enable_httpserver = "True"
else:
enable_httpserver = "False"
if mqtt_detect() and mqtt_address == "none":
mqtt_address = "mqtt"
if mqtt_address != "none":
print("Starting mqtt client, publishing to {0}:1883".format(mqtt_address))
print("Using MQTT publish interval: {0} sec(s)".format(interval))
client = mqtt.Client()
try:
client.connect(mqtt_address, 1883, 60)
except Exception as e:
print("Error connecting to mqtt. ({0})".format(str(e)))
mqtt_address = "none"
enable_httpserver = "True"
else:
client.loop_start()
balenasense = balenaSense()
else:
enable_httpserver = "True"
if enable_httpserver == "True":
SERVER_HOST = '0.0.0.0'
SERVER_PORT = 7575
# Create socket
server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
server_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
server_socket.bind((SERVER_HOST, SERVER_PORT))
server_socket.listen(1)
print("HTTP server listening on port {0}...".format(SERVER_PORT))
t = threading.Thread(target=background_web, args=(server_socket,))
t.start()
while True:
if mqtt_address != "none":
client.publish(publish_topic, json.dumps(balenasense.sample()))
time.sleep(interval)