forked from MagicBane/Server
MagicBot
2 years ago
4 changed files with 89 additions and 17 deletions
@ -0,0 +1,88 @@
@@ -0,0 +1,88 @@
|
||||
// • ▌ ▄ ·. ▄▄▄· ▄▄ • ▪ ▄▄· ▄▄▄▄· ▄▄▄· ▐▄▄▄ ▄▄▄ .
|
||||
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
|
||||
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
|
||||
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
|
||||
// ▀▀ █▪▀▀▀ ▀ ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀ ▀ ▀ ▀▀ █▪ ▀▀▀
|
||||
// Magicbane Emulator Project © 2013 - 2022
|
||||
// www.magicbane.com
|
||||
|
||||
package engine.net.client.handlers; |
||||
|
||||
import engine.Enum; |
||||
import engine.Enum.DispatchChannel; |
||||
import engine.exception.MsgSendException; |
||||
import engine.gameManager.BuildingManager; |
||||
import engine.gameManager.ChatManager; |
||||
import engine.gameManager.DbManager; |
||||
import engine.gameManager.SessionManager; |
||||
import engine.net.Dispatch; |
||||
import engine.net.DispatchMessage; |
||||
import engine.net.client.ClientConnection; |
||||
import engine.net.client.msg.ArcMineWindowChangeMsg; |
||||
import engine.net.client.msg.ClientNetMsg; |
||||
import engine.net.client.msg.KeepAliveServerClientMsg; |
||||
import engine.objects.Building; |
||||
import engine.objects.Guild; |
||||
import engine.objects.GuildStatusController; |
||||
import engine.objects.PlayerCharacter; |
||||
import engine.server.MBServerStatics; |
||||
import org.pmw.tinylog.Logger; |
||||
|
||||
/* |
||||
* @Author: |
||||
* @Summary: Processes requests to change a mine's opendate |
||||
*/ |
||||
|
||||
public class MineWindowChangeHandler extends AbstractClientMsgHandler { |
||||
|
||||
public MineWindowChangeHandler() { |
||||
super(ArcMineWindowChangeMsg.class); |
||||
} |
||||
|
||||
@Override |
||||
protected boolean _handleNetMsg(ClientNetMsg baseMsg, ClientConnection origin) throws MsgSendException { |
||||
|
||||
PlayerCharacter playerCharacter = SessionManager.getPlayerCharacter(origin); |
||||
ArcMineWindowChangeMsg mineWindowChangeMsg = (ArcMineWindowChangeMsg)baseMsg; |
||||
|
||||
if (playerCharacter == null) |
||||
return true; |
||||
|
||||
Building treeOfLife = BuildingManager.getBuildingFromCache(mineWindowChangeMsg.getBuildingID()); |
||||
|
||||
if (treeOfLife == null) |
||||
return true; |
||||
|
||||
if (treeOfLife.getBlueprintUUID() == 0) |
||||
return true; |
||||
|
||||
if (treeOfLife.getBlueprint().getBuildingGroup() != Enum.BuildingGroup.TOL) |
||||
return true; |
||||
|
||||
Guild mineGuild = treeOfLife.getGuild(); |
||||
if (mineGuild == null) |
||||
return true; |
||||
|
||||
if (!Guild.sameGuild(mineGuild, playerCharacter.getGuild())) |
||||
return true; //must be same guild
|
||||
|
||||
if (GuildStatusController.isInnerCouncil(playerCharacter.getGuildStatus()) == false) // is this only GL?
|
||||
return true; |
||||
|
||||
//hodge podge sanity check to make sure they don't set it before early window and is not set at late window.
|
||||
if (mineWindowChangeMsg.getTime() < MBServerStatics.MINE_EARLY_WINDOW && |
||||
mineWindowChangeMsg.getTime() != MBServerStatics.MINE_LATE_WINDOW) |
||||
return true; //invalid mine time, must be in range
|
||||
|
||||
if (!DbManager.GuildQueries.UPDATE_MINETIME(mineGuild.getObjectUUID(), mineWindowChangeMsg.getTime())) { |
||||
Logger.error("MineWindowChange", "Failed to update mine time for guild " + mineGuild.getObjectUUID()); |
||||
ChatManager.chatGuildError(playerCharacter, "Failed to update the mine time"); |
||||
return true; |
||||
} |
||||
mineGuild.setMineTime(mineWindowChangeMsg.getTime()); |
||||
ChatManager.chatGuildInfo(playerCharacter, "Mine time updated."); |
||||
|
||||
return true; |
||||
} |
||||
|
||||
} |
Loading…
Reference in new issue