Today I would like to quickly present one of my current projects, i.e. adding the Raspberry Pi wired with different kind of sensors to IP Symcon. With the sensor data in IP Symcon we can log changes and generate reports upon those, for instance. So we are getting data from the Raspberry Pi, or -to be more precise we push data from the Pi to IP Symcon by invoking JSON Remote Procedure Calls provided by IPS.
I started with the humidity and temperature sensor DHT22. For the wiring you will probably find dozens of introductions and tutorials. The only challenging part was the not so obvious mapping of the sunfounder breakout kit. Please find some great information about the mapping between breakout kit and Raspberry Pi GPIO here:
http://heinrichhartmann.com/2014/11/22/Raspberry-Pi-SunFounder-GPIO-Layout.html
To make RPC invokes easier from the Python side I used “Python Requests”:
http://docs.python-requests.org/en/latest/
I also recommend to use Fiddler for “debugging” purposes. Before I started developing the Python app I made sure I have the right HTTP Post request in place. We call the WebApp Instance of IPS with a “/api” below to make RPCs. It uses Basic authentication (your registered email address) and the main password encoded in base64 and send as http header.
Here is my example:
Here is the small piece of code to read the sensor data and send these into IPS via RPC. As a prerequisite you need the created variables in IPS, even better if you immediately apply the float data type and the temperature and humidity variable profile:
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 |
import pigpio import DHT22 import requests import json from time import sleep #Initiate GPIO for pigpio pi = pigpio.pi() #setup the sensor dht22 = DHT22.sensor(pi, 4) #BCM (description) reference #Board (Pin Numbers) dht22.trigger(); #Sleep time to be above 2 seconds sleepTime = 3 def InvokeIpsRpc(method, parameters): url = "http://192.168.0.40:83/api/" headers = { 'content-type': 'application/json', 'Authorization': 'Basic XXXXBASE64XXXXXX' } payload = { 'method': method, 'params': parameters, 'jsonrpc': '2.0', 'id': '0' } response = requests.post(url ,headers=headers, data=json.dumps(payload)) return(response.text) def readDHT22(): #get new reading dht22.trigger() #save our values # truncate the float to two places humidity = '%.2f' % (dht22.humidity()) temp = '%.2f' % (dht22.temperature()) return (humidity, temp) while True: humidity, temp = readDHT22() print("Humidity is: " + humidity + "%") InvokeIpsRpc('SetValue', [45731,humidity]) print("Temperature is: " + temp + "C") InvokeIpsRpc('SetValue', [25622,temp]) sleep(sleepTime) |
For sure the basic auth password is just a placeholder and should be replaced by a proper base64 encoded password for IP Symcon.
See below how it looks behind the scenes:
And this is how it looks in the Frontend together with my 7$ gadget webcam controlled by “motion” 🙂
No Comment
You can post first response comment.