Chatterbox is a lightweight, real-time chat application designed for seamless and reliable communication. Users can easily register, log in, and exchange messages in a secure and efficient environment.
Built using modern technologies, Chatterbox delivers stable performance and real-time functionality while maintaining simplicity and ease of use. Its intuitive design focuses on essential features, ensuring quick deployment and straightforward maintenance, making it an ideal solution for various scenarios.
(Note: ChatterBox is a personal hobby project developed in spare time. It is currently in its early stages, serving as a preliminary version designed for learning and experimentation, with many features still under development.)
- 🌟 Features
- 🛠️ Technologies Used
- 📦 Installation
- 🧑💻 Usage
- 📂 File Structure
- 🚀 Future Enhancements
- 🐞 Known Bugs
- 📜 License
- 🙏 Acknowledgments
- 👤 Author
- 🔒 User Authentication: Secure registration, login, and logout functionality.
- ⚡ Real-Time Messaging: Chat seamlessly with real-time updates.
- 📱 Responsive Design: Optimized for monitors of all sizes.
- 🗂️ Database: Messages and user data are stored in a robust database.
- Backend: Python 3, Flask, SQLAlchemy, Socket.IO, Gunicorn, Eventlet, Jinja2
- Frontend: HTML, JavaScript, CSS, Bootstrap
- Database: SQLite
- Environment: Docker, Bash, Devcontainers
- Python 3.10+
- Docker
Just run the application using:
docker compose up -d
The application will be accessible at http://0.0.0.0:8081.
To stop the application, run docker compose down
.
-
Install Dependencies (First Run Only):
pip install -r requirements.txt
-
Initialize the Database (First Run Only):
python init_db.py
-
Run the Application:
python app.py
The application will be accessible at http://127.0.0.1:5000.
To stop the application, pressCtrl + C
in the terminal running the app.
- Open the project in a development environment that supports Devcontainers (e.g., Visual Studio Code).
- Follow prompts to build and open the container.
- The enviroment will be set up automatically based on the
devcontainer.json
. - Run
python init_db.py
(first run only), and thenpython app.py
.
To stop the application, press Ctrl + C
in the terminal running the app.
- Open the application in your browser.
- Register a new user account.
- Log in using your credentials.
- Start chatting!
chatterbox/
│
├── app.py # Main application logic
├── docker-compose.yaml # Defines container(s) setup
├── Dockerfile # Builds the Docker image
├── entrypoint.sh # Script to initialize the app
├── event_handlers.py # Event handling logic
├── helpers.py # Helper functions and decorators
├── init_db.py # Database initialization script
├── LICENSE # Project license
├── models.py # Database models
├── README.md # Project documentation
├── requirements.txt # Python dependencies
├── .gitignore # Gitignore file
│
├── instance/
│ └── chatterbox.db # SQLite database file
│
├── misc/ # Miscellaneous files
│
├── static/ # Static files
│ ├── favicon.ico # Favicon
│ ├── logo.png # Logo image
│ ├── scripts.js # JavaScript for the website
│ ├── styles.css # CSS for styling
│ └── websocket.js # WebSocket JavaScript
│
├── templates/ # HTML templates
│ ├── author.html # Author information page
│ ├── chat.html # Chat page template
│ ├── home.html # Homepage template
│ ├── layout.html # Base layout template
│ ├── login.html # Login page template
│ └── register.html # Registration page template
│
└── .devcontainer/
└── devcontainer.json # Dev container configuration
- User Profiles: Add user profile pages and the ability to update account details.
- Media Sharing: Add support for files, images, and videos in chats.
- Mobile Optimization: Ensure the chat interface is responsive and works seamlessly on mobile devices.
- Enhanced UI: Improve the design and usability of the chat interface.
- React Front-End (Optional): Migrate the front-end to React for a more dynamic and modern user experience.
- None at the moment. All identified issues have been resolved.
This project is licensed under the MIT License. See the LICENSE file for details.
- Harvard's CS50x course for inspiration and foundational knowledge.
- The Flask and Bootstrap communities for providing excellent documentation and tools.
Filip Rokita
www.filiprokita.com