Smart Beverage Management

by matsverbeke in Circuits > Raspberry Pi

77 Views, 1 Favorites, 0 Comments

Smart Beverage Management

poster.png

Hello,


On this page, you will find all the information about my Smart Beverage Management project. In my youth movement, we have a bar where you can buy a drink. The problem is that this is anything but efficient and involves a lot of unnecessary work. That's why I created this project. All the information to create this project yourself can be found here.

The idea of my project is that you can take a drink from the fridge that you would like to enjoy. Then, you simply scan your personal badge and the drink. Everything else is automatic, allowing you to enjoy your drink without worrying about anything else. All the data is stored in a database and displayed on the website.


My Github Repository: https://github.com/howest-mct/2023-2024-projectone-mct-mats-verbeke

Supplies

Microcontroller:

  • Raspberry Pi 4


Sensors and modules

Sensors:

  • RC522 RFID Module

This module is designed for reading and writing RFID tags and utilizes the MFRC522 IC, capable of

communication with SPI, I2C and UART interfaces. It is primarily used in attendance systems and various

identification applications for people and objects. In my project, it serves as an identification system.

Datasheet

  • GM805-S Barcode Scanner

This module is a barcode scanner for efficient and accurate reading capabilities. The GM805-S can quickly decode

various barcode types including 1D and 2D, QR codes and more. It is most used in inventory management and

other applications requiring barcode identification. In my project, it is utilized for scanning the barcodes of various

beverages.

Datasheet


  • MC-38 Magnetic contact switch sensor

This is a magnetic sensor commonly used to detect the opening and closing of doors and windows. It consists of a

reed switch and a magnet. When the magnet is close to the sensor, the reed switch is activated, indicating that the

door is closed. When the magnet moves away, it is deactivated, indicating that the door is open. In my project, it

is utilized to monitor whether the refrigerator is open or closed.

Datasheet


Actuators:

  • 2.4 inch SSD1309 OLED Display

This OLED Display is a compact module with a bright and high resolution OLED screen driven by the SSD1309

controller. This controller enables the display to render clear and sharp text and images. OLED technology

ensures each pixel emits its own light. The display typically communicates with microcontrollers via I2C or SPI

protocols. In my project, it is utilized to clarify events and provide visual feedback to users.

Datasheet


  • WS2815 Neopixel LED

This is a versatile RGB LED that incorporates the WS2815 control IC, allowing for individually addressable colors.

With the integrated control, this LED provides vibrant and customizable lighting effects. It can easily controlled

using a microcontroller. In my project, this led serves as a visual indicator adding interactivity.

Datasheet


  • AC-1205G-LF Passive Buzzer

This is a simple sound-producing component that generates audible tones when an electrical signal is applied.

Unlike active buzzers, passive buzzers require an external oscillating signal to produce sound. This buzzer is

compact and simple to use making it suitable for various applications such as alarms, notifications or alerts.

In my project, it serves as an auditory indicator, providing alerts to users based on events.

Datasheet

Connecting All the Electronics

breadboard project.png
schema project.png
barcodescanner test.png
display test.png
rfid test.png
neopixel led test.png

For my project I made two Fritzing circuits, a breadboard and a schematic. On this circuits you can see how all the electronics should be connected.You can also see some pictures from test circuits with the senors and the Raspberry Pi.

Setting Up the Raspberry Pi

For this project we use a Raspberry Pi to control everything.

This means the backend, frontend and the database.

I used Visual Studio Code to run all of my code.


Follow these steps to setup the Raspberry Pi:

Install Raspbian

Download raspbian via these link.


Make connection with your Raspberry Pi

Make connection with your Raspberry Pi.

You can follow the steps via these link.


Creating the Database

database EER.png

All of the sensor data and user data is stored in a MySQL database.

My database consists out of 5 tables:


Device

  • DeviceID: ID of the device
  • Name: Name of the device
  • Type: Type of the device (sensor or actuator)
  • Description: Extra information about the device
  • Price: Price of the device


Meting

  • MetingID: ID of a measurement
  • DeviceID: ID from the Device of the measurement
  • MetingDatum: Date of the measurement
  • Waarde: Value of the measurement
  • Commentaar: Extra information about the measurement

User

  • UserID: ID of the user
  • Firstname: Firstname of the user
  • Lastname: Lastname of the user
  • Email: Email of the user
  • Password: Password of the user
  • Admin: If the user is a admin or not
  • LastPayment: Last Payment of the user
  • RFID: RFID ID of the users badge


Drink

  • DrindID: ID of a drink
  • Name: The name of the drink
  • Price: The price of the drink
  • Stock: The supply of the drink
  • Barcode: The barcode of the drink


User_Drink

  • UserDrinkID: The ID of the UserDrink join
  • UserID: ID of the User
  • DrinkID: ID of the drink
  • Aantal: amount of drinks

Setting Up the Backend

App.py:

This is the main backend code of the project. All sensor programs are controlled from here.

The app.py also contains the routes being used to retrieve data from the Database.


DataRepository.py:

Here are the SQL queries to get, change or delete data from the database.


Database.py:

This is to execute and read the database.


Config.py:

This is the configuration to connect with the Database


Setting Up the Frontend

dashboard.png
users.png
stock.png

The frontend consists out of all the HTML files, the SCC files for de styling and the javascript files.


Login.html:

This is the login page of the site


Dashboard.html:

Here you can find all the information of the sensors


Users.html:

Here you can find all the users. You can add, change or delete users.


Drinks.html:

Here you can find all the different drinks. You can add, change or delete drinks.


App.js:


Here you can find all the javascript code to communicate information from the webserver with the backend.


Creating the Casing

case.png
zijaanzicht.jpg
bovenaanzicht.jpg

Casing:

I have 3D printed a two-part enclosure with the necessary holes to neatly and compactly integrate all components in my housing. I've accomplished this using a resin 3D printer, as it was available to met at home. Hower, the same can be achieved with other types of 3D printers. The lid of the housing is secured using screws positioned at the four corners.