88 lines
3.7 KiB
Python
88 lines
3.7 KiB
Python
# Importeer benodigde modules voor het uitvoeren van HTTP-verzoeken, tijdbeheer, en JSON-operaties.
|
|
import requests
|
|
import time
|
|
import json
|
|
|
|
# Importeer MQTT-client functies van een aangepaste module.
|
|
from mqtt_client import create_client, start_loop
|
|
|
|
# Stel het interval in seconden in voor het periodiek ophalen en publiceren van data.
|
|
publish_interval = 900 # MOET ~900 ZIJN voor productiegebruik. -- 15min
|
|
|
|
# Definieer API-eindpunten en de corresponderende MQTT topics.
|
|
api_endpoints = [
|
|
{"url": "https://garden.inajar.nl/api/devices/", "topic": "goodgarden/devices"},
|
|
{"url": "https://garden.inajar.nl/api/relative_humidity_events/", "topic": "goodgarden/relative_humidity"},
|
|
{"url": "https://garden.inajar.nl/api/battery_voltage_events/", "topic": "goodgarden/battery_voltage"},
|
|
{"url": "https://garden.inajar.nl/api/soil_electric_conductivity_events/", "topic": "goodgarden/soil_electric_conductivity"},
|
|
{"url": "https://garden.inajar.nl/api/soil_relative_permittivity_events/", "topic": "goodgarden/soil_relative_permittivity"},
|
|
{"url": "https://garden.inajar.nl/api/soil_temperature_events/", "topic": "goodgarden/soil_temperature"},
|
|
{"url": "https://garden.inajar.nl/api/par_events/", "topic": "goodgarden/par_events"}
|
|
]
|
|
|
|
def on_connect(client, userdata, flags, rc):
|
|
"""
|
|
Callback functie voor het afhandelen van de connectie-event met de MQTT broker.
|
|
|
|
Parameters:
|
|
client: De MQTT-client instantie.
|
|
userdata: De private user-specifieke data zoals ingesteld in Client() of user_data_set().
|
|
flags: Reactie vlaggen van de broker.
|
|
rc: De connectie resultaat code.
|
|
"""
|
|
print("Geconnect met code "+str(rc))
|
|
|
|
def on_message(client, userdata, msg):
|
|
"""
|
|
Callback functie voor het afhandelen van inkomende berichten voor geabonneerde topics.
|
|
|
|
Parameters:
|
|
client: De MQTT-client instantie.
|
|
userdata: De private user-specifieke data.
|
|
msg: Het bericht instantie.
|
|
"""
|
|
print(f"Message: {msg.topic} {str(msg.payload)}")
|
|
|
|
# Initialiseer de MQTT-client met een unieke client ID en callback functies.
|
|
client = create_client("publisher1", on_connect, on_message)
|
|
|
|
def publish_to_mqtt(topic, data):
|
|
"""
|
|
Publiceert data naar een MQTT topic.
|
|
|
|
Parameters:
|
|
topic (str): Het MQTT topic waarop de data wordt gepubliceerd.
|
|
data (dict): De data die gepubliceerd moet worden, geconverteerd naar JSON formaat.
|
|
"""
|
|
json_data = json.dumps(data) # Serialiseer de data naar een JSON-string.
|
|
client.publish(topic, json_data)
|
|
print(f"\033[92mData gepubliceerd naar MQTT topic {topic}.\033[0m")
|
|
|
|
def fetch_and_publish_data():
|
|
"""
|
|
Haalt data op van API-eindpunten en publiceert deze naar MQTT.
|
|
"""
|
|
for endpoint in api_endpoints:
|
|
url = endpoint["url"]
|
|
mqtt_topic = endpoint["topic"]
|
|
access_token = "33bb3b42452306c58ecedc3c86cfae28ba22329c" # Voorbeeld token.
|
|
|
|
try:
|
|
headers = {"Authorization": f"Token {access_token}"}
|
|
response = requests.get(url, headers=headers)
|
|
response.raise_for_status() # Verifieert respons status.
|
|
data = response.json()
|
|
print(f"Data van {url}: {data}")
|
|
publish_to_mqtt(mqtt_topic, data)
|
|
except requests.exceptions.RequestException as e:
|
|
print(f"Error met data ophalen {url}: {e}")
|
|
|
|
if __name__ == "__main__":
|
|
client.loop_start() # Start de niet-blokkerende MQTT-client loop.
|
|
while True:
|
|
fetch_and_publish_data() # Haal data op en publiceer.
|
|
print(f"\033[91mWachten, wachten en nog eens wachten... {publish_interval} secondes!\033[0m\n")
|
|
time.sleep(publish_interval) # Wacht voor het ingestelde interval.
|
|
|
|
client.loop_stop()
|