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