-
Notifications
You must be signed in to change notification settings - Fork 71
Game
- Maintains game state
- Simulates environment events
- Runs player actions
Each game has its own instance of a game container. The game container is responsible for maintaining the game state, the worker avatars for the game, fetching the actions from each worker, and applying the worker.
The game interacts with the rest of the components as follows:
- It is created by the game creator.
- It creates workers and restarts them when a user changes their avatar's code.
- It exposes an API to provide the workers with the code.
- It fetches the game settings from the UI.
Once per turn it will:
- Inform all workers of the current game state and gets their actions.
- Perform conflict resolution on these actions and then apply them.
- Update the world with any other changes (eg move score squares).
Files for the game are stored in aimmo-game
.
The entry point of the micro-service is service.py. The service coordinates several internal components and provides an interface for the UI to communicate with it. The service coordinates the following components:
- Flusk Micro-service - exposes through Socket.IO(more details here) the world state visible by a client
- Worker Manager - the room loop responsible for updating the user's code, user arrival and departure
- Turn Manager - the game loop that pools each worker for an action to execute and the updates the game environment
Worker Manager and Turn Manager are daemons that run in the back-ground asynchronously. The Flusk Micro-service is exposed to the Django service through a reverse proxy(useful link here). The turn manger runs game loop much more frequently than the worker manager updates the room. (the current wait times are 0.5 sec. for turn manager and 10 sec. for worker manger).
The full implementation of this service is found in the service.py. The resource exposed by the service are exposed through Socket.IO. The micro-service receives base link from the creator and runs the service at that link. This link is passed in the environment as 'GAME_API_URL'. This link is exposed to the Kubernetes cluster through a reverse proxy.
Other resources can be added for testing, but they should not be exposed via the reverse proxy. This approach is used in the our integration tests -- yet to be merged #222.
The communication protocol looks something like this:
> server: world_init
> client: client-ready, id
> server: broadcast world-update for each state
> client: filter my updates(i.e. only the ones for my id)
The communication between the 2 sides is carried through the JSON format. The API is detailed inside the WorldState class from the file simulation/world_state.py. A short description of the World State class can be found [here](not yet).