false-start of doing admin via ajax, would require a lot more work on the admin client to actually do it this way
This commit is contained in:
parent
9a476e4f81
commit
e3ac81705e
|
@ -14,6 +14,7 @@ cah.$.AjaxOperation.GAME_LIST = "games";
|
||||||
cah.$.AjaxOperation.GET_GAME_INFO = "get_game_info";
|
cah.$.AjaxOperation.GET_GAME_INFO = "get_game_info";
|
||||||
cah.$.AjaxOperation.PLAY_CARD = "play_card";
|
cah.$.AjaxOperation.PLAY_CARD = "play_card";
|
||||||
cah.$.AjaxOperation.CREATE_GAME = "create_game";
|
cah.$.AjaxOperation.CREATE_GAME = "create_game";
|
||||||
|
cah.$.AjaxOperation.ADMIN_SET_VERBOSE_LOG = "set_verbose_log";
|
||||||
cah.$.AjaxOperation.GET_CARDS = "get_cards";
|
cah.$.AjaxOperation.GET_CARDS = "get_cards";
|
||||||
cah.$.AjaxOperation.JOIN_GAME = "join_game";
|
cah.$.AjaxOperation.JOIN_GAME = "join_game";
|
||||||
cah.$.AjaxOperation.REGISTER = "register";
|
cah.$.AjaxOperation.REGISTER = "register";
|
||||||
|
@ -76,6 +77,7 @@ cah.$.ErrorCode = function() {
|
||||||
cah.$.ErrorCode.prototype.dummyForAutocomplete = undefined;
|
cah.$.ErrorCode.prototype.dummyForAutocomplete = undefined;
|
||||||
cah.$.ErrorCode.TOO_MANY_GAMES = "too_many_games";
|
cah.$.ErrorCode.TOO_MANY_GAMES = "too_many_games";
|
||||||
cah.$.ErrorCode.NO_CARD_SPECIFIED = "no_card_spec";
|
cah.$.ErrorCode.NO_CARD_SPECIFIED = "no_card_spec";
|
||||||
|
cah.$.ErrorCode.ACCESS_DENIED = "access_denied";
|
||||||
cah.$.ErrorCode.NOT_GAME_HOST = "not_game_host";
|
cah.$.ErrorCode.NOT_GAME_HOST = "not_game_host";
|
||||||
cah.$.ErrorCode.CANNOT_JOIN_ANOTHER_GAME = "cannot_join_another_game";
|
cah.$.ErrorCode.CANNOT_JOIN_ANOTHER_GAME = "cannot_join_another_game";
|
||||||
cah.$.ErrorCode.INVALID_CARD = "invalid_card";
|
cah.$.ErrorCode.INVALID_CARD = "invalid_card";
|
||||||
|
@ -120,6 +122,7 @@ cah.$.ErrorCode_msg['not_in_that_game'] = "You are not in that game.";
|
||||||
cah.$.ErrorCode_msg['msg_too_long'] = "Messages cannot be longer than 200 characters.";
|
cah.$.ErrorCode_msg['msg_too_long'] = "Messages cannot be longer than 200 characters.";
|
||||||
cah.$.ErrorCode_msg['do_not_have_card'] = "You don't have that card.";
|
cah.$.ErrorCode_msg['do_not_have_card'] = "You don't have that card.";
|
||||||
cah.$.ErrorCode_msg['no_game_spec'] = "No game specified.";
|
cah.$.ErrorCode_msg['no_game_spec'] = "No game specified.";
|
||||||
|
cah.$.ErrorCode_msg['access_denied'] = "Access denied.";
|
||||||
cah.$.ErrorCode_msg['invalid_nick'] = "Nickname must contain only upper and lower case letters, numbers, or underscores, must be 3 to 30 characters long, and must not start with a number.";
|
cah.$.ErrorCode_msg['invalid_nick'] = "Nickname must contain only upper and lower case letters, numbers, or underscores, must be 3 to 30 characters long, and must not start with a number.";
|
||||||
cah.$.ErrorCode_msg['no_nick_spec'] = "No nickname specified.";
|
cah.$.ErrorCode_msg['no_nick_spec'] = "No nickname specified.";
|
||||||
cah.$.ErrorCode_msg['nick_in_use'] = "Nickname is already in use.";
|
cah.$.ErrorCode_msg['nick_in_use'] = "Nickname is already in use.";
|
||||||
|
|
|
@ -63,6 +63,7 @@ public class Constants {
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum AjaxOperation {
|
public enum AjaxOperation {
|
||||||
|
ADMIN_SET_VERBOSE_LOG("set_verbose_log"),
|
||||||
CHAT("chat"),
|
CHAT("chat"),
|
||||||
CREATE_GAME("create_game"),
|
CREATE_GAME("create_game"),
|
||||||
FIRST_LOAD("firstload"),
|
FIRST_LOAD("firstload"),
|
||||||
|
@ -141,6 +142,7 @@ public class Constants {
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ErrorCode implements Localizable {
|
public enum ErrorCode implements Localizable {
|
||||||
|
ACCESS_DENIED("access_denied", "Access denied."),
|
||||||
ALREADY_STARTED("already_started", "The game has already started."),
|
ALREADY_STARTED("already_started", "The game has already started."),
|
||||||
BAD_OP("bad_op", "Invalid operation."),
|
BAD_OP("bad_op", "Invalid operation."),
|
||||||
BAD_REQUEST("bad_req", "Bad request."),
|
BAD_REQUEST("bad_req", "Bad request."),
|
||||||
|
|
|
@ -8,8 +8,8 @@ import java.util.List;
|
||||||
|
|
||||||
public class UpdateHandlerList {
|
public class UpdateHandlerList {
|
||||||
|
|
||||||
private static final List<String> EXCLUDE = Arrays.asList("GameHandler", "GameWithPlayerHandler",
|
private static final List<String> EXCLUDE = Arrays.asList("AdminHandler", "GameHandler",
|
||||||
"Handler", "Handlers");
|
"GameWithPlayerHandler", "Handler", "Handlers");
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param args
|
* @param args
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
package net.socialgamer.cah.handlers;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.servlet.http.HttpSession;
|
||||||
|
|
||||||
|
import net.socialgamer.cah.Constants.ErrorCode;
|
||||||
|
import net.socialgamer.cah.Constants.ReturnableData;
|
||||||
|
import net.socialgamer.cah.RequestWrapper;
|
||||||
|
|
||||||
|
|
||||||
|
public abstract class AdminHandler extends Handler {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<ReturnableData, Object> handle(final RequestWrapper request, final HttpSession session) {
|
||||||
|
final String remoteAddr = request.getRemoteAddr();
|
||||||
|
if (!(remoteAddr.equals("0:0:0:0:0:0:0:1") || remoteAddr.equals("127.0.0.1"))) {
|
||||||
|
return error(ErrorCode.ACCESS_DENIED);
|
||||||
|
}
|
||||||
|
|
||||||
|
return handle(request);
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract Map<ReturnableData, Object> handle(RequestWrapper request);
|
||||||
|
}
|
|
@ -0,0 +1,20 @@
|
||||||
|
package net.socialgamer.cah.handlers;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import net.socialgamer.cah.Constants.AjaxOperation;
|
||||||
|
import net.socialgamer.cah.Constants.ReturnableData;
|
||||||
|
import net.socialgamer.cah.RequestWrapper;
|
||||||
|
|
||||||
|
|
||||||
|
public class AdminSetVerboseLog extends AdminHandler {
|
||||||
|
|
||||||
|
public static final String OP = AjaxOperation.ADMIN_SET_VERBOSE_LOG.toString();
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Map<ReturnableData, Object> handle(final RequestWrapper request) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -10,6 +10,7 @@ public class Handlers {
|
||||||
|
|
||||||
static {
|
static {
|
||||||
LIST = new HashMap<String, Class<? extends Handler>>();
|
LIST = new HashMap<String, Class<? extends Handler>>();
|
||||||
|
LIST.put(AdminSetVerboseLog.OP, AdminSetVerboseLog.class);
|
||||||
LIST.put(ChatHandler.OP, ChatHandler.class);
|
LIST.put(ChatHandler.OP, ChatHandler.class);
|
||||||
LIST.put(CreateGameHandler.OP, CreateGameHandler.class);
|
LIST.put(CreateGameHandler.OP, CreateGameHandler.class);
|
||||||
LIST.put(FirstLoadHandler.OP, FirstLoadHandler.class);
|
LIST.put(FirstLoadHandler.OP, FirstLoadHandler.class);
|
||||||
|
|
Loading…
Reference in New Issue