go_rooms

command module
v0.0.0-...-52e83fb Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Nov 29, 2024 License: MIT Imports: 8 Imported by: 0

README

Go Rooms

Go Rooms is a backend application written in Golang. It aims to create WebSocket rooms for users to communicate in real-time.

Requirements

  • Golang 1.22.2 or later
  • MySQL 8.0 or later
  • Redis 7.0 or later

Getting Started

  1. Clone the Repository
    git clone https://github.com/your-username/go-rooms.git
    cd go-rooms
    
  2. Run the Application
    go run main.go

Features

  • Create and Login Users.
  • Authentication and Authorization.
  • Real-time Server communication with Front-End.

To-Do

Core Functionality
  • Set up basic RESTful API server
  • Create and authenticate Users
  • Create and authenticate Hosts
  • Ability to create new rooms by Users
  • Implement unique room identifiers and codes
Error Handling
  • Log server-side errors for debugging
  • Handle API errors gracefully
  • Return meaningful error messages to users
  • Handle unexpected WebSocket closures
Security
  • Validate incoming messages and data
  • Prevent unauthorized access to User data
  • Add rate-limiting for message frequency
  • Implement basic input sanitization

Real Time Communication

  • Set up basic WebSocket server
  • Create and manage WebSocket rooms
  • Allow users to join and leave rooms
  • Broadcast messages to all users within a room
  • Implement unique room identifiers
User Management
  • Track user connections and disconnections
  • Handle user reconnections gracefully
  • Allow users to send private messages within a room
  • Implement username or ID-based user identification
Optimization
  • Optimize WebSocket performance for multiple rooms
  • Test server with high loads and concurrent connections
  • Minimize memory usage for each room and user connection
Testing
  • Create unit tests for room creation logic
  • Test user connection and disconnection handling
  • Test broadcasting and private messaging functionality
  • Implement integration tests for the entire server flow

Database Modeling

model

License

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

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
database
db

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL