Add "score" command, which can be used by any user to view the current score of any other user (even across games). Also allows admins to modify a user's current score, which can be useful on private servers where admins are playing and can "repair" a score if someone gets disconnected or kicked accidentally.
This commit is contained in:
parent
7e7be6c54e
commit
249a308b5b
|
@ -235,3 +235,14 @@ cah.ajax.SuccessHandlers[cah.$.AjaxOperation.KICK] = function(data) {
|
||||||
cah.ajax.SuccessHandlers[cah.$.AjaxOperation.BAN] = function(data) {
|
cah.ajax.SuccessHandlers[cah.$.AjaxOperation.BAN] = function(data) {
|
||||||
// pass
|
// pass
|
||||||
};
|
};
|
||||||
|
|
||||||
|
cah.ajax.SuccessHandlers[cah.$.AjaxOperation.SCORE] = function(data, req) {
|
||||||
|
var gameId = req[cah.$.AjaxRequest.GAME_ID];
|
||||||
|
var info = data[cah.$.AjaxResponse.PLAYER_INFO];
|
||||||
|
var msg = info[cah.$.GamePlayerInfo.NAME] + " has " + info[cah.$.GamePlayerInfo.SCORE] + " Awesome Points.";
|
||||||
|
if (gameId) {
|
||||||
|
cah.log.status_with_game(gameId, msg);
|
||||||
|
} else {
|
||||||
|
cah.log.status(msg);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
|
@ -163,6 +163,12 @@ function chatsubmit_click(game_id, parent_element) {
|
||||||
// this could also be an IP address
|
// this could also be an IP address
|
||||||
ajax = cah.Ajax.build(cah.$.AjaxOperation.BAN).withNickname(text.split(' ')[0]);
|
ajax = cah.Ajax.build(cah.$.AjaxOperation.BAN).withNickname(text.split(' ')[0]);
|
||||||
break;
|
break;
|
||||||
|
case 'score':
|
||||||
|
ajax = cah.Ajax.build(cah.$.AjaxOperation.SCORE).withMessage(text);
|
||||||
|
if (game_id != null) {
|
||||||
|
ajax = ajax.withGameId(game_id);
|
||||||
|
}
|
||||||
|
break;
|
||||||
case 'names':
|
case 'names':
|
||||||
ajax = cah.Ajax.build(cah.$.AjaxOperation.NAMES);
|
ajax = cah.Ajax.build(cah.$.AjaxOperation.NAMES);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -11,6 +11,7 @@ cah.$.AjaxOperation.FIRST_LOAD = "fl";
|
||||||
cah.$.AjaxOperation.LOG_OUT = "lo";
|
cah.$.AjaxOperation.LOG_OUT = "lo";
|
||||||
cah.$.AjaxOperation.BAN = "b";
|
cah.$.AjaxOperation.BAN = "b";
|
||||||
cah.$.AjaxOperation.JUDGE_SELECT = "js";
|
cah.$.AjaxOperation.JUDGE_SELECT = "js";
|
||||||
|
cah.$.AjaxOperation.SCORE = "SC";
|
||||||
cah.$.AjaxOperation.GAME_LIST = "ggl";
|
cah.$.AjaxOperation.GAME_LIST = "ggl";
|
||||||
cah.$.AjaxOperation.CHANGE_GAME_OPTIONS = "cgo";
|
cah.$.AjaxOperation.CHANGE_GAME_OPTIONS = "cgo";
|
||||||
cah.$.AjaxOperation.GET_GAME_INFO = "ggi";
|
cah.$.AjaxOperation.GET_GAME_INFO = "ggi";
|
||||||
|
|
|
@ -182,6 +182,7 @@ public class Constants {
|
||||||
NAMES("gn"),
|
NAMES("gn"),
|
||||||
PLAY_CARD("pc"),
|
PLAY_CARD("pc"),
|
||||||
REGISTER("r"),
|
REGISTER("r"),
|
||||||
|
SCORE("SC"),
|
||||||
START_GAME("sg");
|
START_GAME("sg");
|
||||||
|
|
||||||
private final String op;
|
private final String op;
|
||||||
|
|
|
@ -462,7 +462,7 @@ public class Game {
|
||||||
* The player for whom to get status.
|
* The player for whom to get status.
|
||||||
* @return Information for {@code player}: Name, score, status.
|
* @return Information for {@code player}: Name, score, status.
|
||||||
*/
|
*/
|
||||||
private Map<GamePlayerInfo, Object> getPlayerInfo(final Player player) {
|
public Map<GamePlayerInfo, Object> getPlayerInfo(final Player player) {
|
||||||
final Map<GamePlayerInfo, Object> playerInfo = new HashMap<GamePlayerInfo, Object>();
|
final Map<GamePlayerInfo, Object> playerInfo = new HashMap<GamePlayerInfo, Object>();
|
||||||
// TODO make sure this can't happen in the first place
|
// TODO make sure this can't happen in the first place
|
||||||
if (player == null) {
|
if (player == null) {
|
||||||
|
@ -803,10 +803,7 @@ public class Game {
|
||||||
|
|
||||||
// have to do this after we move to judging state
|
// have to do this after we move to judging state
|
||||||
for (final Player player : playersToUpdateStatus) {
|
for (final Player player : playersToUpdateStatus) {
|
||||||
final HashMap<ReturnableData, Object> data = getEventMap();
|
notifyPlayerInfoChange(player);
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(player));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -830,17 +827,14 @@ public class Game {
|
||||||
final int judgeTimer = useTimer ? JUDGE_TIMEOUT_BASE
|
final int judgeTimer = useTimer ? JUDGE_TIMEOUT_BASE
|
||||||
+ (JUDGE_TIMEOUT_PER_CARD * playedCards.size() * blackCard.getPick()) : Integer.MAX_VALUE;
|
+ (JUDGE_TIMEOUT_PER_CARD * playedCards.size() * blackCard.getPick()) : Integer.MAX_VALUE;
|
||||||
|
|
||||||
HashMap<ReturnableData, Object> data = getEventMap();
|
final HashMap<ReturnableData, Object> data = getEventMap();
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_STATE_CHANGE.toString());
|
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_STATE_CHANGE.toString());
|
||||||
data.put(LongPollResponse.GAME_STATE, GameState.JUDGING.toString());
|
data.put(LongPollResponse.GAME_STATE, GameState.JUDGING.toString());
|
||||||
data.put(LongPollResponse.WHITE_CARDS, getWhiteCards());
|
data.put(LongPollResponse.WHITE_CARDS, getWhiteCards());
|
||||||
data.put(LongPollResponse.PLAY_TIMER, judgeTimer);
|
data.put(LongPollResponse.PLAY_TIMER, judgeTimer);
|
||||||
broadcastToPlayers(MessageType.GAME_EVENT, data);
|
broadcastToPlayers(MessageType.GAME_EVENT, data);
|
||||||
|
|
||||||
data = getEventMap();
|
notifyPlayerInfoChange(getJudge());
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(getJudge()));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
|
|
||||||
synchronized (nextRoundTimerLock) {
|
synchronized (nextRoundTimerLock) {
|
||||||
killRoundTimer();
|
killRoundTimer();
|
||||||
|
@ -892,23 +886,17 @@ public class Game {
|
||||||
final Player judge = getJudge();
|
final Player judge = getJudge();
|
||||||
judgeIndex = 0;
|
judgeIndex = 0;
|
||||||
|
|
||||||
HashMap<ReturnableData, Object> data = getEventMap();
|
final HashMap<ReturnableData, Object> data = getEventMap();
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_STATE_CHANGE.toString());
|
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_STATE_CHANGE.toString());
|
||||||
data.put(LongPollResponse.GAME_STATE, GameState.LOBBY.toString());
|
data.put(LongPollResponse.GAME_STATE, GameState.LOBBY.toString());
|
||||||
broadcastToPlayers(MessageType.GAME_EVENT, data);
|
broadcastToPlayers(MessageType.GAME_EVENT, data);
|
||||||
|
|
||||||
if (host != null) {
|
if (host != null) {
|
||||||
data = getEventMap();
|
notifyPlayerInfoChange(host);
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(host));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (judge != null) {
|
if (judge != null) {
|
||||||
data = getEventMap();
|
notifyPlayerInfoChange(judge);
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(judge));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
gameManager.broadcastGameListRefresh();
|
gameManager.broadcastGameListRefresh();
|
||||||
|
@ -1019,7 +1007,7 @@ public class Game {
|
||||||
* {@code user} is not in this game.
|
* {@code user} is not in this game.
|
||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
private Player getPlayerForUser(final User user) {
|
public Player getPlayerForUser(final User user) {
|
||||||
final Player[] playersCopy = players.toArray(new Player[players.size()]);
|
final Player[] playersCopy = players.toArray(new Player[players.size()]);
|
||||||
for (final Player player : playersCopy) {
|
for (final Player player : playersCopy) {
|
||||||
if (player.getUser() == user) {
|
if (player.getUser() == user) {
|
||||||
|
@ -1210,11 +1198,7 @@ public class Game {
|
||||||
}
|
}
|
||||||
if (playCard != null) {
|
if (playCard != null) {
|
||||||
playedCards.addCard(player, playCard);
|
playedCards.addCard(player, playCard);
|
||||||
|
notifyPlayerInfoChange(player);
|
||||||
final HashMap<ReturnableData, Object> data = getEventMap();
|
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(player));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
|
|
||||||
if (startJudging()) {
|
if (startJudging()) {
|
||||||
judgingState();
|
judgingState();
|
||||||
|
@ -1228,6 +1212,19 @@ public class Game {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sends updated player information about a specific player to all players in the game.
|
||||||
|
*
|
||||||
|
* @param player
|
||||||
|
* The player whose information has been changed.
|
||||||
|
*/
|
||||||
|
public void notifyPlayerInfoChange(final Player player) {
|
||||||
|
final HashMap<ReturnableData, Object> data = getEventMap();
|
||||||
|
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
||||||
|
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(player));
|
||||||
|
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The judge has selected a card. The {@code cardId} passed in may be any white cards's ID for
|
* The judge has selected a card. The {@code cardId} passed in may be any white cards's ID for
|
||||||
* black cards that have multiple selection, however only the first card in the set's ID will be
|
* black cards that have multiple selection, however only the first card in the set's ID will be
|
||||||
|
@ -1264,22 +1261,15 @@ public class Game {
|
||||||
}
|
}
|
||||||
final int clientCardId = playedCards.getCards(cardPlayer).get(0).getId();
|
final int clientCardId = playedCards.getCards(cardPlayer).get(0).getId();
|
||||||
|
|
||||||
HashMap<ReturnableData, Object> data = getEventMap();
|
final HashMap<ReturnableData, Object> data = getEventMap();
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_ROUND_COMPLETE.toString());
|
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_ROUND_COMPLETE.toString());
|
||||||
data.put(LongPollResponse.ROUND_WINNER, cardPlayer.getUser().getNickname());
|
data.put(LongPollResponse.ROUND_WINNER, cardPlayer.getUser().getNickname());
|
||||||
data.put(LongPollResponse.WINNING_CARD, clientCardId);
|
data.put(LongPollResponse.WINNING_CARD, clientCardId);
|
||||||
data.put(LongPollResponse.INTERMISSION, ROUND_INTERMISSION);
|
data.put(LongPollResponse.INTERMISSION, ROUND_INTERMISSION);
|
||||||
broadcastToPlayers(MessageType.GAME_EVENT, data);
|
broadcastToPlayers(MessageType.GAME_EVENT, data);
|
||||||
|
|
||||||
data = getEventMap();
|
notifyPlayerInfoChange(getJudge());
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
notifyPlayerInfoChange(cardPlayer);
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(getJudge()));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
|
|
||||||
data = getEventMap();
|
|
||||||
data.put(LongPollResponse.EVENT, LongPollEvent.GAME_PLAYER_INFO_CHANGE.toString());
|
|
||||||
data.put(LongPollResponse.PLAYER_INFO, getPlayerInfo(cardPlayer));
|
|
||||||
broadcastToPlayers(MessageType.GAME_PLAYER_EVENT, data);
|
|
||||||
|
|
||||||
synchronized (nextRoundTimerLock) {
|
synchronized (nextRoundTimerLock) {
|
||||||
killRoundTimer();
|
killRoundTimer();
|
||||||
|
|
|
@ -72,6 +72,13 @@ public class Player {
|
||||||
score++;
|
score++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Increase the player's score by the specified amount.
|
||||||
|
*/
|
||||||
|
public void increaseScore(final int offset) {
|
||||||
|
score += offset;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Reset the player's score to 0.
|
* Reset the player's score to 0.
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -28,6 +28,7 @@ public class Handlers {
|
||||||
LIST.put(NamesHandler.OP, NamesHandler.class);
|
LIST.put(NamesHandler.OP, NamesHandler.class);
|
||||||
LIST.put(PlayCardHandler.OP, PlayCardHandler.class);
|
LIST.put(PlayCardHandler.OP, PlayCardHandler.class);
|
||||||
LIST.put(RegisterHandler.OP, RegisterHandler.class);
|
LIST.put(RegisterHandler.OP, RegisterHandler.class);
|
||||||
|
LIST.put(ScoreHandler.OP, ScoreHandler.class);
|
||||||
LIST.put(StartGameHandler.OP, StartGameHandler.class);
|
LIST.put(StartGameHandler.OP, StartGameHandler.class);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,72 @@
|
||||||
|
package net.socialgamer.cah.handlers;
|
||||||
|
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpSession;
|
||||||
|
|
||||||
|
import net.socialgamer.cah.Constants.AjaxOperation;
|
||||||
|
import net.socialgamer.cah.Constants.AjaxRequest;
|
||||||
|
import net.socialgamer.cah.Constants.AjaxResponse;
|
||||||
|
import net.socialgamer.cah.Constants.ErrorCode;
|
||||||
|
import net.socialgamer.cah.Constants.ReturnableData;
|
||||||
|
import net.socialgamer.cah.Constants.SessionAttribute;
|
||||||
|
import net.socialgamer.cah.RequestWrapper;
|
||||||
|
import net.socialgamer.cah.data.ConnectedUsers;
|
||||||
|
import net.socialgamer.cah.data.Game;
|
||||||
|
import net.socialgamer.cah.data.Player;
|
||||||
|
import net.socialgamer.cah.data.User;
|
||||||
|
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
|
||||||
|
|
||||||
|
public class ScoreHandler extends Handler {
|
||||||
|
|
||||||
|
public static final String OP = AjaxOperation.SCORE.toString();
|
||||||
|
|
||||||
|
private final ConnectedUsers connectedUsers;
|
||||||
|
|
||||||
|
@Inject
|
||||||
|
public ScoreHandler(final ConnectedUsers connectedUsers) {
|
||||||
|
this.connectedUsers = connectedUsers;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<ReturnableData, Object> handle(final RequestWrapper request, final HttpSession session) {
|
||||||
|
final User user = (User) session.getAttribute(SessionAttribute.USER);
|
||||||
|
assert (user != null);
|
||||||
|
final String params = request.getParameter(AjaxRequest.MESSAGE);
|
||||||
|
final String[] args = (params == null || params.isEmpty()) ? new String[0] : params.trim()
|
||||||
|
.split(" ");
|
||||||
|
|
||||||
|
final User target = (args.length > 0) ? connectedUsers.getUser(args[0]) : user;
|
||||||
|
if (null == target) {
|
||||||
|
return error(ErrorCode.NO_SUCH_USER);
|
||||||
|
}
|
||||||
|
final Game game = target.getGame();
|
||||||
|
if (null == game) {
|
||||||
|
return error(ErrorCode.INVALID_GAME);
|
||||||
|
}
|
||||||
|
final Player player = game.getPlayerForUser(target);
|
||||||
|
if (null == player) {
|
||||||
|
return error(ErrorCode.INVALID_GAME);
|
||||||
|
}
|
||||||
|
|
||||||
|
final Map<ReturnableData, Object> data = new HashMap<ReturnableData, Object>();
|
||||||
|
|
||||||
|
if (user.isAdmin() && args.length == 2) {
|
||||||
|
// for now only admins can change scores. could possibly extend this to let the host do it,
|
||||||
|
// provided it's for a player in the same game and it does a gamewide announcement.
|
||||||
|
try {
|
||||||
|
final int offset = Integer.parseInt(args[1]);
|
||||||
|
player.increaseScore(offset);
|
||||||
|
game.notifyPlayerInfoChange(player);
|
||||||
|
} catch (final NumberFormatException e) {
|
||||||
|
return error(ErrorCode.BAD_REQUEST);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
data.put(AjaxResponse.PLAYER_INFO, game.getPlayerInfo(player));
|
||||||
|
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue