コード例 #1
0
ファイル: serverlistping.cpp プロジェクト: driax/mineserver2
void Mineserver::Watcher_ServerListPing::operator()(Mineserver::Game::pointer_t game, Mineserver::Network_Client::pointer_t client, Mineserver::Network_Message::pointer_t message) const
{
  std::cout << "Server list ping watcher called!" << std::endl;

  boost::shared_ptr<Mineserver::Network_Message_Kick> response = boost::make_shared<Mineserver::Network_Message_Kick>();
  response->mid = 0xFF;
  response->reason = "Mineserver 2.0§0§32"; // description, current users: 0, max users: 32
  client->outgoing().push_back(response);
}
コード例 #2
0
ファイル: command.cpp プロジェクト: timatooth/mineserver2
void Mineserver::Command::execute(Mineserver::Game::pointer_t game, Mineserver::Game::clientList_t m_clients, Mineserver::Network_Client::pointer_t client)
{
  boost::shared_ptr<Mineserver::Game_Player> player = game->getPlayerForClient(client);
  typedef Mineserver::Game::clientList_t clientList_t;
  if (args[0] == "/say")
    
    {
      boost::shared_ptr<Mineserver::Network_Message_Chat> chatMessage = boost::make_shared<Mineserver::Network_Message_Chat>();
      chatMessage->mid = 0x03;
      chatMessage->message += "§5";
      chatMessage->message += "[Server]";
      for (std::vector<std::string>::iterator sayIt = args.begin() + 1; sayIt != args.end(); ++sayIt)
      {
        chatMessage->message += " " ;
        chatMessage->message += *sayIt;
      }
      
      for ( Mineserver::Game::clientList_t::iterator it = m_clients.begin(); it != m_clients.end(); ++it)
      {
        (*it)->outgoing().push_back(chatMessage);
      }

    } //end of /say server command

    //sends a 0xFF packet to all clients. Usage: /kickall [reason]
    else if (args[0] == "/kickall")
    {
      boost::shared_ptr<Network_Message_Kick> KickMessage = boost::make_shared<Mineserver::Network_Message_Kick>();
      KickMessage->mid = 0xFF;
      KickMessage->reason = "Everyone was kicked from the server!";
      //send the kick packet to all clients.
      for (clientList_t::iterator it = m_clients.begin(); it != m_clients.end(); ++it)
      {
        (*it)->outgoing().push_back(KickMessage);
      }

    } //end of /kickall [reason]

    //FIXME works except player spawns at original height.
    else if (args[0] == "/spawn")
    {
      // I should be using world->spawnX.y.z.
      std::cout << "Sending player: " << player->getName() << " from " << player->getPosition().x <<", " << player->getPosition().y <<", " << player->getPosition().z << " to 0,65,0 EntityId: " << player->getEid() << std::endl;
      Mineserver::World::pointer_t world = game->getWorld(0);
      boost::shared_ptr<Mineserver::Network_Message_PositionAndOrientation> TeleportToSpawnMessage = boost::make_shared<Mineserver::Network_Message_PositionAndOrientation>();
      TeleportToSpawnMessage->mid = 0x0D;
      player->getPosition().x = world->getSpawnPosition().x; //0 --defaults
      player->getPosition().y = world->getSpawnPosition().y; //61
      player->getPosition().z = world->getSpawnPosition().z; //0
      player->getPosition().stance = world->getSpawnPosition().y + 1.62;
      player->getPosition().yaw = 180.0;
      player->getPosition().pitch = 0;
      player->getPosition().onGround = false;
      TeleportToSpawnMessage->x = player->getPosition().x;
      TeleportToSpawnMessage->y = player->getPosition().y;
      TeleportToSpawnMessage->z = player->getPosition().z;
      TeleportToSpawnMessage->stance = player->getPosition().stance; //world->getSpawnPosition().y + 1.62;
      TeleportToSpawnMessage->yaw = player->getPosition().yaw;
      TeleportToSpawnMessage->pitch = player->getPosition().pitch;
      TeleportToSpawnMessage->onGround = player->getPosition().onGround;
      client->outgoing().push_back(TeleportToSpawnMessage);
      std::cout << "Sending Player is now at: " << player->getPosition().x <<", " << player->getPosition().y <<", " << player->getPosition().z << std::endl;

    }

    else if (args[0] == "/t" || args[0] == "/tell" || args[0] == "/msg")
    {
      std::string playername = args[1];
      std::string sender = player->getName();
      std::string message;
      for (std::vector<std::string>::iterator pmsgIt = args.begin() + 2; pmsgIt != args.end(); ++pmsgIt)
      {
        message += *pmsgIt;
        message += " ";
      }
      bool sentMessage = false;
      for (clientList_t::iterator playerIt = m_clients.begin(); playerIt != m_clients.end(); ++playerIt)
      {
        if (player->getName() == playername)
        {
          boost::shared_ptr<Mineserver::Network_Message_Chat> privateChatMessage = boost::make_shared<Mineserver::Network_Message_Chat>();
          privateChatMessage->mid = 0x03;
          privateChatMessage->message += sender;
          privateChatMessage->message += " -> ";
          privateChatMessage->message += message;
          (*playerIt)->outgoing().push_back(privateChatMessage);
          sentMessage = true;
          break;
        }

      }
      if (!sentMessage) {
        boost::shared_ptr<Mineserver::Network_Message_Chat> privateChatMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        privateChatMessageFail->mid = 0x03;
        privateChatMessageFail->message = "§cCould not find player: " + playername;
        client->outgoing().push_back(privateChatMessageFail);      }

    }// end of private message commands

    else if (args[0] == "/tpc" || args[0] == "/pos")
    {
      if (argc == 4) {

        int32_t tpX = atoi(args[1].c_str());
        int32_t tpY = atoi(args[2].c_str());
        int32_t tpZ = atoi(args[3].c_str());
        player->getPosition().x = tpX;
        player->getPosition().y = tpY;
        player->getPosition().z = tpZ;
        player->getPosition().stance = tpY + 1.62;
        player->getPosition().yaw = 180.0;
        player->getPosition().pitch = 0.0;
        player->getPosition().onGround = false;
        std::cout << "PositionP " << tpX << ", " << tpY << ", " << tpZ <<std::endl;
        boost::shared_ptr<Mineserver::Network_Message_PositionAndOrientation> tposTeleportMessage = boost::make_shared<Mineserver::Network_Message_PositionAndOrientation>();
        tposTeleportMessage->mid = 0x0D;
        tposTeleportMessage->x = player->getPosition().x;
        tposTeleportMessage->y = player->getPosition().y;
        tposTeleportMessage->z = player->getPosition().z;
        tposTeleportMessage->stance = player->getPosition().stance;
        tposTeleportMessage->yaw = player->getPosition().yaw;
        tposTeleportMessage->pitch = player->getPosition().pitch;
        tposTeleportMessage->onGround = player->getPosition().onGround;
        client->outgoing().push_back(tposTeleportMessage);
      }
      else
      {
        boost::shared_ptr<Mineserver::Network_Message_Chat> tposMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        tposMessageFail->mid = 0x03;
        tposMessageFail->message = "§cCorrect Usage: /tpc or /pos <x> <y> <z>";
        client->outgoing().push_back(tposMessageFail);
      }
    }

    else if (args[0] == "/s" || args[0] == "/tphere")
    {
      if (argc == 2)
      {
        std::string tpherePlayerName = args[1];
        bool foundPlayer;
        for (clientList_t::iterator tphereIt = m_clients.begin(); tphereIt != m_clients.end(); ++tphereIt)
        {
          if(game->getPlayerForClient(*tphereIt)->getName() == tpherePlayerName)
          {
            bool foundPlayer = true;
            boost::shared_ptr<Mineserver::Network_Message_PositionAndOrientation> tphereTeleportMessage = boost::make_shared<Mineserver::Network_Message_PositionAndOrientation>();
            tphereTeleportMessage->mid = 0x0D;
            //we have to convert the values to Big endian before transmitting.
            std::cout << "Tphere player: " << game->getPlayerForClient(*tphereIt)->getName() << " from: ("
              << game->getPlayerForClient(*tphereIt)->getPosition().x << ", " 
              << game->getPlayerForClient(*tphereIt)->getPosition().y << ", " 
              << game->getPlayerForClient(*tphereIt)->getPosition().z << ") To: (" 
              << game->getPlayerForClient(client)->getPosition().x << ", " 
              << game->getPlayerForClient(client)->getPosition().y << ", " 
              << game->getPlayerForClient(client)->getPosition().z << ") End" << std::endl;
            int32_t sX = game->getPlayerForClient(client)->getPosition().x;
            int32_t sY = game->getPlayerForClient(client)->getPosition().y;
            int32_t sZ = game->getPlayerForClient(client)->getPosition().z;
            tphereTeleportMessage->x = sX;
            tphereTeleportMessage->y = sY;
            tphereTeleportMessage->z = sZ;
            tphereTeleportMessage->stance = game->getPlayerForClient(client)->getPosition().y + 1.62;
            tphereTeleportMessage->yaw = game->getPlayerForClient(*tphereIt)->getPosition().yaw;
            tphereTeleportMessage->pitch = game->getPlayerForClient(*tphereIt)->getPosition().pitch;
            tphereTeleportMessage->onGround = game->getPlayerForClient(*tphereIt)->getPosition().onGround;
            (*tphereIt)->outgoing().push_back(tphereTeleportMessage);
          }
        }
        if (foundPlayer == false)
        {
          boost::shared_ptr<Mineserver::Network_Message_Chat> tphereTeleportMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
          tphereTeleportMessageFail->mid = 0x03;
          tphereTeleportMessageFail->message = "§cTphere: Could not find player: " + tpherePlayerName;
          client->outgoing().push_back(tphereTeleportMessageFail);
        }
      }
      else
      {
        boost::shared_ptr<Mineserver::Network_Message_Chat> tphereTeleportMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        tphereTeleportMessageFail->mid = 0x03;
        tphereTeleportMessageFail->message = "§cCorrect Usage: /s or /tphere <playername>";
        client->outgoing().push_back(tphereTeleportMessageFail);
      }
    }

    else if (args[0] == "/help")
    {
      std::vector<std::string> helpOptions;
      helpOptions.push_back("/spawn - Go to 0, 61 ,0");
      helpOptions.push_back("/kickall - Kick all players from the server");
      helpOptions.push_back("/t or /msg <playername> <message> - send a private message");
      helpOptions.push_back("/tp <player> - Teleport to a player");
      helpOptions.push_back("/say <message> - Broadcast a [Server] message");
      helpOptions.push_back("/time <day/night> - Change the world time. Affects all players");
      helpOptions.push_back("/tpc or /pos <x> <y> <z> - Teleport to exact coordinates");
      helpOptions.push_back("/list - list players online. You can also use TAB");
      helpOptions.push_back("/s or /tphere <player> - Teleport a player to you");
      helpOptions.push_back("/gamemode <0 or 1> - Change to Survival(0) or Creative(1)");
      for (std::vector<std::string>::iterator helpIt = helpOptions.begin(); helpIt != helpOptions.end(); ++helpIt) {
        boost::shared_ptr<Mineserver::Network_Message_Chat> chatMessageHelp = boost::make_shared<Mineserver::Network_Message_Chat>();
        chatMessageHelp->mid = 0x03;
        chatMessageHelp->message += "§c";
        chatMessageHelp->message += *helpIt;
        client->outgoing().push_back(chatMessageHelp);
      }
    }
    //teleporting works :)
    else if (args[0] == "/tp")
    {
      if(argc != 2)
      {
        boost::shared_ptr<Mineserver::Network_Message_Chat> tpMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        tpMessageFail->mid = 0x03;
        tpMessageFail->message = "§cCorrect Usage: /tp <player>";
        client->outgoing().push_back(tpMessageFail);
      }
      else
      {
        std::string teleportToPlayer = args[1];
        bool playerExists = false;
        //search for the player...
        for (clientList_t::iterator teleportPlayerToIt = m_clients.begin(); teleportPlayerToIt != m_clients.end(); ++teleportPlayerToIt)
        {
          Mineserver::Game_Player::pointer_t destplayer = game->getPlayerForClient((*teleportPlayerToIt));
          if (destplayer->getName() == teleportToPlayer)
          {
            playerExists = true;
            boost::shared_ptr<Mineserver::Network_Message_PositionAndOrientation> teleportToPlayerMessage = boost::make_shared<Mineserver::Network_Message_PositionAndOrientation>();
            teleportToPlayerMessage->mid = 0x0D;
            teleportToPlayerMessage->x = destplayer->getPosition().x;
            teleportToPlayerMessage->y = destplayer->getPosition().y;
            teleportToPlayerMessage->z = destplayer->getPosition().z;
            teleportToPlayerMessage->stance = destplayer->getPosition().stance;
            teleportToPlayerMessage->yaw = destplayer->getPosition().yaw;
            teleportToPlayerMessage->pitch = destplayer->getPosition().pitch;
            teleportToPlayerMessage->onGround = destplayer->getPosition().onGround;
            client->outgoing().push_back(teleportToPlayerMessage);
            break;
          }
        }
        if (!playerExists)
        {
          boost::shared_ptr<Mineserver::Network_Message_Chat> teleportChatMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
          teleportChatMessageFail->mid = 0x03;
          teleportChatMessageFail->message = "Could not find player: " + teleportToPlayer;
          client->outgoing().push_back(teleportChatMessageFail);
        }
      }

    }

    else if (args[0] == "/time" && argc == 2)
    {
      int64_t tickTime;
      if (args[1] == "day") {
        tickTime = 6000; // noon
      }
      else if (args[1] == "night") {
        tickTime = 18000; //night.
      }
      else {
        boost::shared_ptr<Mineserver::Network_Message_Chat> timeChangeMessageFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        timeChangeMessageFail->mid = 0x03;
        timeChangeMessageFail->message = "§cCorrect Usage: /time <day/night>";
        client->outgoing().push_back(timeChangeMessageFail);
      }

      boost::shared_ptr<Mineserver::Network_Message_TimeUpdate> timeUpdateMessage = boost::make_shared<Mineserver::Network_Message_TimeUpdate>();
      timeUpdateMessage->mid = 0x04;
      timeUpdateMessage->time = tickTime;
      for (clientList_t::iterator timeIt = m_clients.begin(); timeIt != m_clients.end(); ++timeIt)
      {
        (*timeIt)->outgoing().push_back(timeUpdateMessage);
      }

    }

    else if (args[0] == "/list")
    {
      for (clientList_t::iterator listIt = m_clients.begin(); listIt != m_clients.end(); ++listIt)
      {
        boost::shared_ptr<Mineserver::Network_Message_Chat> listChatMessage = boost::make_shared<Mineserver::Network_Message_Chat>();
        listChatMessage->mid = 0x03;
        listChatMessage->message = game->getPlayerForClient(*listIt)->getName();
        for (clientList_t::iterator it = m_clients.begin(); it != m_clients.end(); ++it)
        {
          (*it)->outgoing().push_back(listChatMessage);
        }
      }
    }

    else if (args[0] == "/gamemode")
    {
      if (argc == 2)
      {
        uint8_t gameMode;
        if (args[1] == "0") {
          gameMode = 0;
        }
        else {
          gameMode = 1;
        }

        boost::shared_ptr<Mineserver::Network_Message_NewState> gamemodeChangeMessage = boost::make_shared<Mineserver::Network_Message_NewState>();
        gamemodeChangeMessage->mid = 0x46;
        gamemodeChangeMessage->reason = 3;
        gamemodeChangeMessage->mode = gameMode;
        client->outgoing().push_back(gamemodeChangeMessage);
      }

      else
      {
        boost::shared_ptr<Mineserver::Network_Message_Chat> gamemodeChangeFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        gamemodeChangeFail->mid = 0x03;
        gamemodeChangeFail->message = "§cCorrect Usage: /gamemode <0/1>";
        client->outgoing().push_back(gamemodeChangeFail);
      }

    } // end of if /gamemode <mode>

    else if (args[0] == "/chunkprepare")
    {
      if (argc == 4)
      {
        int32_t cX = atoi(args[1].c_str());
        int32_t cZ = atoi(args[2].c_str());
        bool mode;
        if (args[3] == "true")
        {
          mode = true;
        }
        else
        {
          mode = false;
        }
        boost::shared_ptr<Mineserver::Network_Message_ChunkPrepare> chunkPrepareMessage = boost::make_shared<Mineserver::Network_Message_ChunkPrepare>();
        chunkPrepareMessage->mid = 0x32;
        chunkPrepareMessage->x = cX;
        chunkPrepareMessage->z = cZ;
        chunkPrepareMessage->mode = mode;
        for (clientList_t::iterator chunkIt = m_clients.begin(); chunkIt != m_clients.end(); ++chunkIt)
        {
          (*chunkIt)->outgoing().push_back(chunkPrepareMessage);
        }
      }
      else
      {
        boost::shared_ptr<Mineserver::Network_Message_Chat> chunkPrepareFail = boost::make_shared<Mineserver::Network_Message_Chat>();
        chunkPrepareFail->mid = 0x03;
        chunkPrepareFail->message = "§cCorrect Usage: /chunkprepare <x> <z> <true/false>";
        client->outgoing().push_back(chunkPrepareFail);
      }
    }
    else if (args[0] == "/chunkdata")
    {
      if (argc == 3)
      {
        int32_t cX = atoi(args[1].c_str());
        int32_t cZ = atoi(args[2].c_str());
        boost::shared_ptr<Mineserver::Network_Message_Chunk> chunkDataMessage = boost::make_shared<Mineserver::Network_Message_Chunk>();
        Mineserver::World::pointer_t world = game->getWorld(0);

        chunkDataMessage->mid = 0x33;
        chunkDataMessage->posX = cX * 16;
        chunkDataMessage->posY = 0;
        chunkDataMessage->posZ = cZ * 16;
        chunkDataMessage->sizeX = 15;
        chunkDataMessage->sizeY = 127;
        chunkDataMessage->sizeZ = 15;
        chunkDataMessage->chunk = world->generateChunk(cX, cZ);
        for (clientList_t::iterator chunkIt = m_clients.begin(); chunkIt != m_clients.end(); ++chunkIt)
        {
          (*chunkIt)->outgoing().push_back(chunkDataMessage);
        }
      }
      else {
        {
          boost::shared_ptr<Mineserver::Network_Message_Chat> chunkDataFail = boost::make_shared<Mineserver::Network_Message_Chat>();
          chunkDataFail->mid = 0x03;
          chunkDataFail->message = "§cCorrect Usage: /chunkdata <x> <z>";
          client->outgoing().push_back(chunkDataFail);
        }
      }

    }

    else if (args[0] == "/chunk")
    {
      Mineserver::Game_Player::pointer_t chunkplayer = player;
      boost::shared_ptr<Mineserver::Network_Message_Chat> chunkMessage = boost::make_shared<Mineserver::Network_Message_Chat>();
      chunkMessage->mid = 0x03;
      std::string chunkx;
      std::stringstream outx;
      outx << std::floor(chunkplayer->getPosition().x / 16);
      chunkx = outx.str();
      std::string chunkz;
      std::stringstream outz;
      outz << std::floor(chunkplayer->getPosition().z / 16);
      chunkz = outz.str();
      chunkMessage->message = "§5You are in chunk: " + chunkx + ", " + chunkz;

      client->outgoing().push_back(chunkMessage);
    }
    
    else if (args[0] == "/save")
    {
      //save a chunk
      Mineserver::Game_Player::pointer_t saverplayer = game->getPlayerForClient((client));
      Mineserver::World::pointer_t world = game->getWorld(0);
      int tX = std::floor(player->getPosition().x / 16);
      int tZ = std::floor(player->getPosition().z / 16);
      Mineserver::World_Chunk::pointer_t chunk = world->getChunk(tX,tZ);
      std::cout << "\nsizeof" << sizeof *chunk << std::endl;
      std::string fileName = "c.";
      std::stringstream ssX;
      std::stringstream ssZ;
      ssX << tX;
      ssZ << tZ;
      fileName.append(ssX.str());
      fileName.append(".");
      fileName.append(ssZ.str());
      fileName.append(".cho");
      char *fileName_c = (char*)fileName.c_str();
      std::ofstream file(fileName_c, std::ios::binary);
      file.write((char*)&chunk, sizeof *chunk);
      file.close();

    }
    
    else if (args[0] == "/load")
    {
      Mineserver::Game_Player::pointer_t saverplayer = game->getPlayerForClient((client));
      Mineserver::World::pointer_t world = game->getWorld(0);
      int tX = std::floor(player->getPosition().x / 16);
      int tZ = std::floor(player->getPosition().z / 16);
      Mineserver::World_Chunk::pointer_t chunk = world->getChunk(tX,tZ);
      std::cout << "\nsizeof" << sizeof *chunk << std::endl;
      std::string fileName = "c.";
      std::stringstream ssX;
      std::stringstream ssZ;
      ssX << tX;
      ssZ << tZ;
      fileName.append(ssX.str());
      fileName.append(".");
      fileName.append(ssZ.str());
      fileName.append(".cho");
      char *fileName_c = (char*)fileName.c_str();
      std::ifstream file(fileName_c, std::ios::binary);
      std::cout << "\nAttempting to read: " << fileName_c << std::endl; 
      file.read((char*)&chunk, sizeof &chunk);
      //chunk prepare message -false - unload old
      boost::shared_ptr<Mineserver::Network_Message_ChunkPrepare> chunkPrepareUnloadMessage = boost::make_shared<Mineserver::Network_Message_ChunkPrepare>();
      chunkPrepareUnloadMessage->mid = 0x32;
      chunkPrepareUnloadMessage->x = tX;
      chunkPrepareUnloadMessage->z = tZ;
      chunkPrepareUnloadMessage->mode = 0;
      for (clientList_t::iterator chunkIt = m_clients.begin(); chunkIt != m_clients.end(); ++chunkIt)
      {
        (*chunkIt)->outgoing().push_back(chunkPrepareUnloadMessage);
      }
      //chunk prepare message -true - prepare new...
      boost::shared_ptr<Mineserver::Network_Message_ChunkPrepare> chunkPrepareReloadMessage = boost::make_shared<Mineserver::Network_Message_ChunkPrepare>();
      chunkPrepareReloadMessage->mid = 0x32;
      chunkPrepareReloadMessage->x = tX;
      chunkPrepareReloadMessage->z = tZ;
      chunkPrepareReloadMessage->mode = 1;
      for (clientList_t::iterator chunkIt = m_clients.begin(); chunkIt != m_clients.end(); ++chunkIt)
      {
        (*chunkIt)->outgoing().push_back(chunkPrepareReloadMessage);
      }
      //send the data...
      boost::shared_ptr<Mineserver::Network_Message_Chunk> chunkDataMessage = boost::make_shared<Mineserver::Network_Message_Chunk>();
      chunkDataMessage->mid = 0x33;
      chunkDataMessage->posX = tX * 16;
      chunkDataMessage->posY = 0;
      chunkDataMessage->posZ = tZ * 16;
      chunkDataMessage->sizeX = 15;
      chunkDataMessage->sizeY = 127;
      chunkDataMessage->sizeZ = 15;
      chunkDataMessage->chunk = chunk;
      for (clientList_t::iterator chunkIt = m_clients.begin(); chunkIt != m_clients.end(); ++chunkIt)
      {
        (*chunkIt)->outgoing().push_back(chunkDataMessage);
      }
    }
    
    else
    {
      boost::shared_ptr<Mineserver::Network_Message_Chat> chatMessageError = boost::make_shared<Mineserver::Network_Message_Chat>();
      chatMessageError->mid = 0x03;
      chatMessageError->message = "§cUnknown command. Try /help for a list.";
      client->outgoing().push_back(chatMessageError);
    }

}
コード例 #3
0
ファイル: game.cpp プロジェクト: MitchellMarx/mineserver2
bool is_dead(Mineserver::Network_Client::pointer_t client) {
  return client->alive() == false;
}
コード例 #4
0
ファイル: login.cpp プロジェクト: MitchellMarx/mineserver2
void Mineserver::Watcher_Login::operator()(Mineserver::Game::pointer_t game, Mineserver::Network_Client::pointer_t client, Mineserver::Network_Message::pointer_t message) const
{
  std::cout << "Login watcher called!" << std::endl;
  const Mineserver::Network_Message_Login* msg = reinterpret_cast<Mineserver::Network_Message_Login*>(&(*message));

  Mineserver::Game_Player::pointer_t player(new Mineserver::Game_Player);
  player->setName(msg->username);

  std::cout << "Player login v." << msg->version << ": " << msg->username << std::endl;

  game->addPlayer(player);
  game->associateClient(client, player);

  boost::shared_ptr<Mineserver::Network_Message_Login> loginMessage = boost::make_shared<Mineserver::Network_Message_Login>();
  loginMessage->mid = 0x01;
  loginMessage->version = 1;
  loginMessage->seed = 1;
  loginMessage->mode = 0;
  loginMessage->dimension = 0;
  loginMessage->difficulty = 2;
  loginMessage->worldHeight = 128;
  loginMessage->maxPlayers = 128;
  client->outgoing().push_back(loginMessage);

  for (int x = -5; x <= 5; ++x) {
    for (int z = -5; z <= 5; ++z) {
      boost::shared_ptr<Mineserver::Network_Message_ChunkPrepare> chunkPrepareMessage = boost::make_shared<Mineserver::Network_Message_ChunkPrepare>();
      chunkPrepareMessage->mid = 0x32;
      chunkPrepareMessage->x = x;
      chunkPrepareMessage->z = z;
      chunkPrepareMessage->mode = 1;
      client->outgoing().push_back(chunkPrepareMessage);
    }
  }

  Mineserver::World::pointer_t world = game->getWorld(0);

  for (int x = -5; x <= 5; ++x) {
    for (int z = -5; z <= 5; ++z) {
      boost::shared_ptr<Mineserver::Network_Message_Chunk> chunkMessage = boost::make_shared<Mineserver::Network_Message_Chunk>();
      chunkMessage->mid = 0x33;
      chunkMessage->posX = x;
      chunkMessage->posY = 0;
      chunkMessage->posZ = z;
      chunkMessage->sizeX = 15;
      chunkMessage->sizeY = 127;
      chunkMessage->sizeZ = 15;
      chunkMessage->chunk = world->generateChunk(x, z);
      client->outgoing().push_back(chunkMessage);
    }
  }

  boost::shared_ptr<Mineserver::Network_Message_SpawnPosition> spawnPositionMessage = boost::make_shared<Mineserver::Network_Message_SpawnPosition>();
  spawnPositionMessage->mid = 0x06;
  spawnPositionMessage->x = 0;
  spawnPositionMessage->y = 100;
  spawnPositionMessage->z = 0;
  client->outgoing().push_back(spawnPositionMessage);

  boost::shared_ptr<Mineserver::Network_Message_PositionLook> positionLookMessage = boost::make_shared<Mineserver::Network_Message_PositionLook>();
  positionLookMessage->mid = 0x0D;
  positionLookMessage->x = 0;
  positionLookMessage->y = 100;
  positionLookMessage->z = 0;
  positionLookMessage->stance = 100;
  positionLookMessage->yaw = 0;
  positionLookMessage->pitch = 0;
  positionLookMessage->onGround = 0;
  client->outgoing().push_back(positionLookMessage);
}