Related links:
- The javascript client repo: https://github.com/WarCluster/warcluster-site
- Amazingly strong NodeJS AI player with fuzzy logic (written at 2 day hackathon) here: https://github.com/lepovica/WarCluster-AI ლ(ಠ益ಠლ)
- The awesome UI designer @Denitsa that also made the art of the game: https://www.behance.net/gallery/26279733/War-Cluster
- The team behind this project: humans.txt
What can you expect to see in this ~3-year old repo:
- Go and WebSockets :D
- Go and Redis =D
- Go and tests \(^O^)/
- Voronoi diagram! ... wait, wut?
long story short: We wanted to learn something new ♪┏(・o・)┛♪┗ ( ・o・) ┓♪, experiment with the unthinkable & foresee the unimaginable. So we decided to make a web-fuckin-browser MMO as a side-project... It must had breathtaking tactics, large scale strategizing, thoughtful meta gameplay & dangerously social diplomacy. This is how WarCluster was born as the first social game for twitter! It was greatly inspired by other games
It has 6 different races. Each race has it's own unique color.
Each color corresponds to unique twitter #hashtag used for race wide communication (eg. #WarClusterRed). There're only verbal alliences between players.
The game is time based. Each round is approximately 10 days. The player with the most controlled planets (i.e. biggest empire) at the end of the round is proclaimed winner and therefore Galactic Emperor (here's one of the Beta winners @valexiev)
Each player starts with a solar system consisting of 9 neutral planets. His home planet (the one with the asteroid belt) is impregnable. Typically each colonized planet has owner and generates for him army pilots per minute. The bigger the planet the more it generates.
At some point the army can grow bigger than the allowed population of the planet. So when the numbers get red bad things start to happen and army pilots are beginnig to die by the minute. Different sizes of planets have different population caps.
A player can send army pilots to attack, spy or support other planets depending on their verbal agreements with its owner. The spaceships travel slow so moves are carefully plotted. Imagine it as a real time game of Go :
- Upon attacking a player conquers a planet if his attacking army is
> 1
than the other army. Everything is lost otherwise. - Upon spying a player gets the number of the army on the targeted planet.
- Upon supporting a player is donating his army to the planet's owner.
A player should spend extra effort to pick his enemies wiser and his allies patiently. Plot twists are around every hour.
There're different kind of ships indicating the size of the army. From left (smallest army, no more than 500 pilots) to right (biggest army, more than 6000 pilots). This is used to understand what's the expected army power that's approaching you.
prerequisites:
- Redis, so you have to install it and run the server
(
redis-server
is the most lazy way) - Go. Install version 1.3 or higher. Decide which
directory is going to be your go workspace directory, set
__$GOPATH__
to it and createsrc/
directory inside.
It's a good idea to place these two export commands somewhere in your .bashrc file, though. Otherwise you would have to execute them on each re-login in your system. Now it's time to fetch warcluster and install its requirements.
$ git clone [email protected]:WarCluster/warcluster-server.git $GOPATH/src/warcluster
$ cd $GOPATH/src/warcluster/
$ go get -v github.com/stretchr/testify
$ go get -v
Add your twitter consumer/secret keys here in order to have working social twitter login.
If you run redis on your localhost without any custom configuration and you're
okay with the game running on port 7000, then you should be able to run the
server without any modifications. Otherwise, copy config/config.gcfg.default
to config/config.gcfg
and make your changes.
Just to be sure, everything is set up propery run the tests:
$ go test ./...
If you see no errors, then Hurray! Let's actually compile server:
$ go install
If this command runs without errors you should have a bin/
directory in your
$GOPATH
and now you can run it:
$ warcluster
Fork it ( • ∀•)–Ψ and make required changes. After that push your changes in branch, which is named according to the changes you did. Initiate the PR (づ ̄ ³ ̄)づ