Well after my last successes to make a accessory for my homebridge, I want to see if I can make a Temperature & Humidity Level accessory.

First an need a Temperature & Humidity sensor, so I found this one:

For those who haven’t read my previous post, you must first install HomeBridge on a Raspberry Pi, and configure it as a HomeKit bridge device. For who did’t read my previous post about the Raspian Pi update, there are a few thing changed! First read this post https://www.studiopieters.nl/raspberry-pi-a-security-update-for-raspbian-pixel/

So once again we have to alter a few things in the installation process. For a headless installation we need to add the ssh file to the root of the SD-Card. This in order to connect to the Raspberry Pi. When we have don this we can install Xrdp as described in this post https://www.studiopieters.nl/raspberry-pi-remote-desktop-connection/

But then I found a new problem it has to do with the fact that the Raspbian Jessie with pixel, which officially stands for “Pi Improved Xwindows Environment, Lightweight”, now comes pre-packaged with RealVNC, which conflicts with both xrdp (which uses vnc4server) and tightvncserver.

So I needed a solution: Google me this google me that….

The fix:

Let’s assume you already did sudo apt-get update and sudo apt-get install xrdp.

Now, let’s disable the RealVNC install. I have tested it and follow these steps to disable the RealVNC install and allow xrdp to work:

sudo apt-get remove xrdp vnc4server tightvncserver

sudo apt-get install xrdp

Remote logins using xrdp now work. Here after you can make a remote connection and follow the steps as described in this post https://www.studiopieters.nl/raspberry-pi-apple-homebridge/

When you have installed the homebridge you need to install the homebridge-http-temperature-humidity package in order to let the homebride communicate with your ESP8266 over http.

Edit the HomeBridge /var/homebridge/config.json file on the Raspberry Pi HomeBridge. the file may alternatively be in /home/.homebridge or /root/home/./homebridge.

add this code to the config.json file.

sudo nano ~/.homebridge/config.json

mind the last comma, you may or may not need it if you have other accessories, or Homebridge is crashing on load.

   "bridge": {
      "name": "Homebridge",
      "username": "CC:22:3D:E3:CE:30",
      "port": 51826,
      "pin": "031-45-154"

   "description": "Example configuration file for homebridge-httptemperaturehumidity plugin",

   "platforms": [
   "accessories": [
           "accessory": "HttpTemphum",
           "name": "Living Room",
           "url": "",
           "sendimmediately": "",
           "http_method": "GET"

The Hardware

Once you have HomeKit / HomeBridge working on your Pi and your iPhone, we can build a RGB LED that can be controlled by Siri and the HomeKit app.

At first we need to setup the FTDI programmer to program the ESP8266-E12 with the Arduino IDE.

upload the program below to your ESP8266.

/* Project name: Apple Homebridge - Temperature & Humidity level  
*  Project URI: https://www.studiopieters.nl/apple-homebridge-Temperature & Humidity level/   
*  Description: Apple Homebridge - Temperature & Humidity level
*  Version: Apple homebridge - Temperature & Humidity level 1.0.3 
*  License: GNU General Public License V2 or later  */

#include <ESP8266WiFi.h>
#include <WiFiClient.h>
#include <ESP8266WebServer.h>
#include <DHT.h>
#define DHTTYPE DHT11
#define DHTPIN  2

const char* ssid     = "Your SSID";
const char* password = "Your Password ";

ESP8266WebServer server(80);
// Initialize DHT sensor 
// NOTE: For working with a faster than ATmega328p 16 MHz Arduino chip, like an ESP8266,
// you need to increase the threshold for cycle counts considered a 1 or 0.
// You can do this by passing a 3rd parameter for this threshold.  It's a bit
// of fiddling to find the right value, but in general the faster the CPU the
// higher the value.  The default for a 16mhz AVR is a value of 6.  For an
// Arduino Due that runs at 84mhz a value of 30 works.
// This is for the ESP8266 processor on ESP-01 
DHT dht(DHTPIN, DHTTYPE, 11); // 11 works fine for ESP8266
float humidity, temp_c;  // Values read from sensor

// Generally, you should use "unsigned long" for variables that hold time
unsigned long previousMillis = 0;        // will store last temp was read
const long interval = 2000;              // interval at which to read sensor
void handle_root() {
  server.send(200, "text/plain", "Homebridge http Temperature and humidity Sensor, read from /dht");
void setup(void)
  // You can open the Arduino IDE Serial Monitor window to see what the code is doing
  Serial.begin(115200);  // Serial connection from ESP-01 via 3.3v console cable
  dht.begin();           // initialize temperature sensor

  // Connect to WiFi network
  WiFi.begin(ssid, password);
   IPAddress ip(192, 168, 178, 60);
  IPAddress gateway(192, 168, 178, 1);
  IPAddress subnet(255, 255, 255, 0);
  WiFi.config(ip, gateway, subnet);
  Serial.print("\n\r \n\rWorking to connect");

  // Wait for connection
  while (WiFi.status() != WL_CONNECTED) {
  Serial.println("DHT data Reading Server");
  Serial.print("Connected to ");
  Serial.print("IP address: ");
  server.on("/", handle_root);
 server.on("/dht", [](){
    server.send(200, "text/json","{\n" "\"temperature\": "+String(temp_c)+",\n ""\"humidity\": "+String(humidity)+"" "\n}");

  Serial.println("HTTP server started");
void loop(void)

void gettemperature() {
  // Wait at least 2 seconds seconds between measurements.
  // if the difference between the current time and last time you read
  // the sensor is bigger than the interval you set, read the sensor
  // Works better than delay for things happening elsewhere also
  unsigned long currentMillis = millis();
  if(currentMillis - previousMillis >= interval) {
    // save the last time you read the sensor 
    previousMillis = currentMillis;   

    // Reading temperature for humidity takes about 250 milliseconds!
    // Sensor readings may also be up to 2 seconds 'old' (it's a very slow sensor)
    humidity = dht.readHumidity();          // Read humidity (percent)
    temp_c = dht.readTemperature(false);     // Read temperature as Fahrenheit
    // Check if any reads failed and exit early (to try again).
    if (isnan(humidity) || isnan(temp_c)) {
      Serial.println("Failed to read from DHT sensor!");

Now we can modify our setup so we can see if everything is working. In the fritting digram below you can see that now I have added a the DHT11 Sensor and keeping the RX and TX connected so we can see in the monitor from the Arduino IDE if everything is working as we want to.

Now we have to connect our iPhone to the home bridge and add the new accesoires.

Hooray! it works!

Download all Files for this project on github

Do you have any questions? Leave a comment down below!

Pin on Pinterest2Share on Facebook0Share on Google+0Tweet about this on TwitterShare on LinkedIn0Buffer this pageDigg thisEmail this to someone
Flattr the authorShare on Reddit0Share on StumbleUpon0Share on Tumblr0Share on VKShare on Yummly0
  • Bram

    This is great! I’ve been “Google me this google me that….” for a while as well. Any idea about how to properly connect RPi to a Arduino (Pro mini) via NRF24L01+ ? Also, I recommend this sensor: Temperature Humidity Barometric Pressure BME280. It’s more accurate.

  • Thank you Bram! When you google, I noticed that there are a lot Proof of concept. But no explanations or step by steps for people that don’t have the knowledge or want build a simple setup.

    Regarding your question about the NRF24L01+, I didn’t work with this module yet, I would start here https://arduino-info.wikispaces.com/Nrf24L01-2.4GHz-HowTo. Here you find all the information you need.

    And about the BME280 sensor this is also a Sensor I know about, but in this setup I used the DHT11 because I wanted to test if it works 😉
    Now I can research en fine tune the setup with better sensors like BME280.

  • Kalpesh Mistry

    You are a great…. Excellent work!!!!

  • Thank you Kalpesh!