A bot designed to help manage parties and prevent organizers from going into the red.
This bot is written in Python using the python-telegram-bot
library.
It offers a simple interface with buttons and a few commands.
Key features include:
- Ordering drinks, viewing the menu, and checking order statuses.
- Role-based access levels: Administrator, Bartender, and Customer.
- SQLite3 database integration.
- Open the Telegram app and search for
@BotFather
. - Start a chat with
@BotFather
by clicking the "Start" button. - Use the command
/newbot
to create a new bot. - Follow the instructions to choose a name and username for your bot.
- After successfully creating the bot,
@BotFather
will provide you with a token. This token is required to authenticate your bot and should be kept secure.
Example of the token provided by @BotFather
:
123456789:ABCdefGhIJKlmNoPQRstuVWXyz
Save this token as you will need it to configure your bot in the next steps.
Note: The token is sensitive information and should not be shared publicly.
First, you need to get repository on your local machine. You can do it by cloning the repository or downloading the zip file.
# Clone the repository
# Install Git from https://git-scm.com/downloads if you haven't already.
git clone git@github.com:NikitosKey/alcounting_bot.git
cd alcounting_bot
And get a token from the @BotFather
in Telegram.
TODO: Add the instruction how to get the token.
# Install Python 3.13 if you haven't already.
# Visit https://www.python.org/downloads/ to download the latest version of Python.
# Or use your package manager to install it:
# Ubuntu
sudo apt-get install python3.13
# macOS
# Install Homebrew from https://brew.sh/ if you haven't already.
brew install python3.13
# Windows
# Install Chocolatey from https://chocolatey.org/ if you haven't already.
choco install python3.13
# Install SQLite3 if you haven't already from https://www.sqlite.org/download.html or use your package manager:
# Ubuntu
sudo apt-get install sqlite3
# macOS
brew install sqlite3
# Windows
choco install sqlite3
# Install Poetry
# install pip if you haven't already from https://pip.pypa.io/en/stable/installation/.
pip install poetry
# This is sufficient to install dependencies, but for contributions,
# it's recommended to visit https://python-poetry.org/docs/ and follow their setup instructions.
# Install dependencies using Poetry (recommended for contributors)
poetry install
# Install dependencies using pip (alternative to Poetry)
# Create a virtual environment
python3.13 -m venv venv
# Activate the virtual environment
source venv/bin/activate
pip install -r requirements.txt
# Create an environment variable BOT_TOKEN and set it to your bot's token.
export BOT_TOKEN=your_token
# Run the bot
poetry run python -m bot.__main__
# For convenience, you can use screen or tmux to keep the bot running in the background:
# Using screen
screen -S alcounting_bot
poetry run python -m bot.__main__
# Using tmux
tmux new -s alcounting_bot
poetry run python -m bot.__main__
That's it!
The bot will now run in the background, processing user requests.
To stop the bot, press Ctrl+C
.
Firstly, you need to create .env
file. You can find example in .env.example
.
# Install Docker and Docker Compose from https://docs.docker.com/get-docker/ and https://docs.docker.com/compose/install/ if you haven't already.
docker-compose up --build
To host the bot remotely instead of running it locally, you'll need to set up a hosting environment.
- Open the Telegram app.
- Search for your bot by its username.
- Start a chat with the bot by clicking the "Start" button.
After receiving /start
bot creates a database and sends a welcome message and your automatically get the role of the
customer.
To use all the features of the bot, you need to change your role to administrator. To do this your need to install the SQLite browser and change the role in the database.
The bot supports the following commands:
/start
- restart the bot./help
- Display the help message./menu
- Display the menu.
Menu consists of the following buttons:
TODO: Add the photos and the description of the buttons.
bot/
- Bot folderhandlers/
- Command handlersdatabase/
- Database interactionsusers/
- User management__main__.py
- Bot entry point
data/
- Folder for the databaselogs/
- Folder for logsres/
- Folder for resourcesstartup_script/
- Scripts for starting the bottests/
- Folder for tests.gitignore
- Ignored filespoetry.lock
- Poetry dependency lock filepyproject.toml
- Poetry project configuration filerequirements.txt
- Dependencies for pipREADME.md
- Project description
Basic functionalities:
- View the menu
- Place orders
- View their own orders
- Statistics
Includes all Customer functionalities plus:
- View the order queue
- Confirm orders
Includes all Bartender functionalities plus:
- Assign roles (Customer or Bartender)
- View logs
- Access various statistics
- Modify and edit the database
- Manage users
The database is located in data/database.db
(git-ignored to prevent user data leaks) and is stored locally on the host.
It uses SQLite and is managed through the database.py
file.
The database contains the following tables:
- Users: Tracks user information and roles.
- Menu: Contains bar items and pricing.
- Orders: Tracks customer orders (used to generate the bartender's queue).
Table structure:
- Order number (optional; currently using date and time instead)
- Product name (from the menu)
- Customer ID
- Bartender ID
- Order status
- Status change timestamps (optional, as there are only two statuses for now)
Table structure:
- Item name
- Description
- Price
- Tags (optional, for categorization if the menu becomes too large)
Table structure:
- User ID
- Username
- Access level (role)
- ...
This feature will be implemented later. It is expected to include:
- Creating parties
- Inviting users
- Managing access to parties
- Joining an existing party
You can contribute to this project by creating a pull request or opening an issue. Also you can fork this repository and make your own version of the bot.
All contributions are welcome!