Skip to content

Latest commit

 

History

History
111 lines (82 loc) · 2.77 KB

README.md

File metadata and controls

111 lines (82 loc) · 2.77 KB

Virtual Worlds Racing Discord Bot

A Discord bot designed to manage Zwift racing communities, providing registration, club management, and team organization features.

🚴 Features

Rider Management

  • Registration System
    • Secure rider registration with Zwift ID verification
    • Terms of Service and Privacy Policy acceptance
    • Duplicate registration prevention
    • Profile linking with ZwiftPower and ZwiftRacing

Club Management

  • Create and manage cycling clubs
  • Link clubs with Zwift Power teams
  • Manage club administrators
  • Active/Inactive status tracking
  • Team organization within clubs

Team Management

  • Create and organize teams within clubs
  • Team administrator management
  • Active status tracking

🛠️ Technical Stack

  • Discord API: discord.py (pycord)
  • Database: MongoDB with Beanie ODM
  • Logging: Logfire
  • Configuration: Environment variables via python-dotenv

📋 Prerequisites

  • Python 3.8+
  • MongoDB
  • Discord Bot Token
  • Zwift Power API access (optional)

⚙️ Installation

  1. Clone the repository:
git clone https://github.com/vincentdavis/Virtual_Worlds_Racing_discord.git
cd Virtual_Worlds_Racing_discord
  1. Install dependencies:
uv sync --frozen
  1. Create a .env file:
cp .env.example .env

🚀 Usage

Starting the Bot

uv run main.py

Available Commands

Rider Commands

  • /register - Register as a new rider
  • /lookup <user> - Look up rider information

Club Commands

  • /create_club <name> [zp_club_id] - Create a new club
  • /add_team <club_name> <team_name> - Add a team to a club
  • /remove_team <club_name> <team_name> - Remove a team from a club
  • /add_admin <club_name> <admin_discord_id> - Add an admin to a club
  • /remove_admin <club_name> <admin_discord_id> - Remove an admin from a club
  • /mark_inactive <club_name> - Mark a club as inactive
  • /mark_active <club_name> - Mark a club as active

🔒 Security

  • Discord ID verification
  • Terms of Service acceptance required
  • Duplicate registration prevention
  • Admin-only actions for sensitive operations

🤝 Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

📝 License

This project is licensed under the MIT License - see the LICENSE file for details.

🙏 Acknowledgments

  • Discord.py community
  • Zwift Power API
  • MongoDB team
  • All contributors and testers

📞 Support

For support, please join our Discord server or open an issue in the GitHub repository.


Made with ❤️ for the Zwift racing community