forked from MagicBane/Server
Handler created for SendSummonsMsg
This commit is contained in:
@@ -123,11 +123,8 @@ public class ClientMessagePump implements NetMsgHandler {
|
||||
case ARCREQUESTTRADEBUSY:
|
||||
TradeManager.invalidTradeRequest((InvalidTradeRequestMsg) msg);
|
||||
break;
|
||||
case POWERTARGNAME:
|
||||
PowersManager.summon((SendSummonsRequestMsg) msg, origin);
|
||||
break;
|
||||
case ARCSUMMON:
|
||||
PowersManager.recvSummon((RecvSummonsRequestMsg) msg, origin);
|
||||
PowersManager.recvSummon((RecvSummonsMsg) msg, origin);
|
||||
break;
|
||||
case CHANNELMUTE:
|
||||
break;
|
||||
|
||||
@@ -44,7 +44,7 @@ public enum Protocol {
|
||||
ARCREQUESTTRADEBUSY(0xD4BAB4DF, InvalidTradeRequestMsg.class, null), // Attempt trade with someone who is already trading
|
||||
ARCSERVERSTATUS(0x87BA4462, null, null), //Update Server Status
|
||||
ARCSIEGESPIRE(0x36A49BC6, ArcSiegeSpireMsg.class, ArcSiegeSpireMsgHandler.class), // Activate/Deactivate Spires
|
||||
ARCSUMMON(0xFD816A0A, RecvSummonsRequestMsg.class, null), // Suspect Recv Summons Request
|
||||
ARCSUMMON(0xFD816A0A, RecvSummonsMsg.class, null), // Suspect Recv Summons Request
|
||||
ARCTRACKINGLIST(0xC89CF08B, TrackWindowMsg.class, TrackWindowMsgHandler.class), //Request/Send Track window
|
||||
ARCTRACKOBJECT(0x609B6BA2, TrackArrowMsg.class, null), //Send Track Arrow
|
||||
ARCUNTRAINABILITY(0x548DBF83, RefineMsg.class, RefineMsgHandler.class), //Refine
|
||||
@@ -161,7 +161,7 @@ public enum Protocol {
|
||||
POWERACTION(0xA0B27EEB, ApplyEffectMsg.class, null), // Apply Effect, add to effects icons
|
||||
POWERACTIONDD(0xD43052F8, ModifyHealthMsg.class, null), //Modify Health/Mana/Stamina using power
|
||||
POWERACTIONDDDIE(0xC27D446B, null, null), //Modify Health/Mana/Stamina using power and kill target
|
||||
POWERTARGNAME(0x5A807CCE, SendSummonsRequestMsg.class, null), // Send Summons Request
|
||||
POWERTARGNAME(0x5A807CCE, SendSummonsMsg.class, SendSummonsMsgHandler.class), // Send Summons Request
|
||||
RAISEATTR(0x5EEB65E0, ModifyStatMsg.class, ModifyStatMsgHandler.class), // Modify Stat
|
||||
RANDOM(0xAC5D0135, RandomMsg.class, RandomMsgHandler.class), //RequestSend random roll
|
||||
READYTOENTER(0x490E4FE0, EnterWorldReceivedMsg.class, null), //Client Ack Receive Enter World
|
||||
|
||||
@@ -0,0 +1,90 @@
|
||||
// • ▌ ▄ ·. ▄▄▄· ▄▄ • ▪ ▄▄· ▄▄▄▄· ▄▄▄· ▐▄▄▄ ▄▄▄ .
|
||||
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
|
||||
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
|
||||
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
|
||||
// ▀▀ █▪▀▀▀ ▀ ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀ ▀ ▀ ▀▀ █▪ ▀▀▀
|
||||
// Magicbane Emulator Project © 2013 - 2022
|
||||
// www.magicbane.com
|
||||
|
||||
package engine.net.client.handlers;
|
||||
|
||||
import engine.exception.MsgSendException;
|
||||
import engine.gameManager.ChatManager;
|
||||
import engine.gameManager.ConfigManager;
|
||||
import engine.gameManager.SessionManager;
|
||||
import engine.net.client.ClientConnection;
|
||||
import engine.net.client.msg.ClientNetMsg;
|
||||
import engine.net.client.msg.PerformActionMsg;
|
||||
import engine.net.client.msg.SendSummonsMsg;
|
||||
import engine.objects.PlayerCharacter;
|
||||
import engine.server.MBServerStatics;
|
||||
|
||||
import static engine.gameManager.PowersManager.*;
|
||||
|
||||
public class SendSummonsMsgHandler extends AbstractClientMsgHandler {
|
||||
|
||||
public SendSummonsMsgHandler() {
|
||||
super(SendSummonsMsg.class);
|
||||
}
|
||||
|
||||
@Override
|
||||
protected boolean _handleNetMsg(ClientNetMsg baseMsg, ClientConnection origin) throws MsgSendException {
|
||||
|
||||
PlayerCharacter playerCharacter = origin.getPlayerCharacter();
|
||||
|
||||
// Member variable declaration
|
||||
|
||||
SendSummonsMsg msg;
|
||||
|
||||
// Member variable assignment
|
||||
|
||||
msg = (SendSummonsMsg) baseMsg;
|
||||
|
||||
if (playerCharacter == null)
|
||||
return true;
|
||||
|
||||
PlayerCharacter target = SessionManager
|
||||
.getPlayerCharacterByLowerCaseName(msg.getTargetName());
|
||||
|
||||
if (target == null || target.equals(playerCharacter) || target.isCombat()) {
|
||||
|
||||
if (target == null) // Player not found. Send not found message
|
||||
ChatManager.chatInfoError(playerCharacter,
|
||||
"Cannot find that player to summon.");
|
||||
else if (target.isCombat())
|
||||
ChatManager.chatInfoError(playerCharacter,
|
||||
"Cannot summon player in combat.");
|
||||
|
||||
// else trying to summon self, just fail
|
||||
|
||||
// recycle summon
|
||||
sendRecyclePower(msg.getPowerToken(), origin);
|
||||
|
||||
// TODO: client already subtracted 200 mana.. need to correct it
|
||||
// end cast
|
||||
PerformActionMsg pam = new PerformActionMsg(msg.getPowerToken(),
|
||||
msg.getTrains(), msg.getSourceType(), msg.getSourceID(), 0,
|
||||
0, 0f, 0f, 0f, 1, 0);
|
||||
sendPowerMsg(playerCharacter, 2, pam);
|
||||
|
||||
return true;
|
||||
}
|
||||
if (ConfigManager.MB_RULESET.getValue() == "LORE") {
|
||||
if (playerCharacter.guild.getGuildType().equals(target.guild.getGuildType()) == false) {
|
||||
ChatManager.chatInfoError(playerCharacter,
|
||||
"Cannot summon player outside your charter.");
|
||||
return true;
|
||||
}
|
||||
}
|
||||
PerformActionMsg pam = new PerformActionMsg(msg.getPowerToken(), msg
|
||||
.getTrains(), msg.getSourceType(), msg.getSourceID(), target
|
||||
.getObjectType().ordinal(), target.getObjectUUID(), 0f, 0f, 0f, 1, 0);
|
||||
|
||||
// Client removes 200 mana on summon use.. so don't send message to self
|
||||
target.addSummoner(playerCharacter.getObjectUUID(), System.currentTimeMillis() + MBServerStatics.FOURTYFIVE_SECONDS);
|
||||
usePower(pam, origin, false);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
}
|
||||
+3
-3
@@ -15,7 +15,7 @@ import engine.net.ByteBufferReader;
|
||||
import engine.net.ByteBufferWriter;
|
||||
import engine.net.client.Protocol;
|
||||
|
||||
public class RecvSummonsRequestMsg extends ClientNetMsg {
|
||||
public class RecvSummonsMsg extends ClientNetMsg {
|
||||
|
||||
private int sourceType;
|
||||
private int sourceID;
|
||||
@@ -26,7 +26,7 @@ public class RecvSummonsRequestMsg extends ClientNetMsg {
|
||||
/**
|
||||
* This is the general purpose constructor.
|
||||
*/
|
||||
public RecvSummonsRequestMsg(int sourceType, int sourceID, String sourceName, String locationName, boolean accepted) {
|
||||
public RecvSummonsMsg(int sourceType, int sourceID, String sourceName, String locationName, boolean accepted) {
|
||||
super(Protocol.ARCSUMMON);
|
||||
this.sourceType = sourceType;
|
||||
this.sourceID = sourceID;
|
||||
@@ -41,7 +41,7 @@ public class RecvSummonsRequestMsg extends ClientNetMsg {
|
||||
* past the limit) then this constructor Throws that Exception to the
|
||||
* caller.
|
||||
*/
|
||||
public RecvSummonsRequestMsg(AbstractConnection origin, ByteBufferReader reader) {
|
||||
public RecvSummonsMsg(AbstractConnection origin, ByteBufferReader reader) {
|
||||
super(Protocol.ARCSUMMON, origin, reader);
|
||||
}
|
||||
|
||||
+3
-3
@@ -15,7 +15,7 @@ import engine.net.ByteBufferReader;
|
||||
import engine.net.ByteBufferWriter;
|
||||
import engine.net.client.Protocol;
|
||||
|
||||
public class SendSummonsRequestMsg extends ClientNetMsg {
|
||||
public class SendSummonsMsg extends ClientNetMsg {
|
||||
|
||||
private int powerToken;
|
||||
private int sourceType;
|
||||
@@ -26,7 +26,7 @@ public class SendSummonsRequestMsg extends ClientNetMsg {
|
||||
/**
|
||||
* This is the general purpose constructor.
|
||||
*/
|
||||
public SendSummonsRequestMsg() {
|
||||
public SendSummonsMsg() {
|
||||
super(Protocol.POWERTARGNAME);
|
||||
}
|
||||
|
||||
@@ -36,7 +36,7 @@ public class SendSummonsRequestMsg extends ClientNetMsg {
|
||||
* past the limit) then this constructor Throws that Exception to the
|
||||
* caller.
|
||||
*/
|
||||
public SendSummonsRequestMsg(AbstractConnection origin, ByteBufferReader reader) {
|
||||
public SendSummonsMsg(AbstractConnection origin, ByteBufferReader reader) {
|
||||
super(Protocol.POWERTARGNAME, origin, reader);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user