No description https://chat.jusemon.com/
Find a file
2025-03-24 13:45:52 -05:00
.vscode Feature/Use fastify instead of express (#1) 2025-03-06 19:15:56 -05:00
apps refactor: enhance room resolvers with authentication 2025-03-24 13:45:52 -05:00
packages Feature/Use fastify instead of express (#1) 2025-03-06 19:15:56 -05:00
.dockerignore feat: improve authentication and cookie management 2025-03-10 00:41:39 -05:00
.gitignore Feature/Use fastify instead of express (#1) 2025-03-06 19:15:56 -05:00
.npmrc feat(create-turbo): create basic 2025-03-03 22:46:02 -05:00
docker-compose.yml feat: improve authentication and cookie management 2025-03-10 00:41:39 -05:00
LICENSE refactor: migrate from Next.js to SolidJS and GraphQL 2025-03-04 01:08:52 -05:00
package-lock.json chore: add Keyv package for improved caching and key-value storage 2025-03-10 09:10:17 -05:00
package.json chore: update environment configuration and deployment scripts 2025-03-06 23:08:10 -05:00
README.md refactor: migrate from Next.js to SolidJS and GraphQL 2025-03-04 01:08:52 -05:00
turbo.json feat: improve authentication and cookie management 2025-03-10 00:41:39 -05:00

Unreal Chat

A real-time chat application built with SolidJS, GraphQL, and Prisma.

Project Structure

This is a monorepo containing the following packages:

  • apps/api: GraphQL API server built with Apollo Server, GraphQL, and Prisma
  • apps/web: Web client built with SolidJS and URQL GraphQL client

Features

  • Real-time chat with GraphQL subscriptions
  • User authentication
  • Chat room management
  • Message sending and receiving
  • Public and private chat rooms

Getting Started

Prerequisites

  • Node.js (v18 or later)
  • npm (v10 or later)
  • MariaDB or MySQL

Installation

  1. Clone the repository:
git clone https://github.com/yourusername/unreal-chat.git
cd unreal-chat
  1. Install dependencies:
npm install
  1. Set up environment variables:

Create a .env file in the apps/api directory:

DATABASE_URL="mysql://root:password@localhost:3306/unreal_chat"
JWT_SECRET="your-secret-key"

Create a .env file in the apps/web directory:

VITE_API_URL=http://localhost:4000/graphql
VITE_WS_URL=ws://localhost:4000/graphql
  1. Initialize the database:
npm run prisma:init
  1. Start the development servers:
# Start both API and web servers
npm run dev

# Or start them individually
npm run api:dev
npm run web:dev

The API will be available at http://localhost:4000/graphql and the web app at http://localhost:5173.

Available Scripts

  • npm run dev - Start all development servers
  • npm run api:dev - Start the API development server
  • npm run web:dev - Start the web development server
  • npm run build - Build all packages
  • npm run api:build - Build the API
  • npm run web:build - Build the web app
  • npm run prisma:generate - Generate Prisma client
  • npm run prisma:migrate - Run Prisma migrations
  • npm run prisma:studio - Open Prisma Studio

Technologies

Backend (API)

  • Apollo Server
  • GraphQL
  • Prisma ORM
  • MariaDB
  • JSON Web Tokens (JWT)

Frontend (Web)

  • SolidJS
  • URQL GraphQL Client
  • GraphQL Subscriptions
  • CSS

License

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