2.4 KiB
2.4 KiB
Remote Snake API
General Description
-
All transmissions will be based on TCP because:
- Packet length are not fixed
- Packet ordering is important
-
All TCP stream from client to server will:
- Contain plain json data
- Be terminated by a "#EOF" line (in order for the server to detect the end of the request
- All TCP stream from server to client will contains plai json data (connection will be closed by the server so there is no need of "#EOF".
Communications
Initialisation
- Server wait for a client
-
Client can send:
{ "type": "new-game" } #EOF
-
Server can reply:
{ "type": "state", "game-id": 1, "game-over": false, "snake": [[1,2],[1,3]], "food": [[6,7]] }
Gameplay
Change Direction
-
When client is playing a game it can ask to the server to change snake direction:
{ "type": "update", "game-id": 1, "direction": "left", } #EOF
-
Server can reply
{ "type": "state", "game-id": 1, "game-over": false, "snake": [[0,2],[1,2]], "food": [[6,7]] }
Refresh Screen
-
When no key are press (the snake is simply going straigth forward). So, client can send:
{ "type": "update", "game-id": 1, "direction": null } #EOF
-
Server can reply:
{ "type": "state", "game-id": 1, "game-over": false, "snake": [[1,2],[0,2]], "food": [[6,7]] }
End Game
-
When game is over server will send the following state message (switch game-over to true):
{ "type": "state", "game-id": 1, "game-over": true, "snake": [[0,2],[1,2]], "food": [[6,7]] }
- No reply is expected from the client and server will be in charge to free local memory.