0% found this document useful (0 votes)
55 views23 pages

An IoT-Based Smart Home Automation System

Uploaded by

maasif6379
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
55 views23 pages

An IoT-Based Smart Home Automation System

Uploaded by

maasif6379
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 23

Article

An IoT-Based Smart Home Automation System


Cristina Stolojescu-Crisan 1,*, Calin Crisan 2 and Bogdan-Petru Butunoi 3

1 Communication Department, Politehnica University of Timisoara, 300223 Timișoara, Romania


2 SafeFleet Telematics, 300223 Timisoara, Romania; [email protected]
3 Computer Science Department, West University of Timisoara, 300223 Timișoara, Romania;

[email protected]
* Correspondence: [email protected]; Tel.: +40-723729955

Abstract: Home automation has achieved a lot of popularity in recent years, as day-to-day life is
getting simpler due to the rapid growth of technology. Almost everything has become digitalized
and automatic. In this paper, a system for interconnecting sensors, actuators, and other data sources
with the purpose of multiple home automations is proposed. The system is called qToggle and
works by leveraging the power of a flexible and powerful Application Programming Interface (API),
which represents the foundation of a simple and common communication scheme. The devices used
by qToggle are usually sensors or actuators with an upstream network connection implementing
the qToggle API. Most devices used by qToggle are based on ESP8266/ESP8285 chips and/or on
Raspberry Pi boards. A smartphone application has been developed that allows users to control a
series of home appliances and sensors. The qToggle system is user friendly, flexible, and can be
further developed by using different devices and add-ons.

Keywords: Internet of Things; home automation; smart homes; sensors

Citation: Stolojescu-Crisan, C.;


Crisan, C.; Butunoi, B.-P. An IoT
1. Introduction
Based Smart Home Automation
System. Sensors 2021, 21, 3784.
The Internet of Things (IoT) is a system that allows devices to be connected and re-
https://doi.org/10.3390/s21113784 motely monitored across the Internet. In the last years, the IoT concept has had a strong
evolution, being currently used in various domains such as smart homes, telemedicine,
Academic Editor: Paolo Visconti industrial environments, etc. [1]. Wireless sensor network technologies integrated into the
IoT enable a global interconnection of smart devices with advanced functionalities [2]. A
Received: 15 April 2021 wireless home automation network, composed of sensors and actuators that share re-
Accepted: 26 May 2021 sources and are interconnected to each other, is the key technology to making intelligent
Published: 30 May 2021 homes. A “smart home” is a part of the IoT paradigm and aims to integrate home auto-
mation. Allowing objects and devices in a home to be connected to the Internet enables
Publisher’s Note: MDPI stays neu- users to remotely monitor and control them [3]. These include light switches that can be
tral with regard to jurisdictional
turned on and off by using a smartphone or by voice command, thermostats that will
claims in published maps and institu-
adjust the indoor temperatures and generate reports about energy usage, or smart irriga-
tional affiliations.
tion systems that will start at a specific time of a day, on a custom monthly schedule, and
thus will control water waste. Smart home solutions have become very popular in the last
years. Figure 1 shows an example of a smart home that uses different IoT-connected util-
ities.
Copyright: © 2021 by the authors. Li-
censee MDPI, Basel, Switzerland.
One of the greatest advantages of home automation systems is their easy manage-
This article is an open access article
ment and control using different devices, including smartphones, laptops and desktops,
distributed under the terms and con- tablets, smart watches, or voice assistants. Home automation systems offer a series of ben-
ditions of the Creative Commons At- efits; they add safety through appliance and lighting control, secure the home through
tribution (CC BY) license (http://crea- automated door locks, increase awareness through security cameras, increase conven-
tivecommons.org/licenses/by/4.0/). ience through temperature adjustment, save precious time, give control, and save money.

Sensors 2021, 21, 3784. https://doi.org/10.3390/s21113784 www.mdpi.com/journal/sensors


Sensors 2021, 21, 3784 2 of 23

Figure 1. An IoT-based smart home depicting the use of smart sensing devices for different pur-
poses.

Several home automation systems involved with IoT have been proposed by aca-
demic researchers in the literature in the last decade. In wireless-based home automation
systems, different technologies have been used, each of them with their pros and cons. For
example, Bluetooth-based automation [4–6] is low cost, fast, and easy to be installed, but
it is limited to short distances. GSM and ZigBee are widely used wireless technologies as
well. GSM provides long-range communication at the cost of a mobile plan of the service
provider that operates in the area. Zigbee [7–12] is a wireless mesh network standard that
is designed to be low-cost and with low power consumption, targeted at battery-powered
devices in wireless control and monitoring applications. However, it has a low data speed,
low transmission, as well as low network stability, and has a high maintenance cost. Wi-
Fi technology is used in [9,11–18]. The advantages of Wi-Fi technology over ZigBee or Z-
Wave are related to price, complexity (meaning simplicity), and accessibility. First, Wi-Fi-
enabled smart devices are usually cheap. In addition, it is easier to find do-it-yourself de-
vices that use Wi-Fi, resulting a less expensive option. Second, Wi-Fi is already a necessity
and it is in most homes, so it is easier to buy devices that are already Wi-Fi-enabled. Fi-
nally, Wi-Fi is characterized by simplicity, meaning that a user must connect only a mini-
mal number of devices for a home automation setup. Since it is very common, the invest-
ment on extra hardware is avoided; a user only needs the basic setup for a home automa-
tion system. However, Wi-Fi is not designed to create mesh networks, it consumes ten
times more energy than similar devices using ZigBee, Z-Wave, or Bluetooth for example,
and many Wi-Fi routers can only allow up to thirty devices connected at once. As com-
pared to Ethernet, Wi-Fi brings several advantages, including the easy connection and
access of multiple devices, the expandability (adding new devices without the hassle of
additional wiring), lower cost, or single access point requirement. The cons include lim-
ited distance to cover (a Wi-Fi network with standard equipment can be limited in range
through walls and other obstructions in a standard home), the number of devices can be
limited, there is interference and complex propagation effects, obstacles can block the Wi-
Fi signal and affect the devices connected to it, and there are connection speed (the fastest
speed of Wi-Fi is much slower than a wired network), Internet security, and privacy is-
sues. Low-cost, open source hardware components, such as Arduino and Raspberry Pi
microcontroller unit (MCU) boards, and a combination of sensors have been very used in
the home automation domain. Home automations using Arduino boards are proposed in
[3,19–23]. Arduino is highly flexible, open source, not expensive, and easy to program
[19]. In addition, the existence of a large and active community of users is a great plus.
However, Arduino is not designed to handle the large complexity that comes with
Sensors 2021, 21, 3784 3 of 23

advanced projects. For more advanced and real-time projects, Raspberry Pi is a better op-
tion. Raspberry Pi is an exciting technological development that is much cheaper than any
desktop computer or mobile device [24]. Most of the software and projects done on Rasp-
berry Pi are open source and are maintained by online user communities, which are al-
ways excited about new projects. When developing software on Raspberry Pi, Python is
the language of choice, since it is relatively simple (fewer lines and less complexity) com-
pared to other programming languages. In addition to its low price, Raspberry Pi is en-
ergy efficient and does not require any cooling systems. Smart home automations with
Raspberry Pi are proposed in [9,12,15,25,26]. ESP8266 chips are low-price Wi-Fi modules
that are perfectly suited for projects in the IoT field. ESP8266 is a single core processor that
runs at 80 MHz. ESP8266 chips were used for home automations-related projects in
[9,21,27–30]. A features comparison for home automation system published in scientific
papers, in the last ten years, is presented in Table 1.
Another category of home automation systems is represented by commercial plat-
forms, such as Qivicon, Domintell, Loxone, or HomeSeer. They offer a wide range of smart
home devices, from multiple vendors, different communications protocols for wired
(Domintell) and wireless (Qivicon) transmissions, or both (HomeSeer and Loxone), and
multiple automations such as a locking system, controlling temperature, lightning system,
environmental system, video surveillance (only Qivicon and HomeSeer), or anti-intru-
sion. All solutions provide a mobile app for controlling the systems. Pricewise, it depends
on the size of the house, the number of devices to be installed, and the needs of the user.
According to [9], the minimum cost comes between 1800 and 2600 euros.

Table 1. Features comparison for home automation system published in the last 10 years.

Home Automa-
Communication Controller User Interface Applications
tion System
[4] Bluetooth PIC mobile app control indoor appliances
control appliances indoor and outdoor,
[5] Bluetooth Arduino mobile app
within short range
[6] Bluetooth, GSM PIC mobile app control appliances indoor and outdoor
[7] ZigBee, Ethernet Arduino MEGA mobile app control appliances indoor
Control panel
X10, Serial, EIB, 32-bit ARM mi-
[8] (touch pad), indoor automation solution
ZigBee, Bluetooth, crocontroller
desktop based
Raspberry PI, controlling humidity, temperature, lumi-
[9] Wi-Fi, ZigBee
NodeMCU nosity, movement, and current
Laptop/PC control of indoor appliances but not ac-
[10] ZigBee mobile app
server tually implemented
[11] ZigBee, Wi-Fi Linux board GUI interface control HVAC appliances
web-based, mo- remote control of appliances (IP cams,
[12] ZigBee, Wi-Fi, Ethernet Raspberry PI
bile app smart plugs)
control indoor appliances, monitor the
[13] Wi-Fi TI-CC3200 MCU mobile app
soil moisture
[14] Wi-Fi NodeMCU web-based control indoor appliances
[15] Bluetooth, Wi-Fi Raspberry PI mobile app control indoor appliances
web-based, mo-
[16] Wi-Fi Arduino mega control of indoor appliances
bile app
web-based, mo-
[17] Wi-Fi PC server security, energy management
bile app
[18] Wi-Fi, IR PC server mobile app control of indoor appliances
Sensors 2021, 21, 3784 4 of 23

control indoor appliances, video surveil-


[19] Wi-Fi Arduino mobile app
lance
control indoor appliances, energy man-
[20] Bluetooth Arduino mobile app
agement
Arduino,
[21] Wi-Fi mobile app control indoor appliances
ESP8266
web-based, mo- indoor and outdoor control, monitoring,
[22] Bluetooth, Wi-Fi Arduino mega
bile app energy management, safety, security
[23] Ethernet Arduino mega web-based control of indoor appliances
[25] Ethernet Raspberry PI web-based control home appliances, surveillance
light automation and physical intrusion
[26] ZigBee, Z-wave, Wi-Fi Raspberry PI unspecified
detection
web-based, mo- control indoor appliances (luminosity
[27] Wi-Fi NodeMCU
bile app sensor, LED, buzzer)
testing modules in a smart home system,
[28] Wi-Fi ESP8266 unspecified related to indoor appliances control, sur-
veillance, energy management
Arduino,
[29] Wi-Fi mobile app control of switches
ESP8266
control of appliances indoor and out-
web-based, mo-
[30] Wi-Fi Node MCU door, safety, security, energy manage-
bile app
ment, monitoring
web-based, mo- indoor and outdoor control, energy
[31] Ethernet Galileo board
bile app management, security
safety, monitoring (gas, temperature, fire
[32] GSM, Wi-Fi PC server web-based
sensors)
[33] GSM 8051 MCU web-based indoor and outdoor control
control of indoor appliances, safety, en-
[34] GSM Arduino web-based
ergy management
ZigBee,Wi-Fi, LabVIEW PDA remote monitoring and control system
[35] PC
GSM/GPR Module for intelligent buildings
[36] ZigBee PC web app power outlet control
multiple home automations indoor and
outdoor, irrigations, security, monitor-
Raspberry PI, web-based, mo-
qToggle Wi-Fi ing, power and energy management
ESP 8266 bile app
(including solar energy), Google assis-
tant compatible

Currently, a great variety of open source home automation systems exist [37–42].
OpenHAB [37] and Home Assistant [38] are two of the strongest players in the open
source home automation community, sharing a similar vision and integrating many de-
vices. However, openHAB requires knowledge regarding how to insert commands to in-
tegrate devices; it is complex and time consuming. Home Assistant, on the other hand, is
more user friendly, but it requires a significant configuration effort. Mobile apps seem less
flexible and quite complicated and complex, especially for beginners. Domoticz [39] de-
livers a decent number of features; its configuration is mostly done through the web in-
terface, and plugins are used to extend its functionality. Unfortunately, the interface itself
is not extremely intuitive. Domoticz is quite limited in terms of supported devices and
configurations. Calaos [40] and Jeedom [41] are two French players in the open source
home automation community. Unfortunately, the communities and forums are predomi-
nantly French, which can be a barrier to worldwide adoption. A feature comparison of the
Sensors 2021, 21, 3784 5 of 23

most relevant open-source home automation platforms is presented in Table 2. The plat-
forms can be differentiated, among others, in terms of the development language, the API,
the amount of implemented protocols and plugins, and the amount and type of documen-
tations. Of course, these are not the only options available. The authors of [19] present a
detailed comparison of fifteen open-source platforms.

Table 2. Comparison of the most relevant open-source home automation platforms.

System Development Language API Other Features


Representational state web interface, many protocols, many plugins,
OpenHAB Java
transfer (REST) MQTT, EPL v1 license, extensive documentation
REST/Python/Web- web interface, many protocols, many plugins,
HomeAssistant Python
socket APIs MQTT, Apache 2.0 license, extensive documentation
web interface, many protocols, many plugins,
Domoticz C++ JSON based
MQTT, GPL v3 license, extensive documentation
web interface, a few protocols, under development
Calaos C++ JSON based plugins, MQTT, GPL v3 license, extensive documen-
tation (in French)
web interface, many protocols, many plugins,
JSON RPC and HTTP
Jeedom PHP MQTT, GPL v2 license, extensive documentation (in
based
French)
web interface, many protocols, many plugins,
Fhem Perl ASCCII commands MQTT, GPL v2 license, extensive documentation (in
German)
web interface, many protocols, a few plugins (un-
dergoing continuous development), Hypertext
qToogle Python JSON based REST Transfer Protocol (HTTP) based messaging,
Apache 2.0 license, extensive documentation (in
English on Github)

The purpose of this paper is to present qToggle, which is a system designed and de-
veloped for multiple home/building automations, including access control and security,
appliances control (lights, thermostats, AC, and other appliances), irrigations, and power
and energy management. This paper represents an extension of [43]. In [43], we proposed
a building automation solution to reduce the exposure and transmission of COVID-19
during the pandemic situation in workspaces by avoiding touching certain objects and
surfaces and for helping managing buildings during an emergency. In this paper, we have
focused on smart homes applications, in general, not in a pandemic situation.
What makes our proposal different from others is highlighted in Table 1: it is differ-
ent in terms of the technologies used, the controllers, the type of communication, the user
interface, and most of all the applications regarding what solutions it can offer in terms of
a smart home. The communication technology represents a key point to achieve successful
operation in a home automation system. In many papers in the literature, the authors
combine several communication technologies; for example, the authors use either a wired
or a wireless technology to connect the sensors with the nodes, a wireless technology to
send data from nodes to storage centers, etc. Ethernet and/or a Wi-Fi local network are
usually enough for a working qToggle setup. Most low-cost devices for IoT usually sup-
port Wi-Fi, and most households are able to provide enough wireless coverage with sev-
eral low-cost devices. The best node and the selection of the processor (controller) for an
IoT-based home automation system are chosen considering the necessities and the char-
acteristics a user wants for the system. Even if most automation systems presented in the
literature use Arduino boards, the Raspberry family are frequently used as well, since
they are more potent than the Arduino boards and have powerful computing abilities that
Sensors 2021, 21, 3784 6 of 23

allow the implementation of more demanding software and algorithms. Hence, we chose
the Raspberry Pi board for the proposed system. Our system has not only a research scope,
but we intended to develop a system that can be successfully used in practice and as well
as monetized in the future. The microcontroller used for the proposed system is the
ESP8266 chip, due to its size, ultralow power consumption, powerful on-board pro-
cessing, and storage.
Most systems do not have access to the power grid or may only receive power during
a given time period. The use of solar energy reduces the energetic costs, which is an ad-
vantage for home automation systems. Starting this year, the qToggle system proposed in
this paper will be using solar energy thanks to the photovoltaic panels installed, so the
energy consumption will not be an issue.
qToggle is built around a flexible and powerful API (we have defined the API from
the ground up), allowing various types of devices to work together. qToggle provides a
simple language for the IoT by using the JavaScript Object Notation (JSON) data format,
which is defined by RFC 7159. Turning on a light bulb should be as easy as PATCH-ing a
URL, while obtaining the temperature from a sensor requires a simple GET request. The
idea behind qToggle is to control programmable systems having a Transmission Control
Protocol/Internet Protocol (TCP/IP) stack via simple HTTP requests. For example, these
systems can be single-board computers or TCP/IP-enabled microcontrollers. qToggle aims
to propose a standard that allows managing, provisioning, and communicating to differ-
ent devices. qToggle does not attempt to reinvent the wheel, but it makes use of the exist-
ing and widely used technologies, such as RESTful APIs on the top of HTTP, passing over
data encoded as JSON.
Features that make qToggle special are the following:
• A unitary and consistent solution that integrates all required features;
• Device provisioning and management;
• The firmware update over the same unique API used by all devices;
• The use of expressions allows intelligent and complex rules to be implemented be-
tween various sensors and actuators inside a network;
• Hierarchical master-slave topology that offers flexibility and scalability;
• User data do not leave the premises of the local network, a cloud connection not be-
ing needed (for security and privacy reasons);
• The integrated web app works well on all major platforms (both desktop and mobile):
Android, iOS, Windows, Linux, or macOS.

2. Materials and Methods


2.1. System Architecture and Design
The classic Ethernet and/or a Wi-Fi local network are usually enough for a working
qToggle setup. The different hardware used in the system includes Raspberry Pi 3 or 4
boards (any model), ESP 8266 Wi-Fi modules, and smart devices. The Raspberry Pi ver-
sion used for this project is Raspberry Pi 4, due to the improvements brought, as compared
to previous versions. For example, Raspberry Pi 1 and 2 do not have Bluetooth (it is
needed for controlling the thermostats). An important feature of the Raspberry Pi is the
row of general-purpose input/output (GPIO) pins. A 40-pin GPIO header is found on all
current Raspberry Pi boards [44]. The three roles of a Raspberry Pi board in a qToggle
setup are the following: the board could act as a qToggle device when it is equipped with
peripherals (sensors or relay boards), it could also act as a master hub for other devices,
and, finally, it could help install the ESP firmware on some devices, when running Tuya
Convert OS (Tuya is a Chinese smart devices platform that offers cloud services for
ESP8266/ESP8285-based devices). Tuya Convert OS helps replace this proprietary Tuya
firmware with a custom firmware, without disassembling the device. An important fact
is that it works only for Tuya-based devices. In fact, Tuya Convert OS is a customized
Raspbian OS image that runs Tuya Convert with a friendly user interface.
Sensors 2021, 21, 3784 7 of 23

The main part of the home automation system based on IoT is the microcontroller.
The ESP 8266 Wi-Fi module represents a set of efficient highly integrated wireless Systems
on Chip (SoCs), which provides a complete and standalone Wi-Fi network solution. The
ESP8266EX version is one of the most integrated Wi-Fi chips in the industry. In addition
to its Wi-Fi functionalities, ESP8266EX integrates an enhanced version of L106 Diamond
series 32-bit processor from Tensilica (company based in Silicon Valley, in the semicon-
ductor domain), with on-chip SRAM. ESP8266EX has seventeen GPIO pins, which can be
assigned to various functions by programming the appropriate registers, two power pins,
one ground pin, reset pin, and two clock pins. The devices used by qToggle are usually
sensors or actuators with an upstream network connection. Keeping the device firmware
updated is probably one of the most essential tasks, and it is often neglected when dealing
with a large number of devices. qToggle facilitates this task by allowing updates of the
firmware very simply for devices of different types and models. The qToggle API is an
intuitive HTTP API that enables remote controlling of basic hardware ports, such as
GPIOs or analog-to-digital converters (ADC).
The idea behind qToggle is to control programmable systems having a TCP/IP stack
via simple HTTP requests. For example, these systems can be single-board computers or
TCP/IP-enabled microcontrollers. API functions are grouped into the following catego-
ries:
• Device management—general status and configuration of the device;
• Port management—port information and configuration;
• Port values—reading and writing values from and to ports;
• Notifications—event notifications;
• Reverse API calls—API calls via reverse HTTP requests.
API specifications may seem quite complex, offering a wide range of functionalities
and use cases. However, most of them are optional, and only a small set of functions are
mandatory for a qToggle implementation.
The qToggle ecosystem is composed of a qToggleServer, qToggleOS, espQToggle,
add-ons, and other tools and packages that are specific to certain setups and use cases.
The main component is qToggleServer, which is written in Python. It acts as a hub and
provides the user-friendly web app. qToggleOS is an operating system (OS) ready to be
used with Raspberry Pi boards and runs qToggleServer. espQToggle is a custom firmware
for ESP8266/ESP8285 devices and implements the qToggle API. Finally, add-ons are op-
tional pieces of software that enhance the functionality of qToggleServer. A device used
by qToggle will describe itself, indicating its configuration, its supported optional func-
tionalities, and what ports it exposes. Each port, in its turn, will describe itself, indicating
its identifier, type, configuration, and so on. By combining master–slave relationships be-
tween simple devices and hubs in a network, a complex tree topology is obtained. Thus,
a large number of smart devices can be easily managed, as shown in Figure 2. The type of
communication in Figure 2 is Wi-fi or Ethernet. Consumers could operate at any level in
the hierarchy, thus limiting the access inside the network to any desired subtree.
Sensors 2021, 21, 3784 8 of 23

Figure 2. The qToggle topology.

In a real-world setup, it is difficult to individually manage many devices. Therefore,


a hub will allow a centralized administration of devices used by qToggle. Hubs act as
consumers when communicating to other devices, but they also expose an API interface
that allows other consumers to see them as devices. This allows for the creation of complex
hierarchies of devices and hubs that are in a master–slave relationship. With qToggle, a
device may act as a master for other slave devices. The master controls slave devices and
allows accessing them through its own API functions. In the same way, a slave device can
act as a master for other devices. Thus, complex chained master–slave configurations can
be obtained. Special API functions are supported by the master for listing, adding, and
removing slaves. Slave devices are identified on the master by their names, but the master
must be prepared for a slave’s name to change at any time.
qToggle implements three roles that dictate the access level: the administrator role,
which has the absolute power over a device, being able to view and modify the configu-
ration; the normal role, which has no access the configuration but can read from/write to
ports, and the view-only role that can only read the port’s values. To facilitate automation,
qToggle allows adding rules that dictate port values, based on various conditions. This
means that a port can be taught to use an expression based on other ports and functions
in a way that resembles spreadsheet formulas. Expressions can be set at a device level or
at a hub level. Expressions on a device are very fast, but they can only depend on ports
present on the device. When setting an expression at a hub level, the ports of any device
that is known by the hub can be included. This will effectively implement relations be-
tween different devices. If consumers need to be notified about events that take place on
the device, for example port value changes, qToggle offers three notification methods: lis-
tening for events using long HTTP requests (long polling), webhooks, and polling (the
least efficient, but easiest to be implemented). qToggle setups are usually deployed in pri-
vate networks, where devices cannot be directly accessed from the Internet. The solutions
often depend on port forwarding, where public IPs are available. If port forwarding is not
wanted/impossible, the devices can be set to open a connection to an external public server
and to wait for API requests. This mechanism is called reverse HTTP and allows making
HTTP requests to a device inside a private network without forwarding any port.
Sensors 2021, 21, 3784 9 of 23

From a developer point of view, qToggle offers add-ons that are an easy and conven-
ient way of packaging optional functionalities, which are usually tied to a specific device
or service. Add-ons can be published or be kept private, depending on the developer’s
needs and licensing requirements. The entire source code is completely opensource [45],
so one can easily understand how it works, may propose changes or may even join the
team. In addition, we provide documentation on using and further developing qToggle
for new devices or use cases.
Regarding the security, qToggle uses a series of best practices that are often found in
nowadays web-based applications. HTTPS is employed for when a client from the outside
(the Internet) talks to the hub. It ensures encryption, authenticity of the hub, and integrity
of the HTTP messages. Plain HTTP is used only locally, inside the premises, between the
hub and its controlled devices. A TLS certificate is used in conjunction with HTTPS to
ensure the security goals mentioned above; Let’s Encrypt is used to generate and renew
the TLS certificates. This process is done automatically on the hub, upon certificate expiry.
Remote (administrative) access on the hub is done via SSH. The SSH protocol uses ECDSA
(or similar) private/public key pairs for authentication and encryption. Alternatively, the
administrator password defined on the hub may be used to log in remotely with username
and password.
The API defines three roles that dictate the permissions of an API request: adminis-
trator, normal user, and view-only user. API requests use the JSON Web Token (JWT)
defined by RFC 7519 to supply authentication data. A shared secret (called password)
ensures the authenticity of the caller. The secret is hashed with a salt before used to sign
the JWT token to prevent compromising the original password. Reply attacks are pre-
vented by using the current timestamp as a nonce included in the JWT.
Alternatively, we could have used HTTP Basic Authentication, HTTP Digest Authen-
tication, or a cookie-based session management with a conventional login form. Basic Au-
thentication is insecure when transmitted over unencrypted channels, while Digest Au-
thentication is unnecessarily complicated and requires exchanging multiple messages.
The cookie/session-based method is prone to session stealing attacks and may also be in-
secure on unencrypted channels.
The embedded Over-the-Air (OTA) mechanism (firmware update) ensures that the
hub as well as its attached devices always run the latest available version, thus allowing
us to quickly bring security patches in case a vulnerability is discovered.

2.2. Configuring the Web Application


qToggleServer provides a user-friendly interface, named frontend, which comes in
the form of a progressive web application (PWA). It is designed to be used on
smartphones, tablets, but also on laptops/desktop machines. Firstly, the application
should be installed and, being a PWA, it should be added to the home screen. After instal-
lation, the qToggle app will be found in the applications list of the device, and it can be
uninstalled whenever the user wants to. When the user logs in for the first time (see Figure
3a), an admin with an empty password should be used. However, for security reasons, it
is highly recommended to set a password in the Settings page of the app.
The dashboard is the section where users will spend most of the time when using
qToggleServer. Here, they can create panels and groups of panels, as shown in Figure 4.
In the panel edit mode, the user can perform various tasks, for example add, move around,
remove, resize, or configure widgets. Widgets usually require selecting one or more ports.
Ports values will be displayed and/or changed by the widget upon interaction.
An example is given in Figure 5. The ports section is only accessible to administrators.
In this section, the user may add, remove, and configure ports (see Figure 6). If users have
slave devices management enabled in qtoggleserver.conf (by default they are enabled),
the first thing they will have to do is to select the device whose ports will be edited. The
first device in the list represents the hub (the master device) itself. An important fact is
that only administrators can add, remove, and configure slave devices (see Figure 7).
Sensors 2021, 21, 3784 10 of 23

(a) (b)
Figure 3. Logging in for the first time on qToggleServer (a) and setting used and password (b).

(a) (b)
Figure 4. Creating panels (a) and groups of panels (b).
Sensors 2021, 21, 3784 11 of 23

(a) (b)
Figure 5. Working with widgets: dashboard layout (a), widget properties (b).

(a) (b)
Figure 6. Adding, removing (a) and configuring ports (b).
Sensors 2021, 21, 3784 12 of 23

(a) (b)
Figure 7. Adding, removing (a) and configuring slave devices (b).

qToggle app is linked with the qToggleServer package. This means that users will get
an app update whenever they update their qToggleServer installation. Since qToggle is a
web app, the update process is done automatically by the browser, when the user reopens
or refreshes the app. The user can either close it and reopen it, or he/she can use the pull-
to-refresh function to make sure the app is up to date. The code and documentation for
qToggle can be found on Github [45].

3. Real Home Case Study


In the following, the use of qToggle in a real home will be presented. The scenario
consists of a two-floor house with five rooms, two bathrooms, kitchen, pantry, shed, gar-
age, and garden. In this case, qToggle is used for various purposes, such as:
• Controlling the indoor temperature (thermostats and air conditioning (A/C));
• Controlling the lights (on–off);
• Monitoring the power and the energy;
• Controlling the doors—gates, garage door, or both at the same time (open–close);
• Security—the alarm;
• Garden sprinklers.

3.1. Controlling Temperatures and A/C


The purpose of controlling the indoor temperatures is to maintain thermal comfort
and to save energy cost. In this case, the thermostats system offers the following ad-
vantages: the ability to access and control the indoor temperature anytime and from any-
where using qToggle app on the mobile phone, as presented in Figure 8a, the ability to
monitor and separately set the temperature in individual rooms (not every room has the
Sensors 2021, 21, 3784 13 of 23

same heating requirements), and, finally, the ability to enable scheduling (lower the tem-
perature during the day, when nobody is home, or during vacation). In this way, manual
adjustments are eliminated to save time and effort.

(b)

(a) (c)
Figure 8. Controlling indoor temperatures with qToggle app (a) together with smart termostats (b)
and (c).

This case study home is provided with nine smart thermostats. Thanks to tempera-
ture sensors, the heat system will start only when the temperature falls under a set value
(this value is set on qToggle app, for each room). For this project, six Smart Wi-Fi Touch
Thermostat Temperature Wireless Controllers, connected to the power line (shown in Fig-
ure 8b) and three Eqiva’s eq-3 Bluetooth smart thermostats, which run on batteries,
(shown in Figure 8c) have been used.
The A/C can be controlled to turn on and off without using the remote, by using the
qToggle app. This task can be done using a smart plug for the A/C machine. Controlling
the degrees is a feature that can be very easily implemented in qToggle, if necessary, and
it will look similar to the case of thermostats.

3.2. Controlling the Lights


The proposed lighting control system on the qToggle app is shown in Figure 9. One
of its main advantages is, of course, the comfort. Smart lights can, without any doubts,
make our everyday life easier. Another advantage is related to energy saving. Big houses,
with many rooms, can waste a lot of energy by simply leaving the lights on where they
are not needed. In addition, many people forget the lights on somewhere in the house,
when going to bed or leaving the house. In these cases, it is easy to see where lights are on
and to control them using the mobile app. In addition, a smart lighting control system
supports home security by providing increased protection. For example, this means that
while away on holiday, the lighting system could periodically switch on and off lighting
in the house, as if someone were actually home. The light can be controlled through
Sensors 2021, 21, 3784 14 of 23

qToggle app, or using Google Home assistant and the voice command “turn on/off the
light in ... room”. qToggle is compatible with Amazon Alexa as well. The devices used for
controlling the lights are Sonoff Touch with one, two, or three channels.

(a) (b)
Figure 9. Switching on and off the lights in a house with qToggle app (a) and the Sonoff Touch device (b).

3.3. Energy and Power Monitoring


Nowadays, the whole world is looking for sustainable and energy efficient solutions
to make our planet greener, so the use of renewable energy sources, such as solar energy
to the maximum efficiency possible is the best solution. Photovoltaic panels convert the
sun’s rays into electrical power and have become more affordable than ever. Combining
the energy savings of solar systems with the smart technology, the benefit of renewable
energy in a home is maximized. Home solutions can be fully automated using solar
power. In addition to cutting energy bills and providing energy efficiency, solar power-
based home solutions provide for the reduction of individual carbon footprint, give off
zero emissions, and reduce overall environmental damage. For this case study, thirty-
three photovoltaic (PV) panels have been installed, in two stages: the first sixteen panels
(correspond to PV2 in Figure 10a, first panel, left), and then another seventeen panels (cor-
respond to PV1 in Figure 10a, first panel, left).
Solar installations require a dedicated solar inverter that converts solar power from
the PV system into an alternating current. Inverters that are able to inject the excess of
energy into the grid are called on-grid (or grid-tie) inverters and, in many countries, are
subject to stricter rules than those that work off-grid. One of the most notable require-
ments for a grid-tie inverter is the anti-islanding protection: in case of a grid power outage,
the inverter must immediately stop injecting energy, thus protecting electrical workers
Sensors 2021, 21, 3784 15 of 23

and upstream equipment. For this case study, the PV power inverters are from the follow-
ing brand manufacturers: Fronius for PV1 (see Figure 10b) and MPPSolar for PV2 (see
Figure 10c).

(a)

(b) (c)
Figure 10. Monitoring the energy with qToggle (a) and the two invertors: Fronius Symo (b) and
Mppsolar (c).

Solar energy can also be stored in batteries. When using batteries of a relatively large
capacity, the energy accumulated over the day can be consumed during the night or dur-
ing rainy days. Systems with smaller capacities may only be used as a backup, in case of
grid outages, being able to supply the house with energy for a limited number of hours.
An inverter that is capable of switching between grid, solar, and battery energy sources,
depending on various configurable conditions, is called a hybrid inverter. MPPSolar is
such a hybrid inverter.
The aim for monitoring the power is to see how much energy the house is using and
to become more aware of the energy use and, thus, of the money spent. An electricity
monitor also helps identify any high energy appliance accidentally left switched on. More-
over, an important goal of power monitoring is the detection of abnormal conditions in
voltage when the electrical network is undersized, and there are a lot of voltage variations.
A smart power meter allows a continuous monitoring of all the important parameters
Sensors 2021, 21, 3784 16 of 23

when it comes to electricity: active, reactive, or apparent power, power factor, current,
voltage, frequency, and total energy consumption. The device is based on ESP8266 and
integrates a high current switch that can be used to remotely cut off energy supply, in case
of an emergency. Figure 11 presents how the power is monitored using qToggle.
We consider that voltage monitoring is essential because the actual voltage supplied
by the grid operator often varies from its nominal value, possibly causing faults to the
electrical equipment. The chart (shown in Figure 11a) as well as its underlying historical
data may serve as proof in case of appliance damage. The excess of solar produced power
can be either used for household electrical necessities or it can be injected into the grid.
Hence, we have the total house power (shown in Figure 11b) , as well as the consumed
and injected grid power (shown in Figure 11c,d).

(a) (b)

(c) (d)
Figure 11. An example of monitoring the power with qToggle: AC Input Voltage (a); House Power (b); Gris Consumed
Power (c); Grid Produced Power (d).

3.4. Access Control and Security


Access control involves controlling entrances, gates and doors, in this case study, the
gates and the garage door, specifically. Various options can be chosen: to fully open or
close only the gates, only the garage door, or both at the same time, or to keep half open
one of them or both, as shown in Figure 12a. Access control can be done manually, using
the app, and by vocal commands, using Google assistant on a smart watch. To control
gate motors and the garage door, we used two Blitzwolf SS1smart relay boards that enable
remote opening/closing. This allowed us to mimic the conventional gate remote control
using our Wi-Fi-based system.
Sensors 2021, 21, 3784 17 of 23

(a) (b)
Figure 12. Access control (a) and security (b) with qToggle.

The home security system consists of a master control panel, the keypad (when not
using the qToggle app), motion sensors, and the siren. The qToggle app is provided with
the options to arm and disarm the security system, as shown in Figure 12b. Arming and
disarming can be performed by voice commands as well, using Google Assistant/smart
watch. We have also implemented the Sleep option, which can be used during the night
and arms only the ground floor of a house, for security reasons. If motion is detected
downstairs during the night, the alarm will trigger. Arming and Disarming, using Sleep
mode, can be done manually, using the qToggle app, but also using an extra light switch,
placed upstairs (for more comfort). The alarm system used in this case study is a Paradox
MG5050 alarm. A custom integration module has been developed using a Raspberry Pi
board to be able to control the alarm unit remotely.

3.5. Controlling the Irrigations


Automated irrigation systems help people control the water used in their gardens or
fields and, thus, to avoid water waste, to save energy and time, and to minimize water
bills. Using an automatic system based on valves instead of the classical manual irrigation
also avoids human errors, for example forgetting to irrigate one day, not being able to do
it, or forgetting to turn off the water after irrigation. The proposed irrigation system is
based on Raspberry Pi and controls a number of pop-up sprinklers. The system inside the
well contains: electric valves (Rain Bird DV/DVF valves), one standard 1.1 kW water
pump, a Raspberry Pi board connected to the house LAN, and a pressure switch (Easy
Press II model, with a maximum pressure of 10 bar). Figure 13a shows how the irrigation
system can be controlled using the qToggle app. The user is able to select two modes: the
manual one where he can start and stop irrigations whenever he wants and in which zone
he wants and an automatic mode, with or without humidity sensors (YL69 sensors from
SparkFun, in this case, shown in Figure13b).
Sensors 2021, 21, 3784 18 of 23

(a)

(b)
Figure 13. Controlling the irrigation system with qToggle (a) and the YL 69 sensor (b).

In the automatic case, without sensors, the user is able to set schedules, by turning
on the Enable schedule button. The adjustments can be made on the last four slides in the
app: Morning factor, Evening factor, Morning time, and Evening time. The user is able to
select the time in the morning and evening when the irrigation should start but also select
the amount of water by adjusting the Morning/Evening factor. A time-controlled sprin-
klers system not only eliminates the chore of hand watering but also saves water, time,
energy, and of course money. The sensors and actuators used for the presented case study,
along with their main characteristics are shown in Table 3. Of course, in the arhitecture of
qToggle, any kind of sensor or actuator can be used.
Sensors 2021, 21, 3784 19 of 23

Table 3. Sensors and actuators used by qToggle for this case study.

Sensor/Actuator Name Price Measurement Range Consumption


Temperature ME81H $25–30 5–60 °C 450 mA
Soil moisture YL69 $5 0–100% 35 mA
Motion Paradox PIR sensor $35–40 logic ultralow power
Power meter ZMAi-90 $30–35 90–250 V, 0–60 A, 0–15 kW 1W
Simple relay board Blitzwolf SS1 $8 0.5 W
4-relay module SainSmart $3–5 5–65 mA
Touch sensor Sonoff Touch $15–20 logic 0.5 W

The communication architecture for this case study is shown in Figure 14.

Figure 14. qToggle arhitecture for the presented case study.

The qToggle architecture for this case study is composed of a Master hub connected
to the house LAN and six hubs connected to the Master hub:
• Upstairs hub—controls lightning and HVAC systems upstairs
• Downstairs hub—controls lighting and temperatures downstairs
• Power hub—in charge with energy and power monitoring
• Garage hub—controls lights, temperature, and access
• Alarm controller—motion monitoring and alarm system control
• Irrigation controller—controls the irrigation system in the garden
Sensors 2021, 21, 3784 20 of 23

The communication between the Master hub and the other hubs is done wirelessly
except with the Garage hub and the Power hub, which is wired.
Interoperability and communication between devices is achieved by adopting a sin-
gle, unitary, and extensible API across all devices that are part of a qToggle system.
For logging purposes, we use the Python logging module that captures logging from
all modules and sends it to a log file, which is used for auditing and debugging purposes,
if needed. System-level logs are gathered in the same manner into dedicated log files.
Moreover, all log files are rotated on size and age conditions, so that we do not acci-
dentally run out of storage due to excessive logging.
Events are actually inputs whose values change. These inputs are usually mapped to
physical ports whose logic state may change, but they can also be virtual ports, which are
obtained as combinations of other inputs, using Excel-like expressions.

4. Discussion and Future Work


In this project, we proposed a simple solution for home automation based on ESP8266
chips and Raspberry Pi boards. Both choices are cost effective, small, and easy to work
with. Moreover, the proposed qToggle system uses a very basic core API, allowing for a
more flexible network design. qToggle is aimed to be a complete smart home prototype,
with a lot of functionalities—automation, control, monitoring, and security—and it is a
system that could be continuously developed and improved.
One contribution of this paper involves the reviewing of the recent (last 10 years)
papers published in the literature, commercial solutions, and open source home automa-
tion systems (Tables 1 and 2), so that the paper could be considered a survey. As compared
to other papers in the literature, the proposed paper details the implementation of the
solution (both hardware and software). Most smart home systems presented in the litera-
ture [4–34] have been made with fewer functionalities, using different technologies, con-
trollers, type of communication, user interface, etc., and this is emphasized in Table 1.
qToggle works with a selected list of devices, imposing a unitary API, firmware, and
so on. We provide the open source firmware, meaning that no hacks and no 3rd party
hubs or clouds are required; all devices speak the same language (API) and are controlled
the same way. The supported devices are tested thoroughly, with a well-documented in-
stallation procedure. This does not mean that other devices cannot be added to qToggle:
there are add-ons that provide bridges and adaptation layers to different peripherals, net-
works, and technologies. Regarding the number of devices, qToggle is highly scalable
thanks to its master–slave architecture. One device can be at the same time a master to
other slave devices and a slave for another master, at a higher place in the hierarchy. The
core of qToggleServer, as well as the firmware that runs on ESP8266-based devices, are
entirely asynchronous, meaning that a request can never block the functioning of the de-
vice. In turn, this allows for a relatively large number of incoming requests per second to
each device, increasing the scalability of the system.
In this paper, we present a real case study (a real home) and all the features the pro-
posed system (including the app) offers to make life easier and cheaper. The proposed
solution can be implemented by any used using the code available on Github and can be
used successfully in reality. This paper offers a description on how the system is imple-
mented, how the app can be installed and configured, what functionalities are covered,
and what devices can be used in order to have a smart home (see Figure 14).
qToggle’s strengths lie in its simplicity and flexibility. In addition, we intended to
provide a low-cost home automation system. It is well known that the deployment and
maintenance of a commercial home automation system come with a high cost. This cost is
even higher if the number of devices that compose the system and used technologies
grows. Usually, a basic package for automating a small house exceeds 1000 dollars. qTog-
gle attempts to do a very good job at providing a curated list of supported devices. What
motivates our approach is the fact that we control the firmware of each device (which is
itself open source) and thus the entire user experience is a lot more integrated. Controlling
Sensors 2021, 21, 3784 21 of 23

the firmware also allows leveraging the full power of each device, customizing it per each
user’s needs and providing critical security updates, while unifying the API. We take us-
ers’ privacy very seriously, and in qToggle, user data never leaves the premises (i.e., the
home local network). Not being in control of the firmware of all devices, other platforms
must rely on OEM or vendor-provided firmware, which often employs data communica-
tion via a 3rd party cloud service. Probably one of the biggest differences between qToggle
and its competitors is that our target audience includes users without a technical back-
ground, who prefer intuitive, off-the-shelf solutions with minimal setup requirements and
a smooth learning curve. qToggle provides a PWA (progressive web app). The advantages
of a PWA include the fact that updates are immediate (not being served via App Store or
Play Store) and there is one single code base shared among all platforms. Finally, maybe
the most important thing is that we have provided a solution that can be used successfully
in reality.
The future will bring an increase in terms of sensor products, as well as devices, thus
automating every aspect of our home life. A feature that will be soon added to qToggle is
monitoring the air humidity. Extreme humidity levels can cause mold and result in cost
damage. A high humidity causes condensation and mold; a low humidity increases the
risk of respiratory illnesses and allows viruses and germs to multiply. Thus, a humidity
sensor will protect buildings and belongings by monitoring humidity levels, and it could
be programmed to alert the customer in case the indoor humidity fluctuates to undesira-
ble levels.
Another future task will be the integration of video surveillance in qToggle. We have
already developed a video surveillance OS for single board computers, so that a user can
manage their video cameras very easily, in the browser. The system (called MotionEye)
has become very popular in the open source world, with 50 releases on Github, and more
than 650,000 downloads since 2014.

Author Contributions: Conceptualization, C.C., C.S.-C. and B.-P.B.; methodology, C.C. and B.-P.B.;
software, C.C. and B.-P.B.; validation, C.C., C.S.-C. and B.-P.B.; formal analysis, C.C., C.S.-C. and B.-
P.B.; investigation, B.-P.B.; resources, C.S.-C.; writing—original draft preparation, C.S.-C.; writing—
review and editing, C.C. and B.-P.B.; supervision, C.C., C.S.-C. and B.-P.B.; project administration,
C.C. All authors have read and agreed to the published version of the manuscript.
Funding: This research received no external funding.
Institutional Review Board Statement: Not applicable.
Informed Consent Statement: Not applicable.
Conflicts of Interest: The authors declare no conflict of interest.

Abbreviations
The following abbreviations are used in this manuscript:

API Application Programming Interface


HVAC Heating, Ventilation and Air Conditioning
HTTP Hypertext Transfer Protocol
IoT Internet of Things
JSON JavaScript Object Notation
MQTT Message Queuing Telemetry Transport
PWA Progressive Web App
REST Representational state transfer
TCP-IP Transmission Control Protocol-Internet Protocol
Sensors 2021, 21, 3784 22 of 23

References
1. El-Hajj, M.; Fadlallah, A.; Chamoun, M.; Serhrouchni, A. A Survey of Internet of Things (IoT) Authentication Schemes. Sensors
2019, 19, 1141, doi:10.3390/s19051141.
2. Spadacini, M.; Savazzi, S.; Nicoli, M. Wireless home automation networks for indoor surveillance: Technologies and experi-
ments. EURASIP J. Wirel. Commun. Netw. 2014, 2014, 6, doi:10.1186/1687-1499-2014-6.
3. Lee, K.-M.; Teng, W.-G.; Hou, T.-W. Point-n-Press: An Intelligent Universal Remote Control System for Home Appliances. IEEE
Trans. Autom. Sci. Eng. 2016, 13, 1308–1317, doi:10.1109/tase.2016.2539381.
4. Puri, V.; Nayyar, A. Real time smart home automation based on PIC microcontroller, Bluetooth and Android technology. In
Proceedings of the 3rd International Conference on Computing for Sustainable Global Development (INDIACom), New Del-
hi, India, 16–18 March 2016; pp. 1478–1484.
5. Asadullah, M.; Ullah, K. Smart home automation system using Bluetooth technology. In Proceedings of the 2017 International
Conference on Innovations in Electrical Engineering and Computational Technologies (ICIEECT), Karachi, Pakistan, 5–7 April
2017; pp. 1–6.
6. Anandhavalli, D.; Mubina, N.S.; Bharath, P. Smart Home Automation Control Using Bluetooth and GSM. Int. J. Inf. Futur. Res.
2015, 2; 2547–2552.
7. Baraka, K.; Ghobril, M.; Malek, S.; Kanj, R.; Kayssi, A. Low Cost Arduino/Android-Based Energy-Efficient Home Automation
System with Smart Task Scheduling. In Proceedings of the 2013 5th International Conference on Computational Intelligence,
Communication Systems and Networks, Madrid, Spain, 5–7 June 2013; pp. 296–301.
8. Zamora-Izquierdo, M.A.; Santa, J.; Gomez-Skarmeta, A.F. An Integral and Networked Home Automation Solution for Indoor
Ambient Intelligence. IEEE Pervasive Comput. 2010, 9, 66–77, doi:10.1109/mprv.2010.20.
9. Froiz-Míguez, I.; Fernández-Caramés, T.M.; Fraga-Lamas, P.; Castedo, L. Design, Implementation and Practical Evaluation of
an IoT Home Automation System for Fog Computing Applications Based on MQTT and ZigBee-WiFi Sensor Nodes. Sensors
2018, 18, 2660.
10. Li, Z.M.; Song, M.; Gao, L. Design of Smart Home System Based on Zigbee. Appl. Mech. Mater. 2014, 635–637, 1086–1089, doi:
10.4028/www.scientific.net/amm.635-637.1086.
11. Vivek, G.; Sunil, M. Enabling IOT services using WIFI-ZigBee gateway for a home automation system. In Proceedings of the
2015 IEEE International Conference on Research in Computational Intelligence and Communication Networks (ICRCICN), Kol-
kata, India, 20–22 November 2015; pp. 77–80.
12. Huang, F.-L.; Tseng, S.-Y. Predictable smart home system integrated with heterogeneous network and cloud computing. In
Proceedings of the 2016 International Conference on Machine Learning and Cybernetics (ICMLC), Jeju, Korea, 10–13 July 2016;
Volume 2, pp. 649–653.
13. Kodali, R.K.; Jain, V.; Bose, S.; Boppana, L. IoT based smart security and home automation system. In Proceedings of the 2016
International Conference on Computing, Communication and Automation (ICCCA), Noida, India, 29–30 April 2016; pp. 1286–
1289.
14. Singh, U.; Ansari, M.A. Smart Home Automation System Using Internet of Things. In Proceedings of the 2019 2nd International
Conference on Power Energy, Environment and Intelligent Control (PEEIC), Noida, India, 18–19 October 2019; pp. 144–149.
15. Davidovic, B.; Labus, A. A smart home system based on sensor technology. Facta Univ. Ser. Electron. Energetics 2016, 29, 451–
460, doi:10.2298/fuee1603451d.
16. Jabbar, W.A.; Kian, T.K.; Ramli, R.M.; Zubir, S.N.; Zamrizaman, N.S.M.; Balfaqih, M.; Shepelev, V.; Alharbi, S. Design and
Fabrication of Smart Home with Internet of Things Enabled Automation System. IEEE Access 2019, 7, 144059–144074,
doi:10.1109/access.2019.2942846.
17. Bhatt, A.; Patoliya, J. Cost effective digitization of home appliances for home automation with low-power WiFi devices. In
Proceedings of the 2016 2nd International Conference on Advances in Electrical, Electronics, Information, Communication and
Bio-Informatics (AEEICB), Chennai, India, 27–28 February 2016; pp. 643–648.
18. Yan, W.; Wang, Q.; Gao, Z.; Zhenwei, G. Smart home implementation based on Internet and WiFi technology. In Proceedings
of the 34th Chinese Control Conference (CCC), Hangzhou, China, 28–30 July 2015; pp. 9072–9077.
19. Shafana, A.R.F.; Aridharshan, A. Android based automation and security system for smart homes. Int. J. Comput. Sci. Inf. Technol.
2017, 5, 26–30.
20. Howedi, A.; Jwaid, A. Design and implementation prototype of a smart house system at low cost and multi-functional. In
Proceedings of the 2016 Future Technologies Conference (FTC), San Francisco, CA, USA, 6–7 December 2016; pp. 876–884.
21. Gunputh, S.; Murdan, A.P.; Oree, V. Design and implementation of a low-cost Arduino-based smart home system. In Proceed-
ings of the 2017 IEEE 9th International Conference on Communication Software and Networks (ICCSN), Guangzhou, China,
6–8 May 2017; pp. 1491–1495.
22. David, N.; Chima, A.; Ugochukwu, A.; Obinna, E. Design of a home automation system using Arduino. Int. J. Sci. Eng. Res. 2015,
6, 795–801.
23. Imran, S.S.; Vignesh, J.; Singh, V.K.; Prasath, D.T.A. Smart Home automation based on IoT using Arduino mega. In Proceedings
of the International Conference on Current Research in Engineering Science and Technology (ICCREST-2016), Hyderabad, In-
dia, 25–27 October 2016; pp. 2348–8379.
24. Upton, E.; Halfacree, G. Raspberry Pi User Guide, 4th ed.; John Wiley and Sons Ltd.: Hoboken, NJ, USA, 2016.
Sensors 2021, 21, 3784 23 of 23

25. Patchava, V.; Kandala, H.B.; Babu, P.R. A Smart Home Automation technique with Raspberry Pi using IoT. In Proceedings of
the 2015 International Conference on Smart Sensors and Systems (IC-SSS), Bangalore, India, 21–23 December 2015; pp. 1–4.
26. Ozeer, U.; Letondeur, L.; Ottogalli, F.-G.; Salaun, G.; Vincent, J.-M. Designing and Implementing Resilient IoT Applications in
the Fog: A Smart Home Use Case. In Proceedings of the 2019 22nd Conference on Innovation in Clouds, Internet and Networks
and Workshops (ICIN), Paris, France, 19–21 February 2019; pp. 230–232.
27. Kodali, R.K.; Soratkal, S. MQTT based home automation system using ESP. In Proceedings of the 2016 IEEE Region 10 Human-
itarian Technology Conference (R10-HTC), Agra, India, 21–23 December 2016; pp. 1–5.
28. Syafa’Ah, L.; Minarno, A.E.; Sumadi, F.D.S.; Rahayu, D.A.P. ESP 8266 for Control and Monitoring in Smart Home Application.
In Proceedings of the 2019 International Conference on Computer Science, Information Technology, and Electrical Engineering
(ICOMITEE), Jember, Indonesia, 16–17 October 2019; pp. 123–128.
29. Makhanya, S.P.; Dogo, E.M.; Nwulu, N.I.; Damisa, U. A Smart Switch Control System Using ESP8266 Wi-Fi Module Integrated
with an Android Application. In Proceedings of the 2019 IEEE 7th International Conference on Smart Energy Grid Engineering
(SEGE), Oshawa, ON, Canada, 12–14 August 2019; pp. 125–128.
30. Jabbar, W.A.; Alsibai, M.H.; Amran, N.S.S.; Mahayadin, S.K. Design and Implementation of IoT-Based Automation System for
Smart Home. In Proceedings of the International Symposium on Networks, Computers and Communications (ISNCC), Rome,
Italy, 19–21 June 2018; pp. 1–6.
31. Gupta, P.; Chhabra, J. IoT based Smart Home design using power and security management. In Proceedings of the 2016 Inter-
national Conference on Innovation and Challenges in Cyber Security (ICICCS-INBUSH), Noida, India, 3–5 February 2016; pp.
6–10.
32. Badabaji, S.; Nagaraju, V.S. An IoT Based Smart Home Service System. Int. J. Pure Appl. Math. 2018, 119, 4659–4667.
33. Ganesh, E. Implementation of IOT Architecture for SMART HOME using GSM Technology. Int. J. Comput. Tech. 2017, 4, 42–48.
34. Kaur, S.; Singh, R.; Khairwal, N.; Jain, P. Home Automation and Security System. ACII 2016, 3, 17–23, doi:10.5121/acii.2016.3303.
35. Nedelcu, A.-V.; Sandu, F.; Machedon-Pisu, M.; Alexandru, M.; Ogrutan, P. Wireless-based remote monitoring and control of
intelligent buildings. In Proceedings of the 2009 IEEE International Workshop on Robotic and Sensors Environments, Lecco,
Italy, 6–7 November 2009; pp. 47–52.
36. Fernández-Caramés, T.M. An Intelligent Power Outlet System for the Smart Home of the Internet of Things. Int. J. Distrib. Sens.
Networks 2015, 11, 214805, doi:10.1155/2015/214805.
37. OpenHAB. Available online: http://www.openhab.org (accessed on 23 December 2020).
38. Home-Assistant Official Web Page. Available online: http://wwww.home-assistant.io (accessed on 13 January 2021).
39. Domoticz Official Web Page. Available online: http://domoticz.com (accessed on 13 January 2021).
40. Calaos Official Web Page. Available online: https://calaos.fr/en/ (accessed on 13 January 2021).
41. Jeedom Official Web Page. Available online: https://www.jeedom.com (accessed on 13 January 2021).
42. Fehm Official Web Page. Available online: http://www.fhem.de/fhem.html (accessed on 13 January 2020).
43. Stolojescu-Crisan, C.; Crisan, C.; Butunoi, B.P. IoT Based Intelligent Building Applications in the Context of COVID-19 Pan-
demic. In Proceedings of the International Symposium on Electronics and Telecommunications (ISETC), Timisoara, Romania,
5–6 November 2020.
44. Shahajan, M.; Islam, G.M.J.; Das, S.K.; Islam, S.; Islam, M.; Islam, K.K. Internet of Things (IoT) based automatic electrical energy
meter billing system. J. Electron. Commun. Eng. 2019, 14, 39–50.
45. qToggle Project. Available online: https://github.com/qtoggle/qtoggleserver (accessed on 15 May 2021).

You might also like