NeRDDOOR
data:image/s3,"s3://crabby-images/37f15/37f15b3ea99d2e5a8ce96d6964e1ee82b8882ccd" alt="PHOTO-2021-03-04-20-26-43 (2).jpg".jpg)
All files required for the project are available on https://github.com/NeRDAETTUA/NeRDDOOR
For more detailed instructions you can also watch our workshop: https://www.youtube.com/playlist?list=PLARUXQ9f6QR...
Materials Needed
data:image/s3,"s3://crabby-images/8c896/8c896f6f4665618b7ae8c52d6cf43f486293a630" alt="PHOTO-2021-03-04-20-26-43 (1) (1).jpg" (1).jpg)
You will need :
- ESP12-E
- FTDI (to program the ESP12-E)
- Copper board (to print the pcb)
- A way to print a pcb
- A 5V charger with power jack
- 3D printer
- Servo Motor
- RC522 RFID reader
Program the ESP12-E
Change variables like WiFi SSID and Password for your own
Downloads
Print the PCB
data:image/s3,"s3://crabby-images/99bc8/99bc8c46d083a1399c6122e2ff0ca2c2caf18f91" alt="IMG_20201022_232759 (3).jpg".jpg)
Print the Door Package
Assemble!
data:image/s3,"s3://crabby-images/08519/085190344ef39080d07cb7867fbfd9bc2b5e3b01" alt="IMG_20201030_191334 (2).jpg".jpg)
data:image/s3,"s3://crabby-images/b6657/b6657b64f0b80d0c77f9045e5dd0bd2ccff8706b" alt="IMG_20201030_191312 (2).png".png)
Install a MQTT Server With Node-RED and a SQL Database
To install mqtt:
- sudo apt-get install mosquitto mosquitto-clients
To install MariaDB:
- sudo apt-get install mariadb-server
To configure MariaDB:
- sudo mysql_secure_installation
To install Node-RED:
- sudo apt-get install curl software-properties-common
- curl -sL https://deb.nodesource.com/setup_14.x | sudo bash -
- sudo apt-get install nodejs npm
- sudo npm install -g --unsafe-perm node-red
- sudo npm install -g pm2
- pm2 start /usr/bin/node-red
- pm2 save
- pm2 startup
- Copy/Paste the command printed out by pm2
Create a User on MQTT for the Door ESP
To create a user on MQTT:
- sudo mosquitto_passwd -c /etc/mosquitto/passwd user (substitute user by the username pretended)
- insert the password you want
Disable anonymous logins:
- sudo nano /etc/mosquitto/conf.d/default.conf
- Write "allow_anonymous false
password_file /etc/mosquitto/passwd"
Restart MQTT:
- sudo systemctl restart mosquitto
Create the Database and Tables for the Door
To enter the MariaDB Database:
- sudo mysql -u root -P
To create the Database and Tables for the door:
- CREATE DATABASE users_rfid;
- USE users_rfid;
- CREATE TABLE rfid(id int(8) AUTO_INCREMENT PRIMARY KEY NOT NULL, name TINYTEXT NOT NULL, rfid TINYTEXT NOT NULL);
To create a user for Node-RED:
- CREATE USER 'nerddoor'@'localhost' IDENTIFIED BY 'pwd'; (insert the password instead of pwd)
- GRANT ALL PRIVILEGES ON users_rfid.rfid TO 'nerddoor'@'localhost';
- FLUSH PRIVILEGES;
Install SQL Add-on to Node-RED
data:image/s3,"s3://crabby-images/db02d/db02d2d545d4bdc4d939fab2b6a38eff7396862c" alt="installsql1.png"
data:image/s3,"s3://crabby-images/d1ca3/d1ca3d7300dea5f575055ec94ea2590f45c0e46a" alt="installsql2.png"
Go to menu > Manage palette > Install, search for sql and install the add-on "node-red-node-mysql"
Create and Configure the Flows
data:image/s3,"s3://crabby-images/1a51b/1a51b9db83825c52b0d2437b983e9d7edc4fa17c" alt="Flow.png"
data:image/s3,"s3://crabby-images/fa0ea/fa0eaa4617b09da93e77db17e85334a6cbfc50a0" alt="config.png"
data:image/s3,"s3://crabby-images/c18fa/c18faf5c165b75cd36e0c33c98ad1d2cc43ffe79" alt="function1.png"
data:image/s3,"s3://crabby-images/65f2c/65f2c8239e02990eceba89dfd4f2c0a7cc4c7a6d" alt="function2.png"
data:image/s3,"s3://crabby-images/e9294/e9294ff8a0ae22fb602a9a82df986cb1e0bc9df8" alt="mqtt out.png"
data:image/s3,"s3://crabby-images/128b4/128b47cf55bad83c1b9a2a1957ac355b5992e5e0" alt="Rfid in.png"
data:image/s3,"s3://crabby-images/04ea5/04ea517fb72c5dd45f50f24ef9301a08f19502a3" alt="sql config.png"
data:image/s3,"s3://crabby-images/c9e57/c9e57378182d1382bc858d228a6b4f0b8ad4924e" alt="switch.png"
Configure as shown on the pictures