remote-snake/doc/api.org

88 lines
2.4 KiB
Org Mode
Raw Normal View History

2019-05-07 18:27:20 +02:00
#+TITLE: Remote Snake API
#+OPTIONS: toc:nil
#+LATEX_HEADER: \usepackage{fullpage}
* General Description
2019-05-10 08:51:16 +02:00
- 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".
2019-05-07 18:27:20 +02:00
* Communications
** Initialisation
1. Server wait for a client
2. Client can send:
#+BEGIN_SRC json
{
"type": "new-game"
}
2019-05-10 08:51:16 +02:00
#EOF
2019-05-07 18:27:20 +02:00
#+END_SRC
3. Server can reply:
#+BEGIN_SRC json
{
"type": "state",
"game-id": 1,
"game-over": false,
2019-05-09 18:38:31 +02:00
"snake": [[1,2],[1,3]],
"food": [[6,7]]
2019-05-07 18:27:20 +02:00
}
#+END_SRC
** Gameplay
*** Change Direction
1. When client is playing a game it can ask to the server to change snake direction:
#+BEGIN_SRC json
{
"type": "update",
2019-05-07 18:29:32 +02:00
"game-id": 1,
2019-05-07 18:27:20 +02:00
"direction": "left",
}
2019-05-10 08:51:16 +02:00
#EOF
2019-05-07 18:27:20 +02:00
#+END_SRC
2. Server can reply
#+BEGIN_SRC json
{
"type": "state",
"game-id": 1,
"game-over": false,
2019-05-09 18:38:31 +02:00
"snake": [[0,2],[1,2]],
"food": [[6,7]]
2019-05-07 18:27:20 +02:00
}
#+END_SRC
*** Refresh Screen
1. When no key are press (the snake is simply going straigth forward). So, client can send:
#+BEGIN_SRC json
{
"type": "update",
2019-05-07 18:29:32 +02:00
"game-id": 1,
2019-05-07 18:27:20 +02:00
"direction": null
}
2019-05-10 08:51:16 +02:00
#EOF
2019-05-07 18:27:20 +02:00
#+END_SRC
2. Server can reply:
#+BEGIN_SRC json
{
"type": "state",
"game-id": 1,
"game-over": false,
2019-05-09 18:38:31 +02:00
"snake": [[1,2],[0,2]],
"food": [[6,7]]
2019-05-07 18:27:20 +02:00
}
#+END_SRC
*** End Game
- When game is over server will send the following state message (switch game-over to true):
#+BEGIN_SRC json
{
"type": "state",
"game-id": 1,
"game-over": true,
2019-05-09 18:38:31 +02:00
"snake": [[0,2],[1,2]],
"food": [[6,7]]
2019-05-07 18:27:20 +02:00
}
#+END_SRC
2019-05-10 08:51:16 +02:00
- No reply is expected from the client and server will be in charge to free local memory.