Package mage.server

Source Code of mage.server.ServerImpl

/*
* 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.Constants.MultiplayerAttackOption;
import mage.Constants.RangeOfInfluence;
import mage.cards.decks.DeckCardLists;
import mage.game.GameException;
import mage.interfaces.MageException;
import mage.interfaces.Server;
import mage.interfaces.ServerState;
import mage.interfaces.callback.ClientCallback;
import mage.server.game.DeckValidatorFactory;
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.game.TableManager;
import mage.server.util.ThreadExecutor;
import mage.util.Logging;
import mage.view.ChatMessage.MessageColor;
import mage.view.TableView;

/**
*
* @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, String gameType, String deckType, List<String> playerTypes, MultiplayerAttackOption attackOption, RangeOfInfluence range) throws MageException {
    try {
      TableView table = GamesRoomManager.getInstance().getRoom(roomId).createTable(sessionId, gameType, deckType, playerTypes, attackOption, range);
      logger.info("Table " + table.getTableId() + " created");
      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, DeckCardLists deckList) throws MageException, GameException {
    try {
      boolean ret = GamesRoomManager.getInstance().getRoom(roomId).joinTable(sessionId, tableId, name, 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 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 startGame(final UUID sessionId, final UUID roomId, final UUID tableId) throws MageException {
    try {
      rmiExecutor.execute(
        new Runnable() {
          @Override
          public void run() {
            TableManager.getInstance().startGame(sessionId, roomId, tableId);
          }
        }
      );
    }
    catch (Exception ex) {
      handleException(ex);
    }
  }

  @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 UUID getGameChatId(UUID gameId) throws MageException {
    try {
      return GameManager.getInstance().getChatId(gameId);
    }
    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 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(),
          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);
    }
  }

  public void handleException(Exception ex) throws MageException {
    logger.log(Level.SEVERE, "", ex);
    throw new MageException("Server error");
  }

}
TOP

Related Classes of mage.server.ServerImpl

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.