forked from External/mage
769 lines
20 KiB
Java
769 lines
20 KiB
Java
/*
|
|
* Copyright 2010 BetaSteward_at_googlemail.com. All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without modification, are
|
|
* permitted provided that the following conditions are met:
|
|
*
|
|
* 1. Redistributions of source code must retain the above copyright notice, this list of
|
|
* conditions and the following disclaimer.
|
|
*
|
|
* 2. Redistributions in binary form must reproduce the above copyright notice, this list
|
|
* of conditions and the following disclaimer in the documentation and/or other materials
|
|
* provided with the distribution.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY BetaSteward_at_googlemail.com ``AS IS'' AND ANY EXPRESS OR IMPLIED
|
|
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL BetaSteward_at_googlemail.com OR
|
|
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
|
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
|
|
* ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*
|
|
* The views and conclusions contained in the software and documentation are those of the
|
|
* authors and should not be interpreted as representing official policies, either expressed
|
|
* or implied, of BetaSteward_at_googlemail.com.
|
|
*/
|
|
|
|
package mage.server;
|
|
|
|
import java.rmi.RemoteException;
|
|
import java.rmi.registry.LocateRegistry;
|
|
import java.rmi.registry.Registry;
|
|
import java.rmi.server.ExportException;
|
|
import java.rmi.server.RemoteServer;
|
|
import java.rmi.server.UnicastRemoteObject;
|
|
import java.util.List;
|
|
import java.util.UUID;
|
|
import java.util.concurrent.ExecutorService;
|
|
import java.util.logging.Level;
|
|
import java.util.logging.Logger;
|
|
import mage.cards.decks.DeckCardLists;
|
|
import mage.game.GameException;
|
|
import mage.interfaces.MageException;
|
|
import mage.game.match.MatchOptions;
|
|
import mage.game.tournament.TournamentOptions;
|
|
import mage.interfaces.Server;
|
|
import mage.interfaces.ServerState;
|
|
import mage.interfaces.callback.ClientCallback;
|
|
import mage.server.game.DeckValidatorFactory;
|
|
import mage.server.draft.DraftManager;
|
|
import mage.server.game.GameFactory;
|
|
import mage.server.game.GameManager;
|
|
import mage.server.game.GamesRoomManager;
|
|
import mage.server.game.PlayerFactory;
|
|
import mage.server.game.ReplayManager;
|
|
import mage.server.tournament.TournamentFactory;
|
|
import mage.server.tournament.TournamentManager;
|
|
import mage.server.util.ThreadExecutor;
|
|
import mage.util.Logging;
|
|
import mage.view.ChatMessage.MessageColor;
|
|
import mage.view.DraftPickView;
|
|
import mage.view.GameView;
|
|
import mage.view.TableView;
|
|
import mage.view.TournamentView;
|
|
|
|
/**
|
|
*
|
|
* @author BetaSteward_at_googlemail.com
|
|
*/
|
|
public class ServerImpl extends RemoteServer implements Server {
|
|
|
|
private final static Logger logger = Logging.getLogger("Mage Server");
|
|
private static ExecutorService rmiExecutor = ThreadExecutor.getInstance().getRMIExecutor();
|
|
|
|
private boolean testMode;
|
|
|
|
public ServerImpl(int port, String name, boolean testMode) {
|
|
try {
|
|
System.setSecurityManager(null);
|
|
Registry reg = LocateRegistry.createRegistry(port);
|
|
Server stub = (Server) UnicastRemoteObject.exportObject(this, port);
|
|
reg.rebind(name, stub);
|
|
this.testMode = testMode;
|
|
logger.info("Started MAGE server - listening on port " + port);
|
|
if (testMode)
|
|
logger.info("MAGE server running in test mode");
|
|
} catch (ExportException ex) {
|
|
logger.severe("ERROR: Unable to start Mage Server - another server is likely running");
|
|
} catch (RemoteException ex) {
|
|
logger.log(Level.SEVERE, "Failed to start RMI server at port " + port, ex);
|
|
}
|
|
}
|
|
|
|
public boolean isTestMode() {
|
|
return testMode;
|
|
}
|
|
|
|
@Override
|
|
public ClientCallback callback(UUID sessionId) {
|
|
return SessionManager.getInstance().getSession(sessionId).callback();
|
|
}
|
|
|
|
@Override
|
|
public void ack(String message, UUID sessionId) throws RemoteException, MageException {
|
|
SessionManager.getInstance().getSession(sessionId).ack(message);
|
|
}
|
|
|
|
@Override
|
|
public UUID registerClient(String userName, UUID clientId) throws MageException, RemoteException {
|
|
|
|
UUID sessionId = SessionManager.getInstance().createSession(userName, clientId);
|
|
try {
|
|
logger.info("Session " + sessionId + " created for user " + userName + " at " + getClientHost());
|
|
} catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return sessionId;
|
|
|
|
}
|
|
|
|
@Override
|
|
public TableView createTable(UUID sessionId, UUID roomId, MatchOptions options) throws MageException {
|
|
try {
|
|
TableView table = GamesRoomManager.getInstance().getRoom(roomId).createTable(sessionId, options);
|
|
logger.info("Table " + table.getTableId() + " created");
|
|
return table;
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public TableView createTournamentTable(UUID sessionId, UUID roomId, TournamentOptions options) throws MageException {
|
|
try {
|
|
TableView table = GamesRoomManager.getInstance().getRoom(roomId).createTournamentTable(sessionId, options);
|
|
logger.log(Level.INFO, "Tournament table {0} created", table.getTableId());
|
|
return table;
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void removeTable(final UUID sessionId, final UUID roomId, final UUID tableId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GamesRoomManager.getInstance().getRoom(roomId).removeTable(sessionId, tableId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean joinTable(UUID sessionId, UUID roomId, UUID tableId, String name, String playerType, DeckCardLists deckList) throws MageException, GameException {
|
|
try {
|
|
boolean ret = GamesRoomManager.getInstance().getRoom(roomId).joinTable(sessionId, tableId, name, playerType, deckList);
|
|
logger.info("Session " + sessionId + " joined table " + tableId);
|
|
return ret;
|
|
}
|
|
catch (Exception ex) {
|
|
if (ex instanceof GameException)
|
|
throw (GameException)ex;
|
|
handleException(ex);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public boolean joinTournamentTable(UUID sessionId, UUID roomId, UUID tableId, String name, String playerType) throws MageException, GameException {
|
|
try {
|
|
boolean ret = GamesRoomManager.getInstance().getRoom(roomId).joinTournamentTable(sessionId, tableId, name, playerType);
|
|
logger.info("Session " + sessionId + " joined table " + tableId);
|
|
return ret;
|
|
}
|
|
catch (Exception ex) {
|
|
if (ex instanceof GameException)
|
|
throw (GameException)ex;
|
|
handleException(ex);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public boolean submitDeck(UUID sessionId, UUID tableId, DeckCardLists deckList) throws MageException, GameException {
|
|
try {
|
|
boolean ret = TableManager.getInstance().submitDeck(sessionId, tableId, deckList);
|
|
logger.info("Session " + sessionId + " submitted deck");
|
|
return ret;
|
|
}
|
|
catch (Exception ex) {
|
|
if (ex instanceof GameException)
|
|
throw (GameException)ex;
|
|
handleException(ex);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public List<TableView> getTables(UUID roomId) throws MageException {
|
|
try {
|
|
return GamesRoomManager.getInstance().getRoom(roomId).getTables();
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public TableView getTable(UUID roomId, UUID tableId) throws MageException {
|
|
try {
|
|
return GamesRoomManager.getInstance().getRoom(roomId).getTable(tableId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void deregisterClient(final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
SessionManager.getInstance().getSession(sessionId).kill();
|
|
logger.info("Client deregistered ...");
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void startMatch(final UUID sessionId, final UUID roomId, final UUID tableId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
TableManager.getInstance().startMatch(sessionId, roomId, tableId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void startTournament(final UUID sessionId, final UUID roomId, final UUID tableId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
TableManager.getInstance().startTournament(sessionId, roomId, tableId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public TournamentView getTournament(UUID tournamentId) throws RemoteException, MageException {
|
|
try {
|
|
return TournamentManager.getInstance().getTournamentView(tournamentId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void sendChatMessage(final UUID chatId, final String userName, final String message) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ChatManager.getInstance().broadcast(chatId, userName, message, MessageColor.BLUE);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void joinChat(final UUID chatId, final UUID sessionId, final String userName) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ChatManager.getInstance().joinChat(chatId, sessionId, userName);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void leaveChat(final UUID chatId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ChatManager.getInstance().leaveChat(chatId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public UUID getMainRoomId() throws MageException {
|
|
try {
|
|
return GamesRoomManager.getInstance().getMainRoomId();
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public UUID getRoomChatId(UUID roomId) throws MageException {
|
|
try {
|
|
return GamesRoomManager.getInstance().getRoom(roomId).getChatId();
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public boolean isTableOwner(UUID sessionId, UUID roomId, UUID tableId) throws MageException {
|
|
try {
|
|
return TableManager.getInstance().isTableOwner(tableId, sessionId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public void swapSeats(final UUID sessionId, final UUID roomId, final UUID tableId, final int seatNum1, final int seatNum2) throws RemoteException, MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
TableManager.getInstance().swapSeats(tableId, sessionId, seatNum1, seatNum2);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void leaveTable(final UUID sessionId, final UUID roomId, final UUID tableId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GamesRoomManager.getInstance().getRoom(roomId).leaveTable(sessionId, tableId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public UUID getTableChatId(UUID tableId) throws MageException {
|
|
try {
|
|
return TableManager.getInstance().getChatId(tableId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void joinGame(final UUID gameId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().joinGame(gameId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void joinDraft(final UUID draftId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
DraftManager.getInstance().joinDraft(draftId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void joinTournament(final UUID tournamentId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
TournamentManager.getInstance().joinTournament(tournamentId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public UUID getGameChatId(UUID gameId) throws MageException {
|
|
try {
|
|
return GameManager.getInstance().getChatId(gameId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public UUID getTournamentChatId(UUID tournamentId) throws MageException {
|
|
try {
|
|
return TournamentManager.getInstance().getChatId(tournamentId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void sendPlayerUUID(final UUID gameId, final UUID sessionId, final UUID data) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().sendPlayerUUID(gameId, sessionId, data);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void sendPlayerString(final UUID gameId, final UUID sessionId, final String data) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().sendPlayerString(gameId, sessionId, data);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void sendPlayerBoolean(final UUID gameId, final UUID sessionId, final Boolean data) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().sendPlayerBoolean(gameId, sessionId, data);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void sendPlayerInteger(final UUID gameId, final UUID sessionId, final Integer data) throws RemoteException, MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().sendPlayerInteger(gameId, sessionId, data);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public DraftPickView sendCardPick(final UUID draftId, final UUID sessionId, final UUID cardPick) throws MageException {
|
|
try {
|
|
return DraftManager.getInstance().sendCardPick(draftId, sessionId, cardPick);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void concedeGame(final UUID gameId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().concedeGame(gameId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean watchTable(UUID sessionId, UUID roomId, UUID tableId) throws MageException {
|
|
try {
|
|
return GamesRoomManager.getInstance().getRoom(roomId).watchTable(sessionId, tableId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public void watchGame(final UUID gameId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().watchGame(gameId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void stopWatching(final UUID gameId, final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
GameManager.getInstance().stopWatching(gameId, sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void replayGame(final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ReplayManager.getInstance().startReplay(sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void stopReplay(final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ReplayManager.getInstance().stopReplay(sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void nextPlay(final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ReplayManager.getInstance().nextPlay(sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void previousPlay(final UUID sessionId) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
ReplayManager.getInstance().previousPlay(sessionId);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean replayTable(UUID sessionId, UUID roomId, UUID tableId) throws MageException {
|
|
try {
|
|
return TableManager.getInstance().replayTable(sessionId, tableId);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public ServerState getServerState() throws RemoteException, MageException {
|
|
try {
|
|
return new ServerState(
|
|
GameFactory.getInstance().getGameTypes(),
|
|
TournamentFactory.getInstance().getTournamentTypes(),
|
|
PlayerFactory.getInstance().getPlayerTypes().toArray(new String[0]),
|
|
DeckValidatorFactory.getInstance().getDeckTypes().toArray(new String[0]),
|
|
testMode);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
return null;
|
|
}
|
|
|
|
@Override
|
|
public void cheat(final UUID gameId, final UUID sessionId, final UUID playerId, final DeckCardLists deckList) throws MageException {
|
|
try {
|
|
rmiExecutor.execute(
|
|
new Runnable() {
|
|
@Override
|
|
public void run() {
|
|
if (testMode)
|
|
GameManager.getInstance().cheat(gameId, sessionId, playerId, deckList);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
catch (Exception ex) {
|
|
handleException(ex);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean cheat(final UUID gameId, final UUID sessionId, final UUID playerId, final String cardName) throws MageException {
|
|
if (testMode) {
|
|
return GameManager.getInstance().cheat(gameId, sessionId, playerId, cardName);
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
public void handleException(Exception ex) throws MageException {
|
|
logger.log(Level.SEVERE, "", ex);
|
|
throw new MageException("Server error: " + ex.getMessage());
|
|
}
|
|
|
|
public GameView getGameView(final UUID gameId, final UUID sessionId, final UUID playerId) {
|
|
return GameManager.getInstance().getGameView(gameId, sessionId, playerId);
|
|
}
|
|
|
|
}
|