forked from MagicBane/Server
				
			
				 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