Accepts :
- application/x-www-form-urlencoded
- application/json
Remote test server : https://morbak.alan-balbo.com
- Login with
/api/auth/login
- This should respond with something like :
{
"user": {
"_id": "5ad0b5f26568137c6c85e228",
"username": "MonBlaze",
"creationDate": "2018-04-13T14:07:13.052Z",
"__v": 0
},
"token": "MY_TOKEN"
}
- You should save the user somewhere, as well as the token
- Again, the token should be saved in local storage for auto login
- The token must be provided in the
Authorization
header of every request to the API, preceded with theBearer
keyword; like so:
Authorization: Bearer MY_TOKEN
Name | Method | Route | Params |
---|---|---|---|
Login | POST | /api/auth/login | {username: string, password: string} |
Register | POST | /api/auth/register | {username: string, password: string} |
List Users | GET | /api/users | - |
Get User | GET | /api/users/:id | - |
Update user | PUT | /api/users/:id | {username?: string} |
Create lobby | POST | /api/lobbies | {name: string} |
List lobbies | GET | /api/lobbies | {limit?: number, offset?: number} |
Get lobby | GET | /api/lobbies/:id | |
Get lobby members | GET | /api/lobbies/:id/members | |
Get lobby games | GET | /api/lobbies/:id/games | |
Delete lobby | DELETE | /api/lobbies/:id | |
List Games | GET | /api/games | {limit?: number, offset?: number} |
Get Game | GET | /api/games/:id |
Reçues uniquement après l'envoi d'une requête
Elle te push les événements suivants :
- Mise à jour du profil
- Tu as rejoins une room
- Tu as quitté une room
- Tu as été kick d'une room
- Tu as créé une room
- Tu as rejoins une game
- Tu as terminé une game
- Tu as reçu une réponse à une requête
Reçues uniquement si le user est dans un lobby
Push les événements suivants :
- Un joueur a rejoint le lobby
- Un joueur a quitté le lobby
- Un joueur en a invité un autre à jouer
- Un joueur a accepté une invitation
- Une partie vient de commencer
- Une partie vient de se terminer
- Une partie ouverte vient d'être créée (peut être rejointe par n'importe qui)
- Le lobby vient d'être créé
- Le lobby vient d'être détruit
Reçues uniquement si le user est dans une game
- La game vient d'être créée
- Un joueur a rejoint la game
- Un joueur a quitté la game
- Un spectateur a rejoint la partie
- Un spectateur est parti
- Un joueur vient de jouer un coup
- La partie est terminée
- Une nouvelle partie vient d'être lancée
- La game a été détruite
joinLobby
: Le user veut rejoindre un lobby
joinGame
: Le user veut rejoindre une game
invitePlayer
: Le user veut inviter un autre user à jouer
createGame
: Le user veut créer une partie ouverte
Fair un appel sur POST /request
avec le body suivant :
{
type: 'joinLobby' | 'joinGame' | 'invitePlayer' | 'createGame',
accessResource: "ResourceId"
}
Le call renvoie la request créée (avec son id)
Dans la websocket de ton user tu vas recevoir la réponse à la Request quand elle sera traitée (y'a une queue côté serveur)
- Soit elle a un
status: 'rejected'
et du coup tu peux afficher un message d'erreur comme quoi la requête associé à fail - Soit elle a un
status: 'ok'
et tu peux interpréter le message
Une reponse ressemble à ça :
{
request: Request // La request associée,
message: '', // Un message explicite sur la response
statusCode: 0, // Le code de retour normalisé de la response
status: 'rejected' | 'ok' | 'aborted', // Le statut clair de la response
resourceLink: '', // Un lien vers la resource associée
time: 23165465132132, // timestamp
type: 'user' | 'lobby' | 'game'
}
(je documenterai les codes de retour sur le fil)
En gros, si dans tes sockets tu reçois une requête de type 'joinLobby' avec le statut 'ok', ça veut dire que tu as rejoins un lobby. Donc si tu fais
- GET /lobbies/{LobbyId}/members Tu vas voir que tu es dans la liste des users du lobby, et quand tu feras le get, ça va te renvoyer un lien vers la websocket du lobby
- Se connecter au serveur de websocket:
ws://${serverURL}
- Envoyer un message sur le serveur de websocket avec le contenu suivant :
{
"userId": "idDuUser"
}
Le serveur répond ok
quand vous êtes connectés à la socket.
Avant de pouvoir jouer, il faut rejoindre un lobby
- Envoyer une requête pour rejoindre le lobby:
POST /api/requests
body | value | description |
---|---|---|
type | 'joinLobby' |
L'action a performer |
accessResource | 5adcb42580876a5beecb943f |
L'id du lobby à rejoindre |
- Attendre la réponse sur sa socket. Les sockets envoient la réponse suivante :
{
requestId: '5adcb45580876a5beecb9440',
message: 'Lobby joined',
statusCode: 101,
status: 'ok',
resourceURI: '/api/lobbies/5adcb42580876a5beecb943f',
time: 123454654161,
type: 'user'
}
Avant de pouvoir jouer, il faut créer une game
- Envoyer une requête pour créer la game:
POST /api/requests
body | value | description |
---|---|---|
type | 'createGame' |
L'action a performer |
accessResource | 5adcb42580876a5beecb943f |
Le lobby dans lequel créer la game |
- Attendre la réponse sur sa socket. Les sockets envoient la réponse suivante :
{
requestId: '5adcb45580876a5beecb9440',
message: 'Game created',
statusCode: 301,
status: 'ok',
resourceURI: '/api/games/5adcb42580876a5beecb943f',
time: 123454654161,
type: 'user'
}
Avant de pouvoir jouer, il faut rejoindre une game
- Envoyer une requête pour créer la game:
POST /api/requests
body | value | description |
---|---|---|
type | 'joinGame' |
L'action a performer |
accessResource | 5adcb42580876a5beecb943f |
L'id de la game à rejoindre |
- Attendre la réponse sur sa socket. Les sockets envoient la réponse suivante :
{
requestId: '5adcb45580876a5beecb9440',
message: 'Game joined',
statusCode: 302,
status: 'ok',
resourceURI: '/api/games/5adcb42580876a5beecb943f',
time: 123454654161,
type: 'user'
}
Il suffit de mettre à jour son profil user avec 'game': undefined
pour quitter la game.
PUT /api/users/{id}
body | value |
---|---|
game | undefined |
Il suffit de mettre à jour son profil user avec 'lobby': undefined
pour quitter la game.
PUT /api/users/{id}
body | value |
---|---|
lobby | undefined |
statusCode | status | message | resource associée | détails |
---|---|---|---|---|
101 |
ok |
Lobby joined | URI du lobby joint | |
301 |
ok |
Game created | URI de la partie créée | |
302 |
ok |
Game joined | URI de la partie rejoint |
statusCode | status | message | resource associée | détails |
---|---|---|---|---|
1001 |
rejected |
Internal Server Error | - | Une erreur côté serveur est survenue |
statusCode | status | message | resource associée | détails |
---|---|---|---|---|
1101 |
rejected |
Lobby not found | - | Le lobby n'existe pas ou plus |
statusCode | status | message | resource associée | détails |
---|---|---|---|---|
1201 |
rejected |
User not found | - | L'utilisateur n'existe pas ou plus |
1202 |
rejected |
User already in a lobby | URI du lobby déjà joint | L'utilisateur est déjà dans un lobby |
1203 |
rejected |
User already in a game | URI de la game du user | L'utilisateur est déjà dans une partie |
1204 |
rejected |
User is not in the requested lobby | - | L'utilisateur n'est pas dans le même lobby que la partie |
1205 |
rejected |
User already in this game | URI de la game du user | L'utilisateur est déjà dans la même partie |
statusCode | status | message | resouce associée | détails |
---|---|---|---|---|
1301 |
rejected |
Game not found | - | La partie n'existe pas ou plus |
1302 |
rejected |
Game has already started | - | La partie a déjà commencé |
1303 |
rejected |
Game is already full | - | La partie est pleine |