forked from MagicBane/Server
				
			
				 4 changed files with 89 additions and 17 deletions
			
			
		@ -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