A web platform and hardware solution for automated cocktail mixing machines.
RobotCocktail is a modern reimagining of the Autobar v1 project. While the original project used Django and Raspberry Pi, this new version brings several key improvements:
The project consists of two main parts:
Web Platform
Hardware Implementation
Using the Devices page, use "Flash New Device" and then "Enroll via WiFi" for instructions. You should obtain a page as below.
If you have docker installed, you might prefer to run the project for a quick demo by using:
docker build -t autobar3 .
docker run --rm -it autobar3
The admin authentification is in .env.example
. You may change the values before building the image.
First, generate SSL certificates for local development:
./scripts/generate_dev_certificates.sh
This script generates:
These certificates are for development only and should not be used in production
The firmware is built locally into the static/firmware
folder so that user may flash their device the first time via the webpage.
The following dependencies are required
sudo apt-get install git wget flex bison gperf python3 python3-pip python3-venv cmake ninja-build ccache libffi-dev libssl-dev dfu-util libusb-1.0-0
Install the ESP-IDF plugin and configure the extension. Version v5.3.2 is the only one tested for now.
The CMakeLists.txt
includes commands to copy the firmware binaries to the static folder.
(TODO) VS Code devcontainer or pure docker command
Install dependencies and start the development server:
npm install
npm run dev
The development server will run with HTTPS using the generated self-signed certificates.
Note: For production deployment, replace the development certificates with proper SSL certificates from a trusted Certificate Authority.
Please see CONTRIBUTING.md for development guidelines and contribution process.
This project is licensed under the MIT License - see the LICENSE file for details.