Solaris is a slow-burn browser game heavily inspired by Neptune's Pride and Subterfuge.
- Build economic, industrial and scientific infrastructure to improve your empire.
- Build carriers to travel to new stars or to fight your enemies.
- Research new technologies to gain an edge over your opponents.
- Hire specialists which grant special abilities to stars and carriers like increased weapons and speed.
- Set up trade with your allies to get ahead of the curve.
- Play games with up to 32 players at a time.
- Participate in group chats with your allies to discuss strategy.
- Fight other players and capture stars to win the game.
- Games last around 2-3 weeks, and you don't need to commit a lot of time to play!
- Play on any device that has a web browser.
- Its completely free!
Visit solaris.games to play now!
The server uses the following tech:
The client uses the following tech:
- Install the prerequisites.
- Clone the repository.
- Checkout
master
. npm install
in bothclient/
andserver/
directories.- Create a
.env
file inserver/
(See.env.example
). - Create a
.env
file inclient/
(See.env.example
). npm run start-jobs:dev
inserver/
to start the automated jobs and setup new games.npm run start-api:dev
inserver/
to start the API.npm run dev
inclient/
to start the client application.- Browse to the site locally (default http://localhost:8080).
Note: Development work is to be based on the dev
branch, for a new feature or bug fix, create a branch from dev
.
To keep up to date with the latest changes, you must run the database migations to ensure that your database is compatible.
npm run start-db-migrate:dev
inserver/
to update your local database to the latest schema.
Note: This script assumes that you have a solaris
database on your system. If not, perform the Development Environment Setup above first.
To automate the development environment, it is recommended to use PM2.
- Install
pm2
. pm2 start pm2.config.js
to registerpm2
apps.
The above script will create the server jobs, API and client applications, watch for changes and restart those applications when necessary.
You can make use of debugger attach for VS Code defined in the .vscode/launch.json
configuration file to easily attach the debugger to running apps.
Once configured, you can browse to the site locally (default http://localhost:8080) as using the normal way detailed in the section above and any changes you make will automatically restart the applications.
- Install Docker.
- Create a
.env
file inserver/
(See.env.example
). - Create a
.env
file inclient/
(See.env.example
). - Run
docker compose up
in the project folder - Browse to the site locally (default http://localhost:8080).
See here.
See here.