Proximity Detection in NodeMCU Using Wifi

by jnamanjain2001 in Circuits > Arduino

715 Views, 1 Favorites, 0 Comments

Proximity Detection in NodeMCU Using Wifi

Screenshot 2023-04-15 164039.png

In this project we connect an ESP8266 to a WiFi access point. If a mobile phone with a specific MAC address is also connected to the same access point with RSSI greater than a threshold then updated its status to an IoT dashboard. We use different LED colors on ESP32 to show the status of send/delivered message

Supplies

Hardware Requirements:


  • ESP8266 WiFi module
  • RGB Led
  • Jumper Cables
  • Micro Usb Cable


Software Requirements:

  • Arduino IDE
  • Ubidots Account
  • Node.js


Arduino Library Requirements:


AVision_ESP8266 by A-Vision Software

PubSubClient by Nick O'Leary

ArduinoJson by Benoit Blanchon

Ubidots MQTT for ESP8266 by Jose Garcia

Initial Setup

pin-diagram.png

Clone the GitHub Repository - https://github.com/namanjain-iitr/Proximity-Detector

Using ssh:

git clone git@github.com:namanjain-iitr/Proximity-Detector.git


Navigate to Proximity-Detector library using:

cd Proximity-Detector


Connect ESP 8266 to RGB lights according to given pinout diagram.

Ubidots Setup

Screenshot (55).png
2023-04-17.png
  1. Create a Ubidots STEM account at - https://ubidots.com/stem
  2. Log In to your Ubidots STEM account - https://stem.ubidots.com/accounts/signin/
  3. Click on Profile Icon on Top Right side and select API Credentials.
  4. Copy the default token value and Save it for use in Next Section.

Arduino Code Setup

Navigate to WifiProximity Directory to access WifiProximity.ino file that contains the arduino code for our project:

cd WifiProximity


Now open the WifiProximity.ino file inside your arduino IDE and fill the following details:


First, enter your Ubidots Token string taken from the previous step:

char ubidotsToken[] = "";        // Enter Your Ubidots Token String From Ubidots


Next, Fill the SSID and Password of your Wifi-Router in respective fields. NodeMCU will use this WiFi to connect to the internet:

const char *ssid = "";           // Your Wifi Username
const char *password = "";       // Your Wifi Password


Fill the URL and port for you MQTT broker. There are several ways to get your MQTT broker:

  1. Download and locally run your own MQTT broker offline from - https://mosquitto.org/download/
  2. Create a private instance of Cloud MQTT Broker. E.g- HiveMQ.
  3. For testing you can also use a free public MQTT broker. E.g- https://www.hivemq.com/public-mqtt-broker/

Currently for testing purposes we are using the free public MQTT broker by HiveMQ.

const char *mqtt_broker = "broker.hivemq.com";    // MQTT Broker URL
const int mqtt_port = 1883;           // MQTT Port


Now, macTopic and statusTopic are distinct strings that uniquely identify the MQTT topic for receiving and sending data. You can enter any two distinct strings of your choice. On public MQTT broker use random string to avoid clash of MQTT topic with other MQTT users.

const char *macTopic = "";       // MQTT topic for subscribing to mac address list
const char *statusTopic = "";    // MQTT topic to publish rssi of nearby devices


To learn more about MQTT protocol visit: https://mqtt.org/

Finally, Upload the updated code to ESP8266 via a Micro-USB Cable.

Backend Setup

The Backend API Services are coded in Node JS. To run the backend server make sure you have node installed.

If you are inside WifiProximity Directory, First Navigate to root directory of the project using:

cd ..


Navigate to the Backend directory :

cd Backend/


Fill the following values inside index.js file in backend folder. Make sure that all values are exactly same as values inside WifiProximity.ino file filled in previous step.

const macTopic = '';             // MQTT topic for subscribing to mac address list
const statusTopic = ''; // MQTT topic to publish rssi of nearby devices
const mqttHost = ''; // MQTT Broker URL
const mqttPort = ''; // MQTT Port


Run the following command inside Backend Folder to install all the backend dependencies:

npm install


To start the backend server, run :

npm start

After running the above command, the console should output if the server was started successfully at port:

Server started at port 4000

This will start the backend server at http://localhost:4000.

Frontend Setup

2023-04-04 (2).png
Screenshot (52).png

The frontend for this project is coded in React JS. To run the code, make sure you have Node Package Manager (npm) installed.

If you are inside Backend Directory, First Navigate to root directory of the project using:

cd ..


Now, Navigate to the Frontend directory :

cd Frontend/


Run the following command inside Frontend Folder to install all the frontend dependencies:

npm install --legacy-peer-deps


Now, Depending on your requirements, you either can run:

npm start


This runs the app in the development mode. Open http://localhost:3000 to view it in your browser. The page will reload when you make changes. You may also see any lint errors in the console. Or you can also run:


npm run build


This builds the app for production to the build folder. It correctly bundles React in production mode and optimizes the build for the best performance. The build is minified and the filenames include the hashes. Your app is ready to be deployed! See the section about deployment for more information.

Working

Screenshot 2023-04-17 193822.png
Picture1.png
  • ESP 8266 takes a list of mac address from backend for proximity detection.
  • It runs the Wifi Proximity Detection algorithm by Ricardo Oliveria using Wifi Promiscuous mode to check which devices are present in proximity of ESP 8266 device. Video Explanation - https://youtu.be/30Eww40s9D0
  • It sends the rssi value of all the device within proximity to Backend server as well as Ubidots dashboard.
  • We can add mac address of any new device for proximity detection from our react frontend.
  • React Frontend also shows a list of last-seen time and best RSSI value of all devices that are being tracked.
  • Ubidots Dashboard shows a live graph of device status for each mac address in our list.


RGB Led Modes:

  • Blue Indicates that ESP 8266 is running Proximity Detection Algorithm
  • Green indicates atleast one device from give mac-address list is present in proximity.
  • Red indicates that ESP 8266 is either connecting to Wifi or sending/receiving data from Ubidots/Backend.


Notes:

  • Any change in device status will take a couple minutes to reflect on Ubidots dashboard and React Frontend.
  • Also note that device must be sending some network packets for Proximity detection by ESP 8266.
  • It is not necessary for device and ESP 8266 to be on same network for proximity detection.
  • Turn off Private Wifi-Address or mac-address randomization in device to ensure that its mac address doesn't change.