- Notifications
You must be signed in to change notification settings - Fork33
Online multiplayer chess built with Next.js, Express, & socket.io
License
dotnize/chessu
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
Yet another Chess web app.
- play against other users in real-time
- spectate and chat in ongoing games with other users
- optional user accounts for tracking stats and game history
play solo against Stockfish(wip)- mobile-friendly
- ... and more (view roadmap)
Built with Next.js 14, Tailwind CSS + daisyUI, react-chessboard, chess.js, Express.js, socket.io and PostgreSQL.
Node.js 20 or newer is recommended.
This project is structured as a monorepo usingpnpm workspaces, separated into three packages:
client
- Next.js application for the front-end,deployed to ches.su via Vercel.server
- Node/Express.js application for the back-end,deployed to server.ches.su via Railway.types
- Shared type definitions required by the client and server.
- Installpnpm.
- Install the necessary dependencies by running
pnpm install
in the root directory of the project. - In the
server
directory, create a.env
file for your PostgreSQL database. You can tryElephantSQL orAiven for a free hosted database.PGHOST=db.example.comPGUSER=exampleuserPGPASSWORD=examplepasswordPGDATABASE=chessu
- Run the development servers with
pnpm dev
.- To run the frontend and backend servers separately, use
pnpm dev:client
andpnpm dev:server
, respectively.
- To run the frontend and backend servers separately, use
- You can now access the frontend athttp://localhost:3000 and the backend athttp://localhost:3001.
To build the project with Docker, you can use the providedDockerfile
.
docker build -t chessu.
This command will build the Docker image with the namechessu
. You can then run the image with the following command:
docker run -p 3000:3000 -p 3001:3001 chessu
Once built, to start the project with POSTGRES, you can use the provideddocker-compose.yml
file.
docker-compose up
Please make sure to modify the values in theserver/.env
file to match the values in thedocker-compose.yml
file or vice versa.
The entrypoint for the Docker image is set to run pnpm.The Dockerfile'sCMD
instruction is set to run the project in production mode.If you want to run the project in development mode, you can override theCMD
instruction by running the following command:
docker run -p 3000:3000 -p 3001:3001 chessu dev# runs both client and server in development modedocker run -p 3000:3000 -p 3001:3001 chessu dev:client# runs only the client in development modedocker run -p 3000:3000 -p 3001:3001 chessu dev:server# runs only the server in development mode
Please read ourContributing Guidelines before starting a pull request.
About
Online multiplayer chess built with Next.js, Express, & socket.io