forked from MagicBane/Server
Compare commits
178 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| f0bef72fde | |||
| 450ae2ec82 | |||
| 76eed79b0a | |||
| f73ed17c05 | |||
| b049d21aff | |||
| f6cce5ee1f | |||
| 8038c2ebe2 | |||
| 9f51b9af57 | |||
| cbc75bf9d7 | |||
| 0ecfa546cd | |||
| b89fb0803d | |||
| 11005d58a7 | |||
| b0c6239314 | |||
| 67f66155e9 | |||
| 7fbae12e99 | |||
| 65580c0a47 | |||
| 236afe4cc6 | |||
| c23a6af28f | |||
| 2535106d2c | |||
| d8379ae5a9 | |||
| 9f13f5fc5d | |||
| 884cb30ebd | |||
| 30488e5da6 | |||
| b7e798a950 | |||
| e999ca3f68 | |||
| 039638c0d8 | |||
| f282504896 | |||
| 0062936ac6 | |||
| 19c41daa86 | |||
| d860b16cfd | |||
| e3b42a8ad9 | |||
| 20bd7a82af | |||
| e607eb8220 | |||
| 38ca49d1a5 | |||
| a21bdfe031 | |||
| f95832b87c | |||
| feff9b3540 | |||
| 78118aa08c | |||
| 3539372437 | |||
| 7c498625bd | |||
| e379016123 | |||
| afa68b840c | |||
| 1926deb7f9 | |||
| 25c1f34c23 | |||
| d0e04e53ad | |||
| e475fb5cc9 | |||
| f72f632cd8 | |||
| 02ea27fc6f | |||
| 5d338bb87c | |||
| f9f08c2886 | |||
| dcc139043d | |||
| 520219404c | |||
| f97991f00d | |||
| 7b7e1c5337 | |||
| 6e66659940 | |||
| 3d83baed78 | |||
| 049b27da96 | |||
| 6bcbe0f633 | |||
| 8c44e39275 | |||
| e36ab1f5d2 | |||
| 865c775f41 | |||
| 198778ba2d | |||
| 215aabdc5f | |||
| 8d92c8be37 | |||
| 93b3ce07f0 | |||
| f9b7c8b851 | |||
| b3cf72abdc | |||
| 65fddd06a9 | |||
| 41f4a8ff58 | |||
| a13d5018b9 | |||
| 2ac3ce5bc8 | |||
| 85514987e7 | |||
| c9eb07b5ba | |||
| 7201b61498 | |||
| 55b3161900 | |||
| 9d5c4424a1 | |||
| d507ba2339 | |||
| 4ec5103454 | |||
| 3e09cd415e | |||
| 1098265145 | |||
| df7a106237 | |||
| 00b38970a1 | |||
| c1004e5817 | |||
| 13e9738345 | |||
| 1a7c1e2544 | |||
| ff082487b5 | |||
| 14cac0d892 | |||
| a8347e0b53 | |||
| a73c3453ea | |||
| a64932b2c9 | |||
| 685297171c | |||
| 2e3e403165 | |||
| fbd910ef50 | |||
| 30129d161f | |||
| a6510af56d | |||
| 9830920635 | |||
| 93025b72cd | |||
| 22639baa4c | |||
| 1aba8dfb11 | |||
| 8b4eb96262 | |||
| cafe6cd2fe | |||
| da6140f6f4 | |||
| 3fc68ce2ff | |||
| 5e8927245b | |||
| 75de1b3ae8 | |||
| 6743114d19 | |||
| 28cca67cb3 | |||
| bad7c6e798 | |||
| ecd3b38d3a | |||
| 8f09f16603 | |||
| 80812cb402 | |||
| 66fbf7aee6 | |||
| a92c603ab2 | |||
| 365438370d | |||
| a40b8fc915 | |||
| 5d92c1c86d | |||
| c526fd8847 | |||
| cd767dc68c | |||
| e21ebc75ee | |||
| 931eaaae4a | |||
| 4d487e6bf0 | |||
| 6c45a6573a | |||
| 45b0dda7d9 | |||
| caf3bc7470 | |||
| 5259b801f7 | |||
| 77e6d0db75 | |||
| b2d7e5ec1e | |||
| 15bc99d216 | |||
| 63c6e2abd7 | |||
| 8ab97a1b36 | |||
| d1aa581879 | |||
| 5f56143c5e | |||
| 1a2b558ac3 | |||
| 4f4ff74bf1 | |||
| ded3b08080 | |||
| 14a29c8612 | |||
| e66e430d30 | |||
| c833f560c1 | |||
| 454c721842 | |||
| 26eda324dc | |||
| 16951d36a2 | |||
| e1d36125d2 | |||
| 7a3c259d2f | |||
| aa5fb2a2c5 | |||
| a92cc6506c | |||
| 3971548142 | |||
| d94de771bf | |||
| c5f47ffcd4 | |||
| b336235ad7 | |||
| eea07309aa | |||
| 5529170036 | |||
| 3d745e93b6 | |||
| 019082bec7 | |||
| 855cceea70 | |||
| 487eae85e1 | |||
| 5d188e61c0 | |||
| 546c335198 | |||
| aaecc5eda2 | |||
| d13e939ddd | |||
| afea79474e | |||
| 05f555b5b5 | |||
| 85931b6dc2 | |||
| 9f0c7f6a76 | |||
| 022c06c803 | |||
| 1b72e7d6b7 | |||
| 666ac6df5b | |||
| 36481a53d9 | |||
| 5a9901d775 | |||
| b3a24d0158 | |||
| 8890826070 | |||
| daa84a1fef | |||
| a4bd47f001 | |||
| d031f1be01 | |||
| a48abc59ce | |||
| 878f05c323 | |||
| d462711d25 | |||
| 40a0120a28 | |||
| ac812eaeae |
+14
-10
@@ -9,15 +9,13 @@
|
|||||||
package engine;
|
package engine;
|
||||||
|
|
||||||
import ch.claude_martin.enumbitset.EnumBitSetHelper;
|
import ch.claude_martin.enumbitset.EnumBitSetHelper;
|
||||||
|
import engine.gameManager.BuildingManager;
|
||||||
import engine.gameManager.ConfigManager;
|
import engine.gameManager.ConfigManager;
|
||||||
import engine.gameManager.PowersManager;
|
import engine.gameManager.PowersManager;
|
||||||
import engine.gameManager.ZoneManager;
|
import engine.gameManager.ZoneManager;
|
||||||
import engine.math.Vector2f;
|
import engine.math.Vector2f;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.AbstractCharacter;
|
import engine.objects.*;
|
||||||
import engine.objects.ItemBase;
|
|
||||||
import engine.objects.Shrine;
|
|
||||||
import engine.objects.Zone;
|
|
||||||
import engine.powers.EffectsBase;
|
import engine.powers.EffectsBase;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
|
|
||||||
@@ -211,8 +209,7 @@ public class Enum {
|
|||||||
STANDARD(6.1900001f, 13.97f, 4.2199998f, 13.97f, 6.3299999f, 18.379999f, 6.5f),
|
STANDARD(6.1900001f, 13.97f, 4.2199998f, 13.97f, 6.3299999f, 18.379999f, 6.5f),
|
||||||
CENTAUR(6.1900001f, 16.940001f, 5.5500002f, 16.940001f, 6.3299999f, 18.379999f, 6.5f),
|
CENTAUR(6.1900001f, 16.940001f, 5.5500002f, 16.940001f, 6.3299999f, 18.379999f, 6.5f),
|
||||||
MINOTAUR(6.6300001f, 15.95f, 4.2199998f, 15.95f, 6.3299999f, 18.379999f, 6.5f),
|
MINOTAUR(6.6300001f, 15.95f, 4.2199998f, 15.95f, 6.3299999f, 18.379999f, 6.5f),
|
||||||
IREKEI(6.1900001f, 13.97f, 4.2199998f, 13.97f, 6.3299999f, 18.379999f, 6.5f);
|
IREKEI(6.499500105f, 14.6685f, 4.2199998f, 14.6685f, 6.3299999f, 18.379999f, 6.5f);
|
||||||
|
|
||||||
private float walkStandard;
|
private float walkStandard;
|
||||||
private float walkCombat;
|
private float walkCombat;
|
||||||
private float runStandard;
|
private float runStandard;
|
||||||
@@ -472,11 +469,14 @@ public class Enum {
|
|||||||
|
|
||||||
// 14001 does not have a banestone to bind at
|
// 14001 does not have a banestone to bind at
|
||||||
|
|
||||||
if (ruinZone.getLoadNum() == 14001)
|
if (ruinZone.getLoadNum() == 14001) {
|
||||||
spawnLocation = Vector3fImmutable.getRandomPointOnCircle(ruinZone.getLoc(), 30);
|
spawnLocation = Vector3fImmutable.getRandomPointOnCircle(ruinZone.getLoc(), 30);
|
||||||
else
|
}else {
|
||||||
spawnLocation = Vector3fImmutable.getRandomPointOnCircle(ruinZone.getLoc()
|
//spawnLocation = Vector3fImmutable.getRandomPointOnCircle(ruinZone.getLoc()
|
||||||
.add(new Vector3fImmutable(-196.016f, 2.812f, 203.621f)), 30);
|
//.add(new Vector3fImmutable(-196.016f, 2.812f, 203.621f)), 30);
|
||||||
|
spawnLocation = Vector3fImmutable.getRandomPointOnCircle(BuildingManager.getBuilding(27977).loc,30f);
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -779,6 +779,7 @@ public class Enum {
|
|||||||
Combat,
|
Combat,
|
||||||
Spires,
|
Spires,
|
||||||
Snare,
|
Snare,
|
||||||
|
Snared,
|
||||||
Stun,
|
Stun,
|
||||||
Blind,
|
Blind,
|
||||||
Root,
|
Root,
|
||||||
@@ -881,6 +882,7 @@ public class Enum {
|
|||||||
Siege,
|
Siege,
|
||||||
Slash,
|
Slash,
|
||||||
Snare,
|
Snare,
|
||||||
|
Snared,
|
||||||
Sorcery,
|
Sorcery,
|
||||||
Spear,
|
Spear,
|
||||||
SpearMastery,
|
SpearMastery,
|
||||||
@@ -1030,6 +1032,7 @@ public class Enum {
|
|||||||
Silence,
|
Silence,
|
||||||
Slash,
|
Slash,
|
||||||
Snare,
|
Snare,
|
||||||
|
Snared,
|
||||||
Stance,
|
Stance,
|
||||||
Stun,
|
Stun,
|
||||||
Summon,
|
Summon,
|
||||||
@@ -1154,6 +1157,7 @@ public class Enum {
|
|||||||
SkillDebuff,
|
SkillDebuff,
|
||||||
SlashResistanceDebuff,
|
SlashResistanceDebuff,
|
||||||
Snare,
|
Snare,
|
||||||
|
Snared,
|
||||||
StackableAttrCONBuff,
|
StackableAttrCONBuff,
|
||||||
StackableAttrDEXBuff,
|
StackableAttrDEXBuff,
|
||||||
StackableAttrSTRBuff,
|
StackableAttrSTRBuff,
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ import engine.Enum;
|
|||||||
import engine.Enum.DispatchChannel;
|
import engine.Enum.DispatchChannel;
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.GroupManager;
|
import engine.gameManager.GroupManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.job.JobScheduler;
|
import engine.job.JobScheduler;
|
||||||
import engine.jobs.RefreshGroupJob;
|
import engine.jobs.RefreshGroupJob;
|
||||||
@@ -19,10 +20,7 @@ import engine.net.AbstractNetMsg;
|
|||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
import engine.net.client.msg.LoadCharacterMsg;
|
import engine.net.client.msg.*;
|
||||||
import engine.net.client.msg.LoadStructureMsg;
|
|
||||||
import engine.net.client.msg.MoveToPointMsg;
|
|
||||||
import engine.net.client.msg.UnloadObjectsMsg;
|
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
import engine.server.MBServerStatics;
|
import engine.server.MBServerStatics;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
@@ -236,7 +234,7 @@ public enum InterestManager implements Runnable {
|
|||||||
|
|
||||||
if (distanceSquared > sqr(64))
|
if (distanceSquared > sqr(64))
|
||||||
player.setLastStaticLoc(player.getLoc());
|
player.setLastStaticLoc(player.getLoc());
|
||||||
else if (player.isDirtyLoad() == false)
|
else if (PlayerManager.isDirtyLoad(player) == false)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Get Statics in range
|
// Get Statics in range
|
||||||
@@ -289,14 +287,14 @@ public enum InterestManager implements Runnable {
|
|||||||
lsm.addObject((Building) awo);
|
lsm.addObject((Building) awo);
|
||||||
else if (awo.getObjectType().equals(GameObjectType.Corpse)) {
|
else if (awo.getObjectType().equals(GameObjectType.Corpse)) {
|
||||||
Corpse corpse = (Corpse) awo;
|
Corpse corpse = (Corpse) awo;
|
||||||
lcm = new LoadCharacterMsg(corpse, PlayerCharacter.hideNonAscii());
|
lcm = new LoadCharacterMsg(corpse, PlayerManager.hideNonAscii());
|
||||||
|
|
||||||
Dispatch dispatch = Dispatch.borrow(player, lcm);
|
Dispatch dispatch = Dispatch.borrow(player, lcm);
|
||||||
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.PRIMARY);
|
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.PRIMARY);
|
||||||
|
|
||||||
} else if (awo.getObjectType().equals(GameObjectType.NPC)) {
|
} else if (awo.getObjectType().equals(GameObjectType.NPC)) {
|
||||||
NPC npc = (NPC) awo;
|
NPC npc = (NPC) awo;
|
||||||
lcm = new LoadCharacterMsg(npc, PlayerCharacter.hideNonAscii());
|
lcm = new LoadCharacterMsg(npc, PlayerManager.hideNonAscii());
|
||||||
|
|
||||||
lcmList.add(lcm);
|
lcmList.add(lcm);
|
||||||
}
|
}
|
||||||
@@ -314,7 +312,7 @@ public enum InterestManager implements Runnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
loadedStaticObjects.addAll(toLoad);
|
loadedStaticObjects.addAll(toLoad);
|
||||||
player.setDirtyLoad(false);
|
PlayerManager.setDirtyLoad(player, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void updateMobileList(PlayerCharacter player, ClientConnection origin) {
|
private void updateMobileList(PlayerCharacter player, ClientConnection origin) {
|
||||||
@@ -440,7 +438,7 @@ public enum InterestManager implements Runnable {
|
|||||||
if (player.getSeeInvis() < awopc.getHidden())
|
if (player.getSeeInvis() < awopc.getHidden())
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
lcm = new LoadCharacterMsg(awopc, PlayerCharacter.hideNonAscii());
|
lcm = new LoadCharacterMsg(awopc, PlayerManager.hideNonAscii());
|
||||||
players.add(awo);
|
players.add(awo);
|
||||||
|
|
||||||
// check if in a group with the person being loaded
|
// check if in a group with the person being loaded
|
||||||
@@ -469,11 +467,11 @@ public enum InterestManager implements Runnable {
|
|||||||
|
|
||||||
awonpc.playerAgroMap.put(player.getObjectUUID(), false);
|
awonpc.playerAgroMap.put(player.getObjectUUID(), false);
|
||||||
((Mob) awonpc).setCombatTarget(null);
|
((Mob) awonpc).setCombatTarget(null);
|
||||||
lcm = new LoadCharacterMsg(awonpc, PlayerCharacter.hideNonAscii());
|
lcm = new LoadCharacterMsg(awonpc, PlayerManager.hideNonAscii());
|
||||||
|
|
||||||
} else if ((awo.getObjectTypeMask() & MBServerStatics.MASK_NPC) != 0) {
|
} else if ((awo.getObjectTypeMask() & MBServerStatics.MASK_NPC) != 0) {
|
||||||
NPC awonpc = (NPC) awo;
|
NPC awonpc = (NPC) awo;
|
||||||
lcm = new LoadCharacterMsg(awonpc, PlayerCharacter.hideNonAscii());
|
lcm = new LoadCharacterMsg(awonpc, PlayerManager.hideNonAscii());
|
||||||
} else if ((awo.getObjectTypeMask() & MBServerStatics.MASK_PET) != 0) {
|
} else if ((awo.getObjectTypeMask() & MBServerStatics.MASK_PET) != 0) {
|
||||||
Mob awonpc = (Mob) awo;
|
Mob awonpc = (Mob) awo;
|
||||||
|
|
||||||
@@ -485,7 +483,7 @@ public enum InterestManager implements Runnable {
|
|||||||
if ((awonpc.agentType.equals(Enum.AIAgentType.MOBILE)))
|
if ((awonpc.agentType.equals(Enum.AIAgentType.MOBILE)))
|
||||||
((Mob) awonpc).setCombatTarget(null);
|
((Mob) awonpc).setCombatTarget(null);
|
||||||
|
|
||||||
lcm = new LoadCharacterMsg(awonpc, PlayerCharacter.hideNonAscii());
|
lcm = new LoadCharacterMsg(awonpc, PlayerManager.hideNonAscii());
|
||||||
}
|
}
|
||||||
|
|
||||||
addToList.add(awo);
|
addToList.add(awo);
|
||||||
@@ -521,15 +519,10 @@ public enum InterestManager implements Runnable {
|
|||||||
|
|
||||||
// Update loaded upbjects lists
|
// Update loaded upbjects lists
|
||||||
|
|
||||||
player.isBoxed = PlayerCharacter.checkIfBoxed(player);
|
player.isBoxed = PlayerManager.checkIfBoxed(player);
|
||||||
player.setDirtyLoad(true);
|
PlayerManager.setDirtyLoad(player, true);
|
||||||
updateStaticList(player, origin);
|
updateStaticList(player, origin);
|
||||||
updateMobileList(player, origin);
|
updateMobileList(player, origin);
|
||||||
if(player.level < 10) {
|
|
||||||
player.setLevel((short) 10);
|
|
||||||
player.getCharItemManager().addGoldToInventory(1000,false);
|
|
||||||
player.getCharItemManager().addItemToInventory(new MobLoot(player,ItemBase.getItemBase(980066),1,false).promoteToItem(player));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void HandleLoadForTeleport(PlayerCharacter playerCharacter) {
|
public synchronized void HandleLoadForTeleport(PlayerCharacter playerCharacter) {
|
||||||
@@ -544,7 +537,7 @@ public enum InterestManager implements Runnable {
|
|||||||
|
|
||||||
// Update loaded upbjects lists
|
// Update loaded upbjects lists
|
||||||
|
|
||||||
playerCharacter.setDirtyLoad(true);
|
PlayerManager.setDirtyLoad(playerCharacter, true);
|
||||||
updateStaticList(playerCharacter, origin);
|
updateStaticList(playerCharacter, origin);
|
||||||
updateMobileList(playerCharacter, origin);
|
updateMobileList(playerCharacter, origin);
|
||||||
|
|
||||||
@@ -560,7 +553,7 @@ public enum InterestManager implements Runnable {
|
|||||||
for (AbstractWorldObject playerObject : playerList) {
|
for (AbstractWorldObject playerObject : playerList) {
|
||||||
|
|
||||||
PlayerCharacter playerCharacter = (PlayerCharacter) playerObject;
|
PlayerCharacter playerCharacter = (PlayerCharacter) playerObject;
|
||||||
playerCharacter.setDirtyLoad(true);
|
PlayerManager.setDirtyLoad(playerCharacter, true);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -13,6 +13,7 @@ import engine.Enum;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.ConfigManager;
|
import engine.gameManager.ConfigManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.objects.Account;
|
import engine.objects.Account;
|
||||||
import engine.objects.PlayerCharacter;
|
import engine.objects.PlayerCharacter;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
@@ -140,7 +141,7 @@ public class dbAccountHandler extends dbHandlerBase {
|
|||||||
int playerID;
|
int playerID;
|
||||||
|
|
||||||
playerID = rs.getInt(1);
|
playerID = rs.getInt(1);
|
||||||
trashPlayer = PlayerCharacter.getPlayerCharacter(playerID);
|
trashPlayer = PlayerManager.getPlayerCharacter(playerID);
|
||||||
|
|
||||||
if (trashPlayer == null)
|
if (trashPlayer == null)
|
||||||
continue;
|
continue;
|
||||||
|
|||||||
@@ -10,17 +10,13 @@
|
|||||||
package engine.db.handlers;
|
package engine.db.handlers;
|
||||||
|
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
import engine.objects.Bane;
|
import engine.gameManager.ZoneManager;
|
||||||
import engine.objects.Building;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.City;
|
import engine.objects.*;
|
||||||
import engine.objects.PlayerCharacter;
|
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
|
|
||||||
import java.sql.Connection;
|
import java.sql.*;
|
||||||
import java.sql.PreparedStatement;
|
|
||||||
import java.sql.ResultSet;
|
|
||||||
import java.sql.SQLException;
|
|
||||||
|
|
||||||
public class dbBaneHandler extends dbHandlerBase {
|
public class dbBaneHandler extends dbHandlerBase {
|
||||||
|
|
||||||
@@ -89,6 +85,139 @@ public class dbBaneHandler extends dbHandlerBase {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public boolean SET_BANE_TIME_NEW(int hour, int cityUUID) {
|
||||||
|
hour += 12; // Adjust hour
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement getStatement = connection.prepareStatement("SELECT `placementDate`, `liveDate` FROM `dyn_banes` WHERE `cityUUID`=?");
|
||||||
|
PreparedStatement updateStatement = connection.prepareStatement("UPDATE `dyn_banes` SET `liveDate`=?, `time_set`=? WHERE `cityUUID`=?")) {
|
||||||
|
|
||||||
|
// Retrieve placementDate and liveDate
|
||||||
|
getStatement.setInt(1, cityUUID);
|
||||||
|
try (ResultSet rs = getStatement.executeQuery()) {
|
||||||
|
if (rs.next()) {
|
||||||
|
DateTime placementDate = new DateTime(rs.getTimestamp("placementDate").getTime());
|
||||||
|
Timestamp liveDateTimestamp = rs.getTimestamp("liveDate");
|
||||||
|
|
||||||
|
// Explicitly check if liveDate is null
|
||||||
|
DateTime toSet;
|
||||||
|
if (liveDateTimestamp == null) {
|
||||||
|
// If liveDate is null, default to placementDate
|
||||||
|
toSet = placementDate;
|
||||||
|
} else {
|
||||||
|
// If liveDate is not null, use it
|
||||||
|
DateTime liveDate = new DateTime(liveDateTimestamp.getTime());
|
||||||
|
toSet = liveDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adjust the time
|
||||||
|
toSet = toSet.withHourOfDay(hour).withMinuteOfHour(0).withSecondOfMinute(0).withMillisOfSecond(0);
|
||||||
|
|
||||||
|
// Update liveDate and time_set flag
|
||||||
|
updateStatement.setTimestamp(1, new java.sql.Timestamp(toSet.getMillis()));
|
||||||
|
updateStatement.setInt(2, 1); // time_set flag
|
||||||
|
updateStatement.setInt(3, cityUUID);
|
||||||
|
|
||||||
|
updateStatement.execute();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean SET_BANE_DAY_NEW(int dayOffset, int cityUUID) {
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement getStatement = connection.prepareStatement("SELECT `placementDate`, `liveDate` FROM `dyn_banes` WHERE `cityUUID`=?");
|
||||||
|
PreparedStatement updateStatement = connection.prepareStatement("UPDATE `dyn_banes` SET `liveDate`=?, `day_set`=? WHERE `cityUUID`=?")) {
|
||||||
|
|
||||||
|
// Retrieve placementDate and liveDate
|
||||||
|
getStatement.setInt(1, cityUUID);
|
||||||
|
try (ResultSet rs = getStatement.executeQuery()) {
|
||||||
|
if (rs.next()) {
|
||||||
|
DateTime placementDate = new DateTime(rs.getTimestamp("placementDate").getTime());
|
||||||
|
Timestamp liveDateTimestamp = rs.getTimestamp("liveDate");
|
||||||
|
|
||||||
|
// Explicitly check if liveDate is null
|
||||||
|
DateTime liveDate;
|
||||||
|
if (liveDateTimestamp == null) {
|
||||||
|
// If liveDate is null, default to placementDate
|
||||||
|
liveDate = placementDate;
|
||||||
|
} else {
|
||||||
|
// If liveDate is not null, use it
|
||||||
|
liveDate = new DateTime(liveDateTimestamp.getTime());
|
||||||
|
}
|
||||||
|
|
||||||
|
// Calculate the new liveDate while preserving the time component
|
||||||
|
DateTime updatedDate = placementDate.plusDays(dayOffset)
|
||||||
|
.withHourOfDay(liveDate.getHourOfDay())
|
||||||
|
.withMinuteOfHour(liveDate.getMinuteOfHour())
|
||||||
|
.withSecondOfMinute(liveDate.getSecondOfMinute())
|
||||||
|
.withMillisOfSecond(liveDate.getMillisOfSecond());
|
||||||
|
|
||||||
|
// Update liveDate and day_set flag
|
||||||
|
updateStatement.setTimestamp(1, new java.sql.Timestamp(updatedDate.getMillis()));
|
||||||
|
updateStatement.setInt(2, 1); // day_set flag
|
||||||
|
updateStatement.setInt(3, cityUUID);
|
||||||
|
|
||||||
|
updateStatement.execute();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
public boolean SET_BANE_CAP_NEW(int count, int cityUUID) {
|
||||||
|
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement preparedStatement = connection.prepareStatement("UPDATE `dyn_banes` SET `cap_size`=? WHERE `cityUUID`=?")) {
|
||||||
|
|
||||||
|
preparedStatement.setInt(1, count);
|
||||||
|
preparedStatement.setLong(2, cityUUID);
|
||||||
|
|
||||||
|
preparedStatement.execute();
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement preparedStatement = connection.prepareStatement("UPDATE `dyn_banes` SET `cap_set`=? WHERE `cityUUID`=?")) {
|
||||||
|
|
||||||
|
preparedStatement.setInt(1, 1);
|
||||||
|
preparedStatement.setLong(2, cityUUID);
|
||||||
|
|
||||||
|
preparedStatement.execute();
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement preparedStatement = connection.prepareStatement("UPDATE `dyn_banes` SET `cap_size`=? WHERE `cityUUID`=?")) {
|
||||||
|
|
||||||
|
preparedStatement.setInt(1, count);
|
||||||
|
preparedStatement.setLong(2, cityUUID);
|
||||||
|
|
||||||
|
preparedStatement.execute();
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean REMOVE_BANE(Bane bane) {
|
public boolean REMOVE_BANE(Bane bane) {
|
||||||
|
|
||||||
if (bane == null)
|
if (bane == null)
|
||||||
@@ -107,4 +236,25 @@ public class dbBaneHandler extends dbHandlerBase {
|
|||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public DateTime getLiveDate(int cityUUID) {
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement statement = connection.prepareStatement("SELECT `liveDate` FROM `dyn_banes` WHERE `cityUUID`=?")) {
|
||||||
|
|
||||||
|
statement.setInt(1, cityUUID);
|
||||||
|
|
||||||
|
try (ResultSet rs = statement.executeQuery()) {
|
||||||
|
if (rs.next()) {
|
||||||
|
Timestamp liveDateTimestamp = rs.getTimestamp("liveDate");
|
||||||
|
if (liveDateTimestamp != null) {
|
||||||
|
return new DateTime(liveDateTimestamp.getTime());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
}
|
||||||
|
return null; // Return null if liveDate is not found or an error occurs
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,8 +10,8 @@
|
|||||||
package engine.db.handlers;
|
package engine.db.handlers;
|
||||||
|
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.objects.Account;
|
import engine.objects.Account;
|
||||||
import engine.objects.PlayerCharacter;
|
|
||||||
import engine.session.CSSession;
|
import engine.session.CSSession;
|
||||||
import engine.util.StringUtils;
|
import engine.util.StringUtils;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
@@ -103,7 +103,7 @@ public class dbCSSessionHandler extends dbHandlerBase {
|
|||||||
ResultSet rs = preparedStatement.executeQuery();
|
ResultSet rs = preparedStatement.executeQuery();
|
||||||
|
|
||||||
if (rs.next())
|
if (rs.next())
|
||||||
css = new CSSession(secKey, DbManager.AccountQueries.GET_ACCOUNT(rs.getInt("accountID")), PlayerCharacter.getPlayerCharacter(rs.getInt("characterID")), rs.getString("machineID"));
|
css = new CSSession(secKey, DbManager.AccountQueries.GET_ACCOUNT(rs.getInt("accountID")), PlayerManager.getPlayerCharacter(rs.getInt("characterID")), rs.getString("machineID"));
|
||||||
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
Logger.error(e);
|
Logger.error(e);
|
||||||
|
|||||||
@@ -98,6 +98,7 @@ public class dbContractHandler extends dbHandlerBase {
|
|||||||
|
|
||||||
public void LOAD_SELL_LIST_FOR_CONTRACT(final Contract contract) {
|
public void LOAD_SELL_LIST_FOR_CONTRACT(final Contract contract) {
|
||||||
|
|
||||||
|
if(!contract.getName().contains("Sage")) {
|
||||||
try (Connection connection = DbManager.getConnection();
|
try (Connection connection = DbManager.getConnection();
|
||||||
PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM `static_npc_contract_selltype` WHERE `contractID` = ?;")) {
|
PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM `static_npc_contract_selltype` WHERE `contractID` = ?;")) {
|
||||||
|
|
||||||
@@ -125,6 +126,27 @@ public class dbContractHandler extends dbHandlerBase {
|
|||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
Logger.error(e);
|
Logger.error(e);
|
||||||
}
|
}
|
||||||
|
}else{
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement preparedStatement = connection.prepareStatement("SELECT * FROM `static_npc_contract_selltype`;")) {
|
||||||
|
|
||||||
|
ResultSet rs = preparedStatement.executeQuery();
|
||||||
|
|
||||||
|
while (rs.next()) {
|
||||||
|
int value = rs.getInt("value");
|
||||||
|
if(!contract.getBuySkillToken().contains(value))
|
||||||
|
contract.getBuySkillToken().add(value);
|
||||||
|
|
||||||
|
if(!contract.getBuyItemType().contains(value))
|
||||||
|
contract.getBuyItemType().add(value);
|
||||||
|
|
||||||
|
if(!contract.getBuyUnknownToken().contains(value))
|
||||||
|
contract.getBuyUnknownToken().add(value);
|
||||||
|
}
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean updateAllowedBuildings(final Contract con, final long slotbitvalue) {
|
public boolean updateAllowedBuildings(final Contract con, final long slotbitvalue) {
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.db.handlers;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.Enum.GuildHistoryType;
|
import engine.Enum.GuildHistoryType;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
import engine.server.world.WorldServer;
|
import engine.server.world.WorldServer;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
@@ -222,7 +223,7 @@ public class dbGuildHandler extends dbHandlerBase {
|
|||||||
|
|
||||||
while (rs.next()) {
|
while (rs.next()) {
|
||||||
int playerUUID = rs.getInt(1);
|
int playerUUID = rs.getInt(1);
|
||||||
PlayerCharacter kosPlayer = PlayerCharacter.getPlayerCharacter(playerUUID);
|
PlayerCharacter kosPlayer = PlayerManager.getPlayerCharacter(playerUUID);
|
||||||
|
|
||||||
if (kosPlayer != null)
|
if (kosPlayer != null)
|
||||||
kosList.add(kosPlayer);
|
kosList.add(kosPlayer);
|
||||||
|
|||||||
@@ -56,6 +56,13 @@ public abstract class dbHandlerBase {
|
|||||||
while (rs.next()) {
|
while (rs.next()) {
|
||||||
|
|
||||||
int id = rs.getInt(1);
|
int id = rs.getInt(1);
|
||||||
|
try {
|
||||||
|
if (rs.getInt("capSize") == 0) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
}catch(Exception e){
|
||||||
|
//not a mine
|
||||||
|
}
|
||||||
|
|
||||||
if (DbManager.inCache(localObjectType, id)) {
|
if (DbManager.inCache(localObjectType, id)) {
|
||||||
objectList.add((T) DbManager.getFromCache(localObjectType, id));
|
objectList.add((T) DbManager.getFromCache(localObjectType, id));
|
||||||
|
|||||||
@@ -134,9 +134,13 @@ public class dbItemHandler extends dbHandlerBase {
|
|||||||
|
|
||||||
ResultSet rs = preparedStatement.executeQuery();
|
ResultSet rs = preparedStatement.executeQuery();
|
||||||
|
|
||||||
if (rs.next())
|
if (rs.next()) {
|
||||||
|
try {
|
||||||
worked = rs.getBoolean("result");
|
worked = rs.getBoolean("result");
|
||||||
|
}catch(Exception e){
|
||||||
|
worked = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
Logger.error(e);
|
Logger.error(e);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.db.handlers;
|
|||||||
|
|
||||||
import engine.Enum.ProfitType;
|
import engine.Enum.ProfitType;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.NPC;
|
import engine.objects.NPC;
|
||||||
import engine.objects.NPCProfits;
|
import engine.objects.NPCProfits;
|
||||||
@@ -131,6 +132,32 @@ public class dbNPCHandler extends dbHandlerBase {
|
|||||||
return npc;
|
return npc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public int BANE_COMMANDER_EXISTS(final int objectUUID) {
|
||||||
|
|
||||||
|
int uid = 0;
|
||||||
|
|
||||||
|
String query = "SELECT `UID` FROM `obj_npc` WHERE `npc_buildingID` = ? LIMIT 1;";
|
||||||
|
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement preparedStatement = connection.prepareStatement(query)) {
|
||||||
|
|
||||||
|
preparedStatement.setInt(1, objectUUID);
|
||||||
|
|
||||||
|
try (ResultSet rs = preparedStatement.executeQuery()) {
|
||||||
|
if (rs.next()) {
|
||||||
|
// Retrieve the UID column value
|
||||||
|
uid = rs.getInt("UID");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
return uid;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
public int MOVE_NPC(long npcID, long parentID, float locX, float locY, float locZ) {
|
public int MOVE_NPC(long npcID, long parentID, float locX, float locY, float locZ) {
|
||||||
|
|
||||||
int rowCount;
|
int rowCount;
|
||||||
@@ -176,6 +203,18 @@ public class dbNPCHandler extends dbHandlerBase {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void updateSpecialPricing(final NPC npc){
|
||||||
|
try (Connection connection = DbManager.getConnection();
|
||||||
|
PreparedStatement preparedStatement = connection.prepareStatement("UPDATE obj_npc SET specialPrice=? WHERE UID = ?")) {
|
||||||
|
preparedStatement.setInt(1, npc.getSpecialPrice());
|
||||||
|
preparedStatement.setInt(2, npc.getDBID());
|
||||||
|
|
||||||
|
preparedStatement.executeUpdate();
|
||||||
|
|
||||||
|
} catch (SQLException e) {
|
||||||
|
Logger.error(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
public void updateDatabase(final NPC npc) {
|
public void updateDatabase(final NPC npc) {
|
||||||
|
|
||||||
try (Connection connection = DbManager.getConnection();
|
try (Connection connection = DbManager.getConnection();
|
||||||
@@ -292,12 +331,12 @@ public class dbNPCHandler extends dbHandlerBase {
|
|||||||
|
|
||||||
// Handle new mobbbase entries
|
// Handle new mobbbase entries
|
||||||
|
|
||||||
if (NPC._pirateNames.get(mobBase) == null)
|
if (NPCManager._pirateNames.get(mobBase) == null)
|
||||||
NPC._pirateNames.putIfAbsent(mobBase, new ArrayList<>());
|
NPCManager._pirateNames.putIfAbsent(mobBase, new ArrayList<>());
|
||||||
|
|
||||||
// Insert name into proper arraylist
|
// Insert name into proper arraylist
|
||||||
|
|
||||||
NPC._pirateNames.get(mobBase).add(pirateName);
|
NPCManager._pirateNames.get(mobBase).add(pirateName);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (SQLException e) {
|
} catch (SQLException e) {
|
||||||
@@ -305,7 +344,7 @@ public class dbNPCHandler extends dbHandlerBase {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Logger.info("names read: " + recordsRead + " for "
|
Logger.info("names read: " + recordsRead + " for "
|
||||||
+ NPC._pirateNames.size() + " mobBases");
|
+ NPCManager._pirateNames.size() + " mobBases");
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean ADD_TO_PRODUCTION_LIST(final long ID, final long npcUID, final long itemBaseID, DateTime dateTime, String prefix, String suffix, String name, boolean isRandom, int playerID) {
|
public boolean ADD_TO_PRODUCTION_LIST(final long ID, final long npcUID, final long itemBaseID, DateTime dateTime, String prefix, String suffix, String name, boolean isRandom, int playerID) {
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -71,7 +72,7 @@ public abstract class AbstractDevCmd {
|
|||||||
int targetType = pc.getLastTargetType().ordinal();
|
int targetType = pc.getLastTargetType().ordinal();
|
||||||
int targetID = pc.getLastTargetID();
|
int targetID = pc.getLastTargetID();
|
||||||
if (targetType == GameObjectType.NPC.ordinal()) {
|
if (targetType == GameObjectType.NPC.ordinal()) {
|
||||||
NPC b = NPC.getFromCache(targetID);
|
NPC b = NPCManager.getFromCache(targetID);
|
||||||
if (b == null) {
|
if (b == null) {
|
||||||
ChatManager.chatSystemError(pc,
|
ChatManager.chatSystemError(pc,
|
||||||
"Command Failed. Could not find NPC of ID " + targetID);
|
"Command Failed. Could not find NPC of ID " + targetID);
|
||||||
|
|||||||
@@ -10,12 +10,10 @@
|
|||||||
package engine.devcmd.cmds;
|
package engine.devcmd.cmds;
|
||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.InterestManagement.WorldGrid;
|
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.*;
|
import engine.gameManager.*;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
import org.pmw.tinylog.Logger;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author Eighty
|
* @author Eighty
|
||||||
@@ -77,7 +75,7 @@ public class AddNPCCmd extends AbstractDevCmd {
|
|||||||
} else{
|
} else{
|
||||||
loc = pc.loc;
|
loc = pc.loc;
|
||||||
}
|
}
|
||||||
created = NPC.createNPC(name, contractID, loc, guild, zone, (short)level, building);
|
created = NPCManager.createNPC(name, contractID, loc, guild, zone, (short)level, building);
|
||||||
created.bindLoc = loc;
|
created.bindLoc = loc;
|
||||||
if(building != null) {
|
if(building != null) {
|
||||||
created.buildingUUID = building.getObjectUUID();
|
created.buildingUUID = building.getObjectUUID();
|
||||||
|
|||||||
@@ -11,6 +11,8 @@ package engine.devcmd.cmds;
|
|||||||
|
|
||||||
import engine.Enum.ModType;
|
import engine.Enum.ModType;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.PowersManager;
|
import engine.gameManager.PowersManager;
|
||||||
import engine.net.ItemProductionManager;
|
import engine.net.ItemProductionManager;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
@@ -46,7 +48,7 @@ public class AuditFailedItemsCmd extends AbstractDevCmd {
|
|||||||
String prefix = "";
|
String prefix = "";
|
||||||
String suffix = "";
|
String suffix = "";
|
||||||
String itemName = "";
|
String itemName = "";
|
||||||
NPC npc = NPC.getFromCache(failedItem.getNpcUID());
|
NPC npc = NPCManager.getFromCache(failedItem.getNpcUID());
|
||||||
|
|
||||||
if (npc == null) {
|
if (npc == null) {
|
||||||
npcName = "null";
|
npcName = "null";
|
||||||
@@ -57,7 +59,7 @@ public class AuditFailedItemsCmd extends AbstractDevCmd {
|
|||||||
contractName = npc.getContract().getName();
|
contractName = npc.getContract().getName();
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayerCharacter roller = PlayerCharacter.getFromCache(failedItem.getPlayerID());
|
PlayerCharacter roller = PlayerManager.getFromCache(failedItem.getPlayerID());
|
||||||
|
|
||||||
if (roller == null)
|
if (roller == null)
|
||||||
playerName = "null";
|
playerName = "null";
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.PlayerCharacter;
|
import engine.objects.PlayerCharacter;
|
||||||
|
|
||||||
@@ -34,8 +35,8 @@ public class DecachePlayerCmd extends AbstractDevCmd {
|
|||||||
int objectUUID = Integer.parseInt(words[0]);
|
int objectUUID = Integer.parseInt(words[0]);
|
||||||
|
|
||||||
if (DbManager.inCache(Enum.GameObjectType.PlayerCharacter, objectUUID)) {
|
if (DbManager.inCache(Enum.GameObjectType.PlayerCharacter, objectUUID)) {
|
||||||
this.setTarget(PlayerCharacter.getFromCache(objectUUID)); //for logging
|
this.setTarget(PlayerManager.getFromCache(objectUUID)); //for logging
|
||||||
PlayerCharacter.getFromCache(objectUUID).removeFromCache();
|
PlayerManager.getFromCache(objectUUID).removeFromCache();
|
||||||
} else {
|
} else {
|
||||||
this.sendHelp(pc);
|
this.sendHelp(pc);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.devcmd.cmds;
|
|||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.Building;
|
import engine.objects.Building;
|
||||||
@@ -89,7 +90,7 @@ public class GotoBoundsCmd extends AbstractDevCmd {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
player.teleport(targetLoc);
|
PlayerManager.teleport(player, targetLoc);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
@@ -35,7 +36,7 @@ public class GotoCmd extends AbstractDevCmd {
|
|||||||
|
|
||||||
if (target != null && words[0].isEmpty()) {
|
if (target != null && words[0].isEmpty()) {
|
||||||
AbstractWorldObject targetAgo = (AbstractWorldObject) target;
|
AbstractWorldObject targetAgo = (AbstractWorldObject) target;
|
||||||
pc.teleport(targetAgo.getLoc());
|
PlayerManager.teleport(pc, targetAgo.getLoc());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -50,7 +51,7 @@ public class GotoCmd extends AbstractDevCmd {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (loc != null)
|
if (loc != null)
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -61,7 +62,7 @@ public class GotoCmd extends AbstractDevCmd {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (loc != null)
|
if (loc != null)
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -164,7 +165,7 @@ public class GotoCmd extends AbstractDevCmd {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (loc != null) {
|
if (loc != null) {
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
|
|
||||||
@@ -84,7 +85,7 @@ public class GotoObj extends AbstractDevCmd {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
player.teleport(targetLoc);
|
PlayerManager.teleport(player, targetLoc);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -15,9 +15,11 @@ import engine.Enum.GameObjectType;
|
|||||||
import engine.Enum.TargetColor;
|
import engine.Enum.TargetColor;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
|
import engine.server.MBServerStatics;
|
||||||
import engine.util.StringUtils;
|
import engine.util.StringUtils;
|
||||||
|
|
||||||
import java.text.DecimalFormat;
|
import java.text.DecimalFormat;
|
||||||
@@ -334,7 +336,7 @@ public class InfoCmd extends AbstractDevCmd {
|
|||||||
|
|
||||||
output += "Altitude : " + targetPC.getLoc().y;
|
output += "Altitude : " + targetPC.getLoc().y;
|
||||||
|
|
||||||
output += "Swimming : " + targetPC.isSwimming();
|
output += "Swimming : " + PlayerManager.isSwimming(targetPC);
|
||||||
output += newline;
|
output += newline;
|
||||||
output += "isMoving : " + targetPC.isMoving();
|
output += "isMoving : " + targetPC.isMoving();
|
||||||
output += newline;
|
output += newline;
|
||||||
@@ -530,6 +532,13 @@ public class InfoCmd extends AbstractDevCmd {
|
|||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case Corpse:
|
||||||
|
Corpse corpse = (Corpse)target;
|
||||||
|
Long timeLeft = MBServerStatics.CORPSE_CLEANUP_TIMER_MS - (System.currentTimeMillis() - corpse.spawnedTime);
|
||||||
|
output += "Despawn in: " + timeLeft;
|
||||||
|
output += newline;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
throwbackInfo(pc, output);
|
throwbackInfo(pc, output);
|
||||||
|
|||||||
@@ -10,6 +10,7 @@
|
|||||||
package engine.devcmd.cmds;
|
package engine.devcmd.cmds;
|
||||||
|
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.PlayerCharacter;
|
import engine.objects.PlayerCharacter;
|
||||||
@@ -36,7 +37,7 @@ public class JumpCmd extends AbstractDevCmd {
|
|||||||
try {
|
try {
|
||||||
float range = Float.parseFloat(words[1]);
|
float range = Float.parseFloat(words[1]);
|
||||||
Vector3fImmutable newLoc = pc.getFaceDir().scaleAdd(range, pc.getLoc());
|
Vector3fImmutable newLoc = pc.getFaceDir().scaleAdd(range, pc.getLoc());
|
||||||
pc.teleport(newLoc);
|
PlayerManager.teleport(pc, newLoc);
|
||||||
|
|
||||||
|
|
||||||
} catch (NumberFormatException e) {
|
} catch (NumberFormatException e) {
|
||||||
@@ -68,7 +69,7 @@ public class JumpCmd extends AbstractDevCmd {
|
|||||||
|
|
||||||
Vector3fImmutable loc = pc.getLoc();
|
Vector3fImmutable loc = pc.getLoc();
|
||||||
loc = loc.add(lat, 0f, -lon);
|
loc = loc.add(lat, 0f, -lon);
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -12,10 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum.ProtectionState;
|
import engine.Enum.ProtectionState;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.ChatManager;
|
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.ZoneManager;
|
|
||||||
import engine.math.Vector3f;
|
import engine.math.Vector3f;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
@@ -74,7 +71,7 @@ public class MakeBaneCmd extends AbstractDevCmd {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
PlayerCharacter player = PlayerCharacter.getPlayerCharacter(attackerID);
|
PlayerCharacter player = PlayerManager.getPlayerCharacter(attackerID);
|
||||||
|
|
||||||
|
|
||||||
if (player.getGuild().isEmptyGuild()) {
|
if (player.getGuild().isEmptyGuild()) {
|
||||||
@@ -194,7 +191,7 @@ public class MakeBaneCmd extends AbstractDevCmd {
|
|||||||
Vector3fImmutable movePlayerOutsideStone = player.getLoc();
|
Vector3fImmutable movePlayerOutsideStone = player.getLoc();
|
||||||
movePlayerOutsideStone = movePlayerOutsideStone.setX(movePlayerOutsideStone.x + 10);
|
movePlayerOutsideStone = movePlayerOutsideStone.setX(movePlayerOutsideStone.x + 10);
|
||||||
movePlayerOutsideStone = movePlayerOutsideStone.setZ(movePlayerOutsideStone.z + 10);
|
movePlayerOutsideStone = movePlayerOutsideStone.setZ(movePlayerOutsideStone.z + 10);
|
||||||
player.teleport(movePlayerOutsideStone);
|
PlayerManager.teleport(player, movePlayerOutsideStone);
|
||||||
|
|
||||||
throwbackInfo(pc, "The city has been succesfully baned.");
|
throwbackInfo(pc, "The city has been succesfully baned.");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,10 +14,7 @@ import engine.Enum.DbObjectType;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.ChatManager;
|
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.ZoneManager;
|
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
|
|
||||||
@@ -94,7 +91,7 @@ public class RemoveObjectCmd extends AbstractDevCmd {
|
|||||||
removeBuilding(player, targetBuilding);
|
removeBuilding(player, targetBuilding);
|
||||||
break;
|
break;
|
||||||
case NPC:
|
case NPC:
|
||||||
targetNPC = NPC.getNPC(targetID);
|
targetNPC = NPCManager.getNPC(targetID);
|
||||||
removeNPC(player, targetNPC);
|
removeNPC(player, targetNPC);
|
||||||
break;
|
break;
|
||||||
case MOB:
|
case MOB:
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
package engine.devcmd.cmds;
|
package engine.devcmd.cmds;
|
||||||
|
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.PlayerCharacter;
|
import engine.objects.PlayerCharacter;
|
||||||
|
|
||||||
@@ -16,7 +17,7 @@ public class ResetLevelCmd extends AbstractDevCmd {
|
|||||||
protected void _doCmd(PlayerCharacter player, String[] args,
|
protected void _doCmd(PlayerCharacter player, String[] args,
|
||||||
AbstractGameObject target) {
|
AbstractGameObject target) {
|
||||||
|
|
||||||
player.ResetLevel(Short.parseShort(args[0]));
|
PlayerManager.ResetLevel(player, Short.parseShort(args[0]));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import engine.devcmd.AbstractDevCmd;
|
|||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.math.Vector3f;
|
import engine.math.Vector3f;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
@@ -96,7 +97,7 @@ public class RotateCmd extends AbstractDevCmd {
|
|||||||
// building failed, try npc
|
// building failed, try npc
|
||||||
NPC npc;
|
NPC npc;
|
||||||
if (id != 0)
|
if (id != 0)
|
||||||
npc = NPC.getNPC(id);
|
npc = NPCManager.getNPC(id);
|
||||||
else
|
else
|
||||||
npc = getTargetAsNPC(pc);
|
npc = getTargetAsNPC(pc);
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
@@ -156,7 +157,7 @@ public class RotateCmd extends AbstractDevCmd {
|
|||||||
// building failed, try npc
|
// building failed, try npc
|
||||||
NPC npc;
|
NPC npc;
|
||||||
if (id != 0)
|
if (id != 0)
|
||||||
npc = NPC.getNPC(id);
|
npc = NPCManager.getNPC(id);
|
||||||
else
|
else
|
||||||
npc = getTargetAsNPC(pc);
|
npc = getTargetAsNPC(pc);
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.MobBase;
|
import engine.objects.MobBase;
|
||||||
import engine.objects.NPC;
|
import engine.objects.NPC;
|
||||||
@@ -52,7 +53,7 @@ public class SetNpcEquipSetCmd extends AbstractDevCmd {
|
|||||||
boolean complete = false;
|
boolean complete = false;
|
||||||
|
|
||||||
while (complete == false) {
|
while (complete == false) {
|
||||||
complete = NPC.UpdateEquipSetID(npc, SetNpcEquipSetCmd.lastEquipSetID);
|
complete = NPCManager.UpdateEquipSetID(npc, SetNpcEquipSetCmd.lastEquipSetID);
|
||||||
|
|
||||||
if (!complete) {
|
if (!complete) {
|
||||||
SetNpcEquipSetCmd.lastEquipSetID++;
|
SetNpcEquipSetCmd.lastEquipSetID++;
|
||||||
@@ -81,7 +82,7 @@ public class SetNpcEquipSetCmd extends AbstractDevCmd {
|
|||||||
boolean complete = false;
|
boolean complete = false;
|
||||||
|
|
||||||
while (complete == false) {
|
while (complete == false) {
|
||||||
complete = NPC.UpdateEquipSetID(npc, SetNpcEquipSetCmd.lastEquipSetID);
|
complete = NPCManager.UpdateEquipSetID(npc, SetNpcEquipSetCmd.lastEquipSetID);
|
||||||
|
|
||||||
if (!complete) {
|
if (!complete) {
|
||||||
SetNpcEquipSetCmd.lastEquipSetID--;
|
SetNpcEquipSetCmd.lastEquipSetID--;
|
||||||
@@ -109,7 +110,7 @@ public class SetNpcEquipSetCmd extends AbstractDevCmd {
|
|||||||
this.throwbackError(pc, e.getMessage());
|
this.throwbackError(pc, e.getMessage());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!NPC.UpdateEquipSetID(npc, equipSetID)) {
|
if (!NPCManager.UpdateEquipSetID(npc, equipSetID)) {
|
||||||
this.throwbackError(pc, "Unable to find Equipset for ID " + equipSetID);
|
this.throwbackError(pc, "Unable to find Equipset for ID " + equipSetID);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.MobBase;
|
import engine.objects.MobBase;
|
||||||
import engine.objects.NPC;
|
import engine.objects.NPC;
|
||||||
@@ -47,7 +48,7 @@ public class SetNpcMobbaseCmd extends AbstractDevCmd {
|
|||||||
this.throwbackError(player, "Cannot find Mobbase for ID " + mobBaseID);
|
this.throwbackError(player, "Cannot find Mobbase for ID " + mobBaseID);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NPC.UpdateRaceID(npc, mobBaseID);
|
NPCManager.UpdateRaceID(npc, mobBaseID);
|
||||||
|
|
||||||
WorldGrid.updateObject(npc);
|
WorldGrid.updateObject(npc);
|
||||||
|
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.devcmd.cmds;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.NPC;
|
import engine.objects.NPC;
|
||||||
import engine.objects.PlayerCharacter;
|
import engine.objects.PlayerCharacter;
|
||||||
@@ -43,7 +44,7 @@ public class SetNpcNameCmd extends AbstractDevCmd {
|
|||||||
|
|
||||||
String name = words[0];
|
String name = words[0];
|
||||||
|
|
||||||
NPC.UpdateName(npc, name);
|
NPCManager.UpdateName(npc, name);
|
||||||
|
|
||||||
WorldGrid.updateObject(npc);
|
WorldGrid.updateObject(npc);
|
||||||
|
|
||||||
|
|||||||
@@ -54,6 +54,7 @@ public class SimulateBootyCmd extends AbstractDevCmd {
|
|||||||
ArrayList<Item> Resources = new ArrayList<Item>();
|
ArrayList<Item> Resources = new ArrayList<Item>();
|
||||||
ArrayList<Item> Runes = new ArrayList<Item>();
|
ArrayList<Item> Runes = new ArrayList<Item>();
|
||||||
ArrayList<Item> Contracts = new ArrayList<Item>();
|
ArrayList<Item> Contracts = new ArrayList<Item>();
|
||||||
|
ArrayList<Item> GuardContracts = new ArrayList<Item>();
|
||||||
ArrayList<Item> Offerings = new ArrayList<Item>();
|
ArrayList<Item> Offerings = new ArrayList<Item>();
|
||||||
ArrayList<Item> OtherDrops = new ArrayList<Item>();
|
ArrayList<Item> OtherDrops = new ArrayList<Item>();
|
||||||
ArrayList<Item> EquipmentDrops = new ArrayList<Item>();
|
ArrayList<Item> EquipmentDrops = new ArrayList<Item>();
|
||||||
@@ -68,6 +69,9 @@ public class SimulateBootyCmd extends AbstractDevCmd {
|
|||||||
for (Item lootItem : mob.getCharItemManager().getInventory()) {
|
for (Item lootItem : mob.getCharItemManager().getInventory()) {
|
||||||
switch (lootItem.getItemBase().getType()) {
|
switch (lootItem.getItemBase().getType()) {
|
||||||
case CONTRACT: //CONTRACT
|
case CONTRACT: //CONTRACT
|
||||||
|
if(lootItem.getName().contains("Captain"))
|
||||||
|
GuardContracts.add(lootItem);
|
||||||
|
else
|
||||||
Contracts.add(lootItem);
|
Contracts.add(lootItem);
|
||||||
break;
|
break;
|
||||||
case OFFERING: //OFFERING
|
case OFFERING: //OFFERING
|
||||||
@@ -140,9 +144,17 @@ public class SimulateBootyCmd extends AbstractDevCmd {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int baseBound = 100000;
|
||||||
|
int levelPenalty = (int) (Math.max(0, Math.abs(50 - mob.level)) * 0.01 * 100000);
|
||||||
|
int totalRange = baseBound + levelPenalty;
|
||||||
|
if(mob.level >= 50){
|
||||||
|
totalRange = baseBound;
|
||||||
|
}
|
||||||
|
output += "TOTAL ROLL POTENTIAL: " + totalRange + newline;
|
||||||
output += "GLASS DROPS: " + GlassItems.size() + newline;
|
output += "GLASS DROPS: " + GlassItems.size() + newline;
|
||||||
output += "RUNE DROPS: " + Runes.size() + newline;
|
output += "RUNE DROPS: " + Runes.size() + newline;
|
||||||
output += "CONTRACTS DROPS: " + Contracts.size() + newline;
|
output += "CONTRACTS DROPS: " + Contracts.size() + newline;
|
||||||
|
output += "GUARD CONTRACTS DROPS: " + GuardContracts.size() + newline;
|
||||||
output += "RESOURCE DROPS: " + Resources.size() + newline;
|
output += "RESOURCE DROPS: " + Resources.size() + newline;
|
||||||
output += "OFFERINGS DROPPED: " + Offerings.size() + newline;
|
output += "OFFERINGS DROPPED: " + Offerings.size() + newline;
|
||||||
output += "ENCHANTED ITEMS DROPPED: " + OtherDrops.size() + newline;
|
output += "ENCHANTED ITEMS DROPPED: " + OtherDrops.size() + newline;
|
||||||
|
|||||||
@@ -13,6 +13,7 @@ import engine.Enum.GameObjectType;
|
|||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
|
|
||||||
@@ -56,7 +57,7 @@ public class SlotTestCmd extends AbstractDevCmd {
|
|||||||
BuildingLocation buildingLocation = BuildingManager._slotLocations.get(building.meshUUID).get(slot - 1);
|
BuildingLocation buildingLocation = BuildingManager._slotLocations.get(building.meshUUID).get(slot - 1);
|
||||||
slotLocation = building.getLoc().add(buildingLocation.getLocation());
|
slotLocation = building.getLoc().add(buildingLocation.getLocation());
|
||||||
slotLocation = Vector3fImmutable.rotateAroundPoint(building.getLoc(), slotLocation, building.getBounds().getQuaternion().angleY);
|
slotLocation = Vector3fImmutable.rotateAroundPoint(building.getLoc(), slotLocation, building.getBounds().getQuaternion().angleY);
|
||||||
playerCharacter.teleport(slotLocation);
|
PlayerManager.teleport(playerCharacter, slotLocation);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -10,6 +10,7 @@
|
|||||||
package engine.devcmd.cmds;
|
package engine.devcmd.cmds;
|
||||||
|
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.gameManager.ZoneManager;
|
import engine.gameManager.ZoneManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
@@ -91,7 +92,7 @@ public class SummonCmd extends AbstractDevCmd {
|
|||||||
this.setTarget(pcToSummon); //for logging
|
this.setTarget(pcToSummon); //for logging
|
||||||
|
|
||||||
Vector3fImmutable loc = pc.getLoc();
|
Vector3fImmutable loc = pc.getLoc();
|
||||||
pcToSummon.teleport(loc);
|
PlayerManager.teleport(pcToSummon, loc);
|
||||||
|
|
||||||
this.throwbackInfo(pc, "Player " + pcToSummon.getCombinedName()
|
this.throwbackInfo(pc, "Player " + pcToSummon.getCombinedName()
|
||||||
+ " has been summoned to your location.");
|
+ " has been summoned to your location.");
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.devcmd.cmds;
|
|||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.devcmd.AbstractDevCmd;
|
import engine.devcmd.AbstractDevCmd;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.Mob;
|
import engine.objects.Mob;
|
||||||
import engine.objects.PlayerCharacter;
|
import engine.objects.PlayerCharacter;
|
||||||
@@ -77,7 +78,7 @@ public class aiInfoCmd extends AbstractDevCmd {
|
|||||||
output += "Players Loaded:" + newline;
|
output += "Players Loaded:" + newline;
|
||||||
}
|
}
|
||||||
for (Map.Entry<Integer, Boolean> entry : mob.playerAgroMap.entrySet()) {
|
for (Map.Entry<Integer, Boolean> entry : mob.playerAgroMap.entrySet()) {
|
||||||
output += "Player ID: " + entry.getKey() + " Hate Value: " + (PlayerCharacter.getPlayerCharacter(entry.getKey())).getHateValue() + newline;
|
output += "Player ID: " + entry.getKey() + " Hate Value: " + (PlayerManager.getPlayerCharacter(entry.getKey())).getHateValue() + newline;
|
||||||
}
|
}
|
||||||
if (mob.getCombatTarget() != null)
|
if (mob.getCombatTarget() != null)
|
||||||
output += "Current Target: " + mob.getCombatTarget().getName() + newline;
|
output += "Current Target: " + mob.getCombatTarget().getName() + newline;
|
||||||
|
|||||||
@@ -0,0 +1,168 @@
|
|||||||
|
package engine.gameManager;
|
||||||
|
|
||||||
|
import engine.Enum;
|
||||||
|
import engine.InterestManagement.WorldGrid;
|
||||||
|
import engine.exception.MsgSendException;
|
||||||
|
import engine.math.Vector3f;
|
||||||
|
import engine.math.Vector3fImmutable;
|
||||||
|
import engine.objects.*;
|
||||||
|
import engine.server.MBServerStatics;
|
||||||
|
import org.pmw.tinylog.Logger;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
import java.util.concurrent.ThreadLocalRandom;
|
||||||
|
|
||||||
|
public class ArenaManager {
|
||||||
|
private static final List<Arena> activeArenas = new ArrayList<>();
|
||||||
|
public static final List<PlayerCharacter> playerQueue = new ArrayList<>();
|
||||||
|
public static Long pulseDelay = 180000L;
|
||||||
|
public static Long lastExecution = 0L;
|
||||||
|
|
||||||
|
public static void pulseArenas() {
|
||||||
|
if(lastExecution == 0L){
|
||||||
|
lastExecution = System.currentTimeMillis();
|
||||||
|
}
|
||||||
|
|
||||||
|
if(activeArenas.isEmpty() && playerQueue.isEmpty())
|
||||||
|
return;
|
||||||
|
|
||||||
|
Iterator<Arena> iterator = activeArenas.iterator();
|
||||||
|
|
||||||
|
while (iterator.hasNext()) {
|
||||||
|
Arena arena = iterator.next();
|
||||||
|
if (arena.checkToComplete()) {
|
||||||
|
iterator.remove();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(lastExecution + pulseDelay > System.currentTimeMillis())
|
||||||
|
return;
|
||||||
|
|
||||||
|
lastExecution = System.currentTimeMillis();
|
||||||
|
|
||||||
|
while (playerQueue.size() > 1) {
|
||||||
|
createArena();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void joinQueue(PlayerCharacter player) {
|
||||||
|
if (!playerQueue.contains(player)) {
|
||||||
|
playerQueue.add(player);
|
||||||
|
}
|
||||||
|
for(PlayerCharacter pc : playerQueue){
|
||||||
|
if(pc.equals(player))
|
||||||
|
continue;
|
||||||
|
ChatManager.chatSystemInfo(pc, player.getName() + " has joined the arena que. There are now " + playerQueue.size() + " players queued.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void leaveQueue(PlayerCharacter player) {
|
||||||
|
playerQueue.remove(player);
|
||||||
|
for(PlayerCharacter pc : playerQueue){
|
||||||
|
if(pc.equals(player))
|
||||||
|
continue;
|
||||||
|
ChatManager.chatSystemInfo(pc, player.getName() + " has left the arena que. There are now " + playerQueue.size() + " players queued.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void createArena() {
|
||||||
|
if (playerQueue.size() > 1) {
|
||||||
|
|
||||||
|
Collections.shuffle(playerQueue);
|
||||||
|
Arena newArena = new Arena();
|
||||||
|
|
||||||
|
//set starting time
|
||||||
|
newArena.startTime = System.currentTimeMillis();
|
||||||
|
|
||||||
|
//decide an arena location
|
||||||
|
newArena.loc = selectRandomArenaLocation();
|
||||||
|
|
||||||
|
// Assign players to the arena
|
||||||
|
newArena.player1 = playerQueue.remove(0);
|
||||||
|
newArena.player2 = playerQueue.remove(0);
|
||||||
|
|
||||||
|
// Teleport players to the arena location
|
||||||
|
Zone sdr = ZoneManager.getZoneByUUID(656);
|
||||||
|
MovementManager.translocate(newArena.player1, Vector3fImmutable.getRandomPointOnCircle(newArena.loc,75f), null);
|
||||||
|
MovementManager.translocate(newArena.player2, Vector3fImmutable.getRandomPointOnCircle(newArena.loc,75f), null);
|
||||||
|
|
||||||
|
// Add the new arena to the active arenas list
|
||||||
|
activeArenas.add(newArena);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void endArena(Arena arena, PlayerCharacter winner, PlayerCharacter loser, String condition){
|
||||||
|
if (winner != null && loser != null) {
|
||||||
|
Logger.info("[ARENA] The fight between {} and {} is concluded. Victor: {}",
|
||||||
|
arena.player1.getName(), arena.player2.getName(), winner.getName());
|
||||||
|
} else {
|
||||||
|
Logger.info("[ARENA] The fight between {} and {} is concluded. No Winner Declared.",
|
||||||
|
arena.player1.getName(), arena.player2.getName());
|
||||||
|
}
|
||||||
|
// Teleport players to the arena location
|
||||||
|
Zone sdr = ZoneManager.getZoneByUUID(656);
|
||||||
|
MovementManager.translocate(arena.player1, Vector3fImmutable.getRandomPointOnCircle(sdr.getLoc(),50f), null);
|
||||||
|
MovementManager.translocate(arena.player2, Vector3fImmutable.getRandomPointOnCircle(sdr.getLoc(),50f), null);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
activeArenas.remove(arena);
|
||||||
|
|
||||||
|
if(winner != null){
|
||||||
|
ChatManager.chatPVP("[ARENA] " + winner.getName() + " has slain " + loser.getName() + " in the arena!");
|
||||||
|
//handle prize distribution
|
||||||
|
//ItemBase specialLoot = ItemBase.getItemBase(866);
|
||||||
|
//Item promoted = new MobLoot(winner, specialLoot, 1, false).promoteToItem(winner);
|
||||||
|
//promoted.setNumOfItems(21235);
|
||||||
|
//promoted.setName("Special Banker(21235)");
|
||||||
|
//DbManager.ItemQueries.UPDATE_NUM_ITEMS(promoted,21235);
|
||||||
|
//winner.getCharItemManager().addItemToInventory(promoted);
|
||||||
|
//winner.getCharItemManager().updateInventory();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Vector3fImmutable selectRandomArenaLocation() {
|
||||||
|
boolean locSet = false;
|
||||||
|
Vector3fImmutable loc = Vector3fImmutable.ZERO;
|
||||||
|
|
||||||
|
while (!locSet) {
|
||||||
|
try {
|
||||||
|
float x = ThreadLocalRandom.current().nextInt(114300, 123600);
|
||||||
|
float z = ThreadLocalRandom.current().nextInt(82675, 91700);
|
||||||
|
float y = 0; // Y coordinate is always 0
|
||||||
|
|
||||||
|
loc = new Vector3fImmutable(x, y, z * -1);
|
||||||
|
HashSet<AbstractWorldObject> inRange = WorldGrid.getObjectsInRangePartial(loc,500f, MBServerStatics.MASK_PLAYER);
|
||||||
|
if(inRange.isEmpty() && !isUnderWater(loc))
|
||||||
|
locSet = true;
|
||||||
|
//}
|
||||||
|
}catch(Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return loc;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean isUnderWater(Vector3fImmutable loc) {
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Zone zone = ZoneManager.findSmallestZone(loc);
|
||||||
|
|
||||||
|
if (zone.getSeaLevel() != 0) {
|
||||||
|
|
||||||
|
float localAltitude = loc.y;
|
||||||
|
if (localAltitude < zone.getSeaLevel())
|
||||||
|
return true;
|
||||||
|
} else {
|
||||||
|
if (loc.y < 0)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -438,6 +438,18 @@ public enum BuildingManager {
|
|||||||
|
|
||||||
public static boolean IsPlayerHostile(Building building, PlayerCharacter player) {
|
public static boolean IsPlayerHostile(Building building, PlayerCharacter player) {
|
||||||
|
|
||||||
|
if(building.getBlueprint() != null && building.getBlueprint().getBuildingGroup() != null && building.getBlueprint().getBuildingGroup().equals(BuildingGroup.BANESTONE))
|
||||||
|
{
|
||||||
|
Guild playerNation = player.guild.getNation();
|
||||||
|
City banedCity = ZoneManager.getCityAtLocation(building.loc);
|
||||||
|
if(banedCity != null){
|
||||||
|
if(banedCity.getGuild().getNation().equals(playerNation)){
|
||||||
|
return false;
|
||||||
|
}else{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
//Nation Members and Guild members are not hostile.
|
//Nation Members and Guild members are not hostile.
|
||||||
// if (building.getGuild() != null){
|
// if (building.getGuild() != null){
|
||||||
// if (pc.getGuild() != null)
|
// if (pc.getGuild() != null)
|
||||||
@@ -501,7 +513,7 @@ public enum BuildingManager {
|
|||||||
|
|
||||||
NPC npc = null;
|
NPC npc = null;
|
||||||
|
|
||||||
npc = NPC.createNPC(pirateName, NpcID.getObjectUUID(), NpcLoc, null, zone, (short) rank, building);
|
npc = NPCManager.createNPC(pirateName, NpcID.getObjectUUID(), NpcLoc, null, zone, (short) rank, building);
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return false;
|
return false;
|
||||||
@@ -556,7 +568,7 @@ public enum BuildingManager {
|
|||||||
Mob mob;
|
Mob mob;
|
||||||
NPC npc;
|
NPC npc;
|
||||||
|
|
||||||
if (NPC.ISWallArcher(contract)) {
|
if (NPCManager.ISWallArcher(contract)) {
|
||||||
|
|
||||||
mob = Mob.createMob(contract.getMobbaseID(), Vector3fImmutable.ZERO, contractOwner.getGuild(), true, zone, building, contract.getContractID(), pirateName, rank);
|
mob = Mob.createMob(contract.getMobbaseID(), Vector3fImmutable.ZERO, contractOwner.getGuild(), true, zone, building, contract.getContractID(), pirateName, rank);
|
||||||
|
|
||||||
@@ -568,7 +580,7 @@ public enum BuildingManager {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (NPC.ISGuardCaptain(contract.getContractID())) {
|
if (NPCManager.ISGuardCaptain(contract.getContractID())) {
|
||||||
|
|
||||||
mob = Mob.createMob(contract.getMobbaseID(), Vector3fImmutable.ZERO, contractOwner.getGuild(), true, zone, building, contract.getContractID(), pirateName, rank);
|
mob = Mob.createMob(contract.getMobbaseID(), Vector3fImmutable.ZERO, contractOwner.getGuild(), true, zone, building, contract.getContractID(), pirateName, rank);
|
||||||
|
|
||||||
@@ -592,7 +604,7 @@ public enum BuildingManager {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
npc = NPC.createNPC(pirateName, contract.getObjectUUID(), Vector3fImmutable.ZERO, contractOwner.getGuild(), zone, (short) rank, building);
|
npc = NPCManager.createNPC(pirateName, contract.getObjectUUID(), Vector3fImmutable.ZERO, contractOwner.getGuild(), zone, (short) rank, building);
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return false;
|
return false;
|
||||||
@@ -798,7 +810,7 @@ public enum BuildingManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ManageCityAssetsMsg mca = new ManageCityAssetsMsg();
|
ManageCityAssetsMsg mca = new ManageCityAssetsMsg();
|
||||||
mca.actionType = NPC.SVR_CLOSE_WINDOW;
|
mca.actionType = NPCManager.SVR_CLOSE_WINDOW;
|
||||||
mca.setTargetType(building.getObjectType().ordinal());
|
mca.setTargetType(building.getObjectType().ordinal());
|
||||||
mca.setTargetID(building.getObjectUUID());
|
mca.setTargetID(building.getObjectUUID());
|
||||||
origin.sendMsg(mca);
|
origin.sendMsg(mca);
|
||||||
|
|||||||
@@ -65,7 +65,7 @@ public enum CombatManager {
|
|||||||
targetType = msg.getTargetType();
|
targetType = msg.getTargetType();
|
||||||
|
|
||||||
if (targetType == GameObjectType.PlayerCharacter.ordinal()) {
|
if (targetType == GameObjectType.PlayerCharacter.ordinal()) {
|
||||||
target = PlayerCharacter.getFromCache(msg.getTargetID());
|
target = PlayerManager.getFromCache(msg.getTargetID());
|
||||||
} else if (targetType == GameObjectType.Building.ordinal()) {
|
} else if (targetType == GameObjectType.Building.ordinal()) {
|
||||||
target = BuildingManager.getBuildingFromCache(msg.getTargetID());
|
target = BuildingManager.getBuildingFromCache(msg.getTargetID());
|
||||||
} else if (targetType == GameObjectType.Mob.ordinal()) {
|
} else if (targetType == GameObjectType.Mob.ordinal()) {
|
||||||
@@ -171,7 +171,7 @@ public enum CombatManager {
|
|||||||
targetType = msg.getTargetType();
|
targetType = msg.getTargetType();
|
||||||
|
|
||||||
if (targetType == GameObjectType.PlayerCharacter.ordinal())
|
if (targetType == GameObjectType.PlayerCharacter.ordinal())
|
||||||
target = PlayerCharacter.getFromCache(msg.getTargetID());
|
target = PlayerManager.getFromCache(msg.getTargetID());
|
||||||
else if (targetType == GameObjectType.Building.ordinal())
|
else if (targetType == GameObjectType.Building.ordinal())
|
||||||
target = BuildingManager.getBuildingFromCache(msg.getTargetID());
|
target = BuildingManager.getBuildingFromCache(msg.getTargetID());
|
||||||
else if (targetType == GameObjectType.Mob.ordinal())
|
else if (targetType == GameObjectType.Mob.ordinal())
|
||||||
@@ -1242,13 +1242,16 @@ public enum CombatManager {
|
|||||||
DispatchMessage.dispatchMsgToInterestArea(pc, rwss, DispatchChannel.PRIMARY, MBServerStatics.CHARACTER_LOAD_RANGE, false, false);
|
DispatchMessage.dispatchMsgToInterestArea(pc, rwss, DispatchChannel.PRIMARY, MBServerStatics.CHARACTER_LOAD_RANGE, false, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void toggleSit(boolean toggle, ClientConnection origin) {
|
public static void toggleSit(boolean toggle, ClientConnection origin) {
|
||||||
|
|
||||||
PlayerCharacter pc = SessionManager.getPlayerCharacter(origin);
|
PlayerCharacter pc = SessionManager.getPlayerCharacter(origin);
|
||||||
|
|
||||||
if (pc == null)
|
if (pc == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
if(PlayerManager.isFlying(pc))
|
||||||
|
pc.setSit(false);
|
||||||
|
else
|
||||||
pc.setSit(toggle);
|
pc.setSit(toggle);
|
||||||
|
|
||||||
UpdateStateMsg rwss = new UpdateStateMsg();
|
UpdateStateMsg rwss = new UpdateStateMsg();
|
||||||
@@ -1327,6 +1330,13 @@ public enum CombatManager {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
retaliater.setCombatTarget(ac);
|
retaliater.setCombatTarget(ac);
|
||||||
|
if(retaliater.isPlayerGuard && (retaliater.BehaviourType.equals(MobBehaviourType.GuardMinion) || retaliater.BehaviourType.equals(MobBehaviourType.GuardCaptain))){
|
||||||
|
for(Mob guard : retaliater.guardedCity.getParent().zoneMobSet){
|
||||||
|
if(guard.isPlayerGuard && guard.combatTarget == null){
|
||||||
|
guard.setCombatTarget(ac);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -65,6 +65,7 @@ public enum ConfigManager {
|
|||||||
MB_WORLD_MAINTENANCE,
|
MB_WORLD_MAINTENANCE,
|
||||||
MB_WORLD_GREETING,
|
MB_WORLD_GREETING,
|
||||||
MB_WORLD_KEYCLONE_MAX,
|
MB_WORLD_KEYCLONE_MAX,
|
||||||
|
MB_WORLD_TESTMODE,
|
||||||
MB_USE_RUINS,
|
MB_USE_RUINS,
|
||||||
|
|
||||||
// Mobile AI modifiers
|
// Mobile AI modifiers
|
||||||
|
|||||||
@@ -85,10 +85,10 @@ public enum DbManager {
|
|||||||
|
|
||||||
switch (objectType) {
|
switch (objectType) {
|
||||||
case PlayerCharacter:
|
case PlayerCharacter:
|
||||||
outObject = PlayerCharacter.getPlayerCharacter(objectUUID);
|
outObject = PlayerManager.getPlayerCharacter(objectUUID);
|
||||||
break;
|
break;
|
||||||
case NPC:
|
case NPC:
|
||||||
outObject = NPC.getNPC(objectUUID);
|
outObject = NPCManager.getNPC(objectUUID);
|
||||||
break;
|
break;
|
||||||
case Mob:
|
case Mob:
|
||||||
outObject = Mob.getFromCache(objectUUID);
|
outObject = Mob.getFromCache(objectUUID);
|
||||||
|
|||||||
@@ -180,17 +180,21 @@ public enum DevCmdManager {
|
|||||||
//kill any commands not available to everyone on production server
|
//kill any commands not available to everyone on production server
|
||||||
//only admin level can run dev commands on production
|
//only admin level can run dev commands on production
|
||||||
boolean playerAllowed = false;
|
boolean playerAllowed = false;
|
||||||
switch(adc.getMainCmdString()){
|
if(ConfigManager.MB_WORLD_TESTMODE.getValue().equals("true")) {
|
||||||
|
switch (adc.getMainCmdString()) {
|
||||||
case "printresists":
|
case "printresists":
|
||||||
case "printstats":
|
case "printstats":
|
||||||
case "printskills":
|
case "printskills":
|
||||||
case "printpowers":
|
case "printpowers":
|
||||||
case "gimme":
|
case "gimme":
|
||||||
|
case "goto":
|
||||||
|
case "teleportmode":
|
||||||
playerAllowed = true;
|
playerAllowed = true;
|
||||||
if(!a.status.equals(Enum.AccountStatus.ADMIN))
|
if (!a.status.equals(Enum.AccountStatus.ADMIN))
|
||||||
target = pcSender;
|
target = pcSender;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (!playerAllowed && !a.status.equals(Enum.AccountStatus.ADMIN)) {
|
if (!playerAllowed && !a.status.equals(Enum.AccountStatus.ADMIN)) {
|
||||||
Logger.info("Account " + a.getUname() + "attempted to use dev command " + cmd);
|
Logger.info("Account " + a.getUname() + "attempted to use dev command " + cmd);
|
||||||
return false;
|
return false;
|
||||||
|
|||||||
@@ -74,16 +74,16 @@ public enum GuildManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
playerCharacter.setInnerCouncil(false);
|
PlayerManager.setInnerCouncil(playerCharacter, false);
|
||||||
playerCharacter.setGuildLeader(false);
|
PlayerManager.setGuildLeader(playerCharacter, false);
|
||||||
playerCharacter.setGuild(guild);
|
playerCharacter.setGuild(guild);
|
||||||
|
|
||||||
// Cleanup guild stuff
|
// Cleanup guild stuff
|
||||||
playerCharacter.resetGuildStatuses();
|
PlayerManager.resetGuildStatuses(playerCharacter);
|
||||||
|
|
||||||
// send success message to client
|
// send success message to client
|
||||||
if (fromTeleportScreen && guild.isNPCGuild())
|
if (fromTeleportScreen && guild.isNPCGuild())
|
||||||
playerCharacter.setFullMember(true);
|
PlayerManager.setFullMember(playerCharacter, true);
|
||||||
|
|
||||||
msg = new AcceptInviteToGuildMsg(guild.getObjectUUID(), 1, 0);
|
msg = new AcceptInviteToGuildMsg(guild.getObjectUUID(), 1, 0);
|
||||||
|
|
||||||
@@ -178,7 +178,7 @@ public enum GuildManager {
|
|||||||
bindBuilding = city.getTOL();
|
bindBuilding = city.getTOL();
|
||||||
|
|
||||||
if (bindBuilding == null)
|
if (bindBuilding == null)
|
||||||
bindBuilding = PlayerCharacter.getBindBuildingForGuild(playerCharacter);
|
bindBuilding = PlayerManager.getBindBuildingForGuild(playerCharacter);
|
||||||
|
|
||||||
playerCharacter.setBindBuildingID(bindBuilding != null ? bindBuilding.getObjectUUID() : 0);
|
playerCharacter.setBindBuildingID(bindBuilding != null ? bindBuilding.getObjectUUID() : 0);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -40,6 +40,7 @@ public enum LootManager {
|
|||||||
public static final ArrayList<Integer> vorg_ma_uuids = new ArrayList<>(Arrays.asList(27570,188900,188910,188920,188930,188940,188950,189500));
|
public static final ArrayList<Integer> vorg_ma_uuids = new ArrayList<>(Arrays.asList(27570,188900,188910,188920,188930,188940,188950,189500));
|
||||||
public static final ArrayList<Integer> vorg_la_uuids = new ArrayList<>(Arrays.asList(27550,27560,189100,189110,189120,189130,189140,189150));
|
public static final ArrayList<Integer> vorg_la_uuids = new ArrayList<>(Arrays.asList(27550,27560,189100,189110,189120,189130,189140,189150));
|
||||||
public static final ArrayList<Integer> vorg_cloth_uuids = new ArrayList<>(Arrays.asList(27600,188700,188720,189550,189560));
|
public static final ArrayList<Integer> vorg_cloth_uuids = new ArrayList<>(Arrays.asList(27600,188700,188720,189550,189560));
|
||||||
|
public static final ArrayList<Integer> racial_guard_uuids = new ArrayList<>(Arrays.asList(841,951,952,1050,1052,1180,1182,1250,1252,1350,1352,1450,1452,1500,1502,1525,1527,1550,1552,1575,1577,1600,1602,1650,1652,1700,980100,980102));
|
||||||
|
|
||||||
// Drop Rates
|
// Drop Rates
|
||||||
|
|
||||||
@@ -125,26 +126,58 @@ public enum LootManager {
|
|||||||
boolean hotzoneWasRan = false;
|
boolean hotzoneWasRan = false;
|
||||||
float dropRate;
|
float dropRate;
|
||||||
|
|
||||||
if(!mob.getSafeZone()) {
|
if (!mob.getSafeZone()) {
|
||||||
int specialCaseRoll = ThreadLocalRandom.current().nextInt(1, 100000);
|
int contractLow = 1, contractHigh = 400;
|
||||||
//Special Case Contract Drop
|
int runeLow = 401, runeHigh = 800;
|
||||||
if(specialCaseRoll < 100){
|
int resourceLow = 801, resourceHigh = 900;
|
||||||
SpecialCaseResourceDrop(mob,entries);
|
int glassLow = 901, glassHigh = 910;
|
||||||
} else if(specialCaseRoll > 100 && specialCaseRoll < 500){
|
int guardLow = 911, guardHigh = 920;
|
||||||
SpecialCaseContractDrop(mob,entries);
|
|
||||||
}else if(specialCaseRoll > 500 && specialCaseRoll < 900){
|
// Pre-compute adjusted high values
|
||||||
SpecialCaseRuneDrop(mob,entries);
|
int contractAdjust = 0, runeAdjust = 0, resourceAdjust = 0, glassAdjust = 0, guardAdjust = 0;
|
||||||
} else if(specialCaseRoll > 900 && specialCaseRoll < 910){
|
if (mob.level < 50) {
|
||||||
|
int dif = 50 - mob.level;
|
||||||
|
contractAdjust = (int)(400 * (dif * 0.02f));
|
||||||
|
runeAdjust = (int)(400 * (dif * 0.02f));
|
||||||
|
resourceAdjust = (int)(100 * (dif * 0.02f));
|
||||||
|
glassAdjust = (int)(10 * (dif * 0.02f));
|
||||||
|
guardAdjust = (int)(10 * (dif * 0.02f));
|
||||||
|
}
|
||||||
|
|
||||||
|
// Generate a single random roll
|
||||||
|
int specialCaseRoll = ThreadLocalRandom.current().nextInt(1, 100001);
|
||||||
|
|
||||||
|
// Calculate adjusted high values once
|
||||||
|
int contractHighAdjusted = contractHigh - contractAdjust;
|
||||||
|
int runeHighAdjusted = runeHigh - runeAdjust;
|
||||||
|
int resourceHighAdjusted = resourceHigh - resourceAdjust;
|
||||||
|
int glassHighAdjusted = glassHigh - glassAdjust;
|
||||||
|
int guardHighAdjusted = guardHigh - guardAdjust;
|
||||||
|
|
||||||
|
// Check the roll range and handle accordingly
|
||||||
|
if (specialCaseRoll >= contractLow && specialCaseRoll <= contractHighAdjusted) {
|
||||||
|
SpecialCaseContractDrop(mob, entries);
|
||||||
|
} else if (specialCaseRoll >= runeLow && specialCaseRoll <= runeHighAdjusted) {
|
||||||
|
SpecialCaseRuneDrop(mob, entries);
|
||||||
|
} else if (specialCaseRoll >= resourceLow && specialCaseRoll <= resourceHighAdjusted) {
|
||||||
|
SpecialCaseResourceDrop(mob, entries);
|
||||||
|
} else if (specialCaseRoll >= glassLow && specialCaseRoll <= glassHighAdjusted) {
|
||||||
int glassID = rollRandomItem(126);
|
int glassID = rollRandomItem(126);
|
||||||
ItemBase glassItem = ItemBase.getItemBase(glassID);
|
ItemBase glassItem = ItemBase.getItemBase(glassID);
|
||||||
if (glassItem != null) {
|
if (glassItem != null) {
|
||||||
MobLoot toAddGlass = new MobLoot(mob, glassItem, false);
|
MobLoot toAddGlass = new MobLoot(mob, glassItem, false);
|
||||||
|
|
||||||
if (toAddGlass != null)
|
|
||||||
mob.getCharItemManager().addItemToInventory(toAddGlass);
|
mob.getCharItemManager().addItemToInventory(toAddGlass);
|
||||||
}
|
}
|
||||||
|
} else if (specialCaseRoll >= guardLow && specialCaseRoll <= guardHighAdjusted) {
|
||||||
|
int guardContractID = racial_guard_uuids.get(new java.util.Random().nextInt(racial_guard_uuids.size()));
|
||||||
|
ItemBase guardContract = ItemBase.getItemBase(guardContractID);
|
||||||
|
if (guardContract != null) {
|
||||||
|
MobLoot toAddContract = new MobLoot(mob, guardContract, false);
|
||||||
|
mob.getCharItemManager().addItemToInventory(toAddContract);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Iterate all entries in this bootySet and process accordingly
|
// Iterate all entries in this bootySet and process accordingly
|
||||||
for (BootySetEntry bse : entries) {
|
for (BootySetEntry bse : entries) {
|
||||||
|
|||||||
@@ -122,9 +122,9 @@ public enum MaintenanceManager {
|
|||||||
|
|
||||||
|
|
||||||
//no maintenance if day of week doesnt match
|
//no maintenance if day of week doesnt match
|
||||||
if (LocalDateTime.now().getDayOfWeek().ordinal() != building.maintDateTime.getDayOfWeek().ordinal()) {
|
//if (LocalDateTime.now().getDayOfWeek().ordinal() != building.maintDateTime.getDayOfWeek().ordinal()) {
|
||||||
continue;
|
// continue;
|
||||||
}
|
//}
|
||||||
// Add building to maintenance queue
|
// Add building to maintenance queue
|
||||||
|
|
||||||
maintList.add(building);
|
maintList.add(building);
|
||||||
|
|||||||
@@ -68,7 +68,7 @@ public enum MovementManager {
|
|||||||
|
|
||||||
if (toMove.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
if (toMove.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
||||||
if (((PlayerCharacter) toMove).isCasting())
|
if (((PlayerCharacter) toMove).isCasting())
|
||||||
((PlayerCharacter) toMove).update();
|
((PlayerCharacter) toMove).update(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -96,7 +96,7 @@ public enum MovementManager {
|
|||||||
if (!toMove.isMoving())
|
if (!toMove.isMoving())
|
||||||
toMove.resetLastSetLocUpdate();
|
toMove.resetLastSetLocUpdate();
|
||||||
else
|
else
|
||||||
toMove.update();
|
toMove.update(false);
|
||||||
|
|
||||||
// Update movement for the player
|
// Update movement for the player
|
||||||
|
|
||||||
@@ -351,7 +351,7 @@ public enum MovementManager {
|
|||||||
ChatManager.chatSystemInfo((PlayerCharacter) ac, "Finished Alt change, setting the end location to " + ac.getEndLoc().getX() + ' ' + ac.getEndLoc().getZ() + " moving=" + ac.isMoving() + " and current location is " + curLoc.getX() + ' ' + curLoc.getZ());
|
ChatManager.chatSystemInfo((PlayerCharacter) ac, "Finished Alt change, setting the end location to " + ac.getEndLoc().getX() + ' ' + ac.getEndLoc().getZ() + " moving=" + ac.isMoving() + " and current location is " + curLoc.getX() + ' ' + curLoc.getZ());
|
||||||
|
|
||||||
//Send run/walk/sit/stand to tell the client we are flying / landing etc
|
//Send run/walk/sit/stand to tell the client we are flying / landing etc
|
||||||
ac.update();
|
ac.update(false);
|
||||||
ac.stopMovement(ac.getLoc());
|
ac.stopMovement(ac.getLoc());
|
||||||
if (ac.isAlive())
|
if (ac.isAlive())
|
||||||
MovementManager.sendRWSSMsg(ac);
|
MovementManager.sendRWSSMsg(ac);
|
||||||
@@ -408,7 +408,7 @@ public enum MovementManager {
|
|||||||
if (bonus.getBool(ModType.Stunned, SourceType.None) || bonus.getBool(ModType.CannotMove, SourceType.None))
|
if (bonus.getBool(ModType.Stunned, SourceType.None) || bonus.getBool(ModType.CannotMove, SourceType.None))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
member.update();
|
member.update(false);
|
||||||
|
|
||||||
|
|
||||||
// All checks passed, let's move the player
|
// All checks passed, let's move the player
|
||||||
|
|||||||
@@ -2,14 +2,17 @@ package engine.gameManager;
|
|||||||
|
|
||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
|
import engine.exception.SerializationException;
|
||||||
import engine.math.Quaternion;
|
import engine.math.Quaternion;
|
||||||
import engine.math.Vector3f;
|
import engine.math.Vector3f;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
|
import engine.net.ByteBufferWriter;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.msg.PetMsg;
|
import engine.net.client.msg.PetMsg;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
import engine.powers.EffectsBase;
|
import engine.powers.EffectsBase;
|
||||||
|
import engine.server.MBServerStatics;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
@@ -22,6 +25,8 @@ public enum NPCManager {
|
|||||||
|
|
||||||
NPC_MANAGER;
|
NPC_MANAGER;
|
||||||
public static HashMap<Integer, ArrayList<Integer>> _runeSetMap = new HashMap<>();
|
public static HashMap<Integer, ArrayList<Integer>> _runeSetMap = new HashMap<>();
|
||||||
|
public static int SVR_CLOSE_WINDOW = 4;
|
||||||
|
public static HashMap<Integer, ArrayList<String>> _pirateNames = new HashMap<>();
|
||||||
|
|
||||||
public static void LoadAllRuneSets() {
|
public static void LoadAllRuneSets() {
|
||||||
_runeSetMap = DbManager.ItemBaseQueries.LOAD_RUNES_FOR_NPC_AND_MOBS();
|
_runeSetMap = DbManager.ItemBaseQueries.LOAD_RUNES_FOR_NPC_AND_MOBS();
|
||||||
@@ -286,10 +291,10 @@ public enum NPCManager {
|
|||||||
// If we cannot find name for this mobbase then
|
// If we cannot find name for this mobbase then
|
||||||
// fallback to human male
|
// fallback to human male
|
||||||
|
|
||||||
if (NPC._pirateNames.containsKey(mobBaseID))
|
if (_pirateNames.containsKey(mobBaseID))
|
||||||
nameList = NPC._pirateNames.get(mobBaseID);
|
nameList = _pirateNames.get(mobBaseID);
|
||||||
else
|
else
|
||||||
nameList = NPC._pirateNames.get(2111);
|
nameList = _pirateNames.get(2111);
|
||||||
|
|
||||||
if (nameList == null) {
|
if (nameList == null) {
|
||||||
Logger.error("Null name list for 2111!");
|
Logger.error("Null name list for 2111!");
|
||||||
@@ -370,4 +375,384 @@ public enum NPCManager {
|
|||||||
|
|
||||||
return buildingSlot;
|
return buildingSlot;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static boolean ISWallArcher(Contract contract) {
|
||||||
|
|
||||||
|
if (contract == null)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
//838, 950, 1051, 1181, 1251, 1351, 1451, 1501, 1526, 1551, 980101,
|
||||||
|
|
||||||
|
return contract.getAllowedBuildings().contains(Enum.BuildingGroup.WALLCORNER) ||
|
||||||
|
contract.getAllowedBuildings().contains(Enum.BuildingGroup.WALLSTRAIGHTTOWER);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static NPC getFromCache(int id) {
|
||||||
|
return (NPC) DbManager.getFromCache(Enum.GameObjectType.NPC, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean UpdateName(NPC npc, String value) {
|
||||||
|
|
||||||
|
if (!DbManager.NPCQueries.UPDATE_NAME(npc, value))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
npc.setName(value);
|
||||||
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void serializeNpcForClientMsgOtherPlayer(NPC npc, ByteBufferWriter writer, boolean hideAsciiLastName)
|
||||||
|
throws SerializationException {
|
||||||
|
serializeForClientMsgOtherPlayer(npc, writer);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void serializeForClientMsgOtherPlayer(NPC npc, ByteBufferWriter writer)
|
||||||
|
throws SerializationException {
|
||||||
|
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
//num Runes
|
||||||
|
int cnt = 3;
|
||||||
|
boolean isVamp = false, isHealer = false, isArcher = false, isTrainer = false;
|
||||||
|
int contractID = 0, classID = 0;
|
||||||
|
int extraRune = 0;
|
||||||
|
|
||||||
|
if (npc.contract != null) {
|
||||||
|
contractID = npc.contract.getContractID();
|
||||||
|
classID = npc.contract.getClassID();
|
||||||
|
extraRune = npc.contract.getExtraRune();
|
||||||
|
|
||||||
|
if (extraRune == contractID)
|
||||||
|
extraRune = 0;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((contractID > 252642 && contractID < 252647) || contractID == 252652) {
|
||||||
|
isVamp = true;
|
||||||
|
cnt++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contractID == 252582 || contractID == 252579 || contractID == 252581
|
||||||
|
|| contractID == 252584 || contractID == 252597 || contractID == 252598
|
||||||
|
|| contractID == 252628 || extraRune == 252582 || extraRune == 252579
|
||||||
|
|| extraRune == 252581 || extraRune == 252584 || extraRune == 252597
|
||||||
|
|| extraRune == 252598 || extraRune == 252628) {
|
||||||
|
isHealer = true;
|
||||||
|
cnt++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (contractID == 252570) {
|
||||||
|
isArcher = true;
|
||||||
|
cnt++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (classID != 0)
|
||||||
|
cnt++;
|
||||||
|
|
||||||
|
if (extraRune != 0 && extraRune != contractID)
|
||||||
|
cnt++;
|
||||||
|
|
||||||
|
writer.putInt(cnt);
|
||||||
|
|
||||||
|
//Race
|
||||||
|
writer.putInt(1);
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
if (npc.getMobBase() != null)
|
||||||
|
writer.putInt(npc.getMobBase().getLoadID());
|
||||||
|
else
|
||||||
|
writer.putInt(2011);
|
||||||
|
|
||||||
|
writer.putInt(Enum.GameObjectType.NPCRaceRune.ordinal());
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
|
||||||
|
//Class/Trainer/Whatever
|
||||||
|
writer.putInt(5);
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
if (npc.contract != null)
|
||||||
|
writer.putInt(contractID);
|
||||||
|
else
|
||||||
|
writer.putInt(2500);
|
||||||
|
|
||||||
|
writer.putInt(Enum.GameObjectType.NPCClassRune.ordinal());
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
|
||||||
|
//vampire trainer
|
||||||
|
cnt = 0;
|
||||||
|
|
||||||
|
if (extraRune != 0)
|
||||||
|
cnt = serializeExtraRune(npc, extraRune, cnt, writer);
|
||||||
|
if (isVamp)
|
||||||
|
cnt = serializeExtraRune(npc, 252647, cnt, writer);
|
||||||
|
|
||||||
|
//Healer trainer
|
||||||
|
if (isHealer)
|
||||||
|
cnt = serializeExtraRune(npc, 252592, cnt, writer);
|
||||||
|
|
||||||
|
if (classID != 0) {
|
||||||
|
writer.putInt(4);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(classID);
|
||||||
|
writer.putInt(Enum.GameObjectType.NPCExtraRune.ordinal());
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Scout trainer
|
||||||
|
if (isArcher)
|
||||||
|
cnt = serializeExtraRune(npc, 252654, cnt, writer);
|
||||||
|
|
||||||
|
//Shopkeeper
|
||||||
|
writer.putInt(5);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0x3DACC);
|
||||||
|
writer.putInt(Enum.GameObjectType.NPCShopkeeperRune.ordinal());
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
|
||||||
|
//Send Stats
|
||||||
|
writer.putInt(5);
|
||||||
|
writer.putInt(0x8AC3C0E6); //Str
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0xACB82E33); //Dex
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0xB15DC77E); //Con
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0xE07B3336); //Int
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0xFF665EC3); //Spi
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
writer.putString(npc.getName());
|
||||||
|
writer.putString("");
|
||||||
|
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
writer.put((byte) 0);
|
||||||
|
writer.putInt(npc.getObjectType().ordinal());
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
|
||||||
|
writer.putFloat(1.0f);
|
||||||
|
writer.putFloat(1.0f);
|
||||||
|
writer.putFloat(1.0f);
|
||||||
|
|
||||||
|
if (npc.region != null)
|
||||||
|
writer.putVector3f(ZoneManager.convertWorldToLocal(npc.building, npc.getLoc()));
|
||||||
|
else
|
||||||
|
writer.putVector3f(npc.getLoc());
|
||||||
|
|
||||||
|
//Rotation
|
||||||
|
float radians = (float) Math.acos(npc.getRot().y) * 2;
|
||||||
|
|
||||||
|
if (npc.building != null)
|
||||||
|
if (npc.building.getBounds() != null && npc.building.getBounds().getQuaternion() != null)
|
||||||
|
radians += (npc.building.getBounds().getQuaternion()).angleY;
|
||||||
|
|
||||||
|
writer.putFloat(radians);
|
||||||
|
|
||||||
|
//Running Speed
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
// get a copy of the equipped items.
|
||||||
|
|
||||||
|
if (npc.equip != null) {
|
||||||
|
writer.putInt(npc.equip.size());
|
||||||
|
|
||||||
|
for (MobEquipment me : npc.equip.values())
|
||||||
|
MobEquipment.serializeForClientMsg(me, writer);
|
||||||
|
} else
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
writer.putInt((npc.level / 10));
|
||||||
|
writer.putInt(npc.level);
|
||||||
|
writer.putInt(npc.getIsSittingAsInt()); //Standing
|
||||||
|
writer.putInt(npc.getIsWalkingAsInt()); //Walking
|
||||||
|
writer.putInt(npc.getIsCombatAsInt()); //Combat
|
||||||
|
writer.putInt(2); //Unknown
|
||||||
|
writer.putInt(1); //Unknown - Headlights?
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
if (npc.building != null && npc.region != null) {
|
||||||
|
writer.putInt(npc.building.getObjectType().ordinal());
|
||||||
|
writer.putInt(npc.building.getObjectUUID());
|
||||||
|
} else {
|
||||||
|
writer.putInt(0); //<-Building Object Type
|
||||||
|
writer.putInt(0); //<-Building Object ID
|
||||||
|
}
|
||||||
|
writer.put((byte) 0);
|
||||||
|
writer.put((byte) 0);
|
||||||
|
writer.put((byte) 0);
|
||||||
|
|
||||||
|
//npc dialog menus from contracts
|
||||||
|
|
||||||
|
if (npc.contract != null) {
|
||||||
|
ArrayList<Integer> npcMenuOptions = npc.contract.getNPCMenuOptions();
|
||||||
|
writer.putInt(npcMenuOptions.size());
|
||||||
|
for (Integer val : npcMenuOptions) {
|
||||||
|
writer.putInt(val);
|
||||||
|
}
|
||||||
|
|
||||||
|
} else
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
writer.put((byte) 1);
|
||||||
|
|
||||||
|
if (npc.building != null) {
|
||||||
|
writer.putInt(Enum.GameObjectType.StrongBox.ordinal());
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
writer.putInt(Enum.GameObjectType.StrongBox.ordinal());
|
||||||
|
writer.putInt(npc.building.getObjectUUID());
|
||||||
|
} else {
|
||||||
|
writer.putLong(0);
|
||||||
|
writer.putLong(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (npc.contract != null)
|
||||||
|
writer.putInt(npc.contract.getIconID());
|
||||||
|
else
|
||||||
|
writer.putInt(0); //npc icon ID
|
||||||
|
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putShort((short) 0);
|
||||||
|
|
||||||
|
if (npc.contract != null && npc.contract.isTrainer()) {
|
||||||
|
writer.putInt(classID);
|
||||||
|
} else {
|
||||||
|
writer.putInt(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (npc.contract != null && npc.contract.isTrainer())
|
||||||
|
writer.putInt(classID);
|
||||||
|
else
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
writer.putFloat(4);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.put((byte) 0);
|
||||||
|
|
||||||
|
//Pull guild info from building if linked to one
|
||||||
|
|
||||||
|
Guild.serializeForClientMsg(npc.guild, writer, null, true);
|
||||||
|
|
||||||
|
writer.putInt(1);
|
||||||
|
writer.putInt(0x8A2E);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(0);
|
||||||
|
|
||||||
|
//TODO Guard
|
||||||
|
writer.put((byte) 0); //Is guard..
|
||||||
|
|
||||||
|
writer.putFloat(1500f); //npc.healthMax
|
||||||
|
writer.putFloat(1500f); //npc.health
|
||||||
|
|
||||||
|
//TODO Peace Zone
|
||||||
|
writer.put((byte) 1); //0=show tags, 1=don't
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.put((byte) 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static int serializeExtraRune(NPC npc, int runeID, int cnt, ByteBufferWriter writer) {
|
||||||
|
|
||||||
|
writer.putInt(5);
|
||||||
|
writer.putInt(0);
|
||||||
|
writer.putInt(runeID);
|
||||||
|
|
||||||
|
if (cnt == 0)
|
||||||
|
writer.putInt(Enum.GameObjectType.NPCClassRuneTwo.ordinal());
|
||||||
|
else
|
||||||
|
writer.putInt(Enum.GameObjectType.NPCClassRuneThree.ordinal());
|
||||||
|
|
||||||
|
writer.putInt(npc.currentID);
|
||||||
|
return cnt + 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static NPC createNPC(String name, int contractID, Vector3fImmutable spawn, Guild guild, Zone parent, short level, Building building) {
|
||||||
|
|
||||||
|
NPC newNPC = new NPC();
|
||||||
|
|
||||||
|
newNPC.setName(name);
|
||||||
|
newNPC.contractUUID = contractID;
|
||||||
|
|
||||||
|
if (building == null)
|
||||||
|
newNPC.bindLoc = spawn;
|
||||||
|
else
|
||||||
|
newNPC.bindLoc = Vector3fImmutable.ZERO;
|
||||||
|
|
||||||
|
newNPC.parentZoneUUID = parent.getObjectUUID();
|
||||||
|
newNPC.guildUUID = guild.getObjectUUID();
|
||||||
|
|
||||||
|
if (building == null)
|
||||||
|
newNPC.buildingUUID = 0;
|
||||||
|
else
|
||||||
|
newNPC.buildingUUID = building.getObjectUUID();
|
||||||
|
|
||||||
|
newNPC.level = level;
|
||||||
|
|
||||||
|
newNPC.buyPercent = .33f;
|
||||||
|
newNPC.sellPercent = 1;
|
||||||
|
|
||||||
|
NPC npc;
|
||||||
|
|
||||||
|
try {
|
||||||
|
npc = DbManager.NPCQueries.PERSIST(newNPC);
|
||||||
|
npc.setObjectTypeMask(MBServerStatics.MASK_NPC);
|
||||||
|
} catch (Exception e) {
|
||||||
|
Logger.error(e);
|
||||||
|
npc = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
return npc;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static NPC getNPC(int id) {
|
||||||
|
|
||||||
|
if (id == 0)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
NPC npc = (NPC) DbManager.getFromCache(Enum.GameObjectType.NPC, id);
|
||||||
|
|
||||||
|
if (npc != null)
|
||||||
|
return npc;
|
||||||
|
|
||||||
|
return DbManager.NPCQueries.GET_NPC(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean ISGuardCaptain(int contractID) {
|
||||||
|
return Enum.MinionType.ContractToMinionMap.containsKey(contractID);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean UpdateEquipSetID(NPC npc, int equipSetID) {
|
||||||
|
|
||||||
|
if (!LootManager._bootySetMap.containsKey(equipSetID))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (!DbManager.NPCQueries.UPDATE_EQUIPSET(npc, equipSetID))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
npc.equipmentSetID = equipSetID;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static boolean UpdateRaceID(NPC npc, int raceID) {
|
||||||
|
|
||||||
|
if (!DbManager.NPCQueries.UPDATE_MOBBASE(npc, raceID))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
npc.loadID = raceID;
|
||||||
|
npc.mobBase = MobBase.getMobBase(npc.loadID);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static NPCProfits GetNPCProfits(NPC npc) {
|
||||||
|
return NPCProfits.ProfitCache.get(npc.currentID);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
@@ -8,7 +8,6 @@
|
|||||||
|
|
||||||
package engine.gameManager;
|
package engine.gameManager;
|
||||||
|
|
||||||
import com.sun.corba.se.spi.orbutil.fsm.ActionBase;
|
|
||||||
import engine.Enum.*;
|
import engine.Enum.*;
|
||||||
import engine.InterestManagement.HeightMap;
|
import engine.InterestManagement.HeightMap;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
@@ -28,7 +27,6 @@ import engine.net.client.ClientConnection;
|
|||||||
import engine.net.client.msg.*;
|
import engine.net.client.msg.*;
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
import engine.powers.*;
|
import engine.powers.*;
|
||||||
import engine.powers.effectmodifiers.AbstractEffectModifier;
|
|
||||||
import engine.powers.poweractions.AbstractPowerAction;
|
import engine.powers.poweractions.AbstractPowerAction;
|
||||||
import engine.powers.poweractions.TrackPowerAction;
|
import engine.powers.poweractions.TrackPowerAction;
|
||||||
import engine.server.MBServerStatics;
|
import engine.server.MBServerStatics;
|
||||||
@@ -165,6 +163,14 @@ public enum PowersManager {
|
|||||||
public static void usePower(final PerformActionMsg msg, ClientConnection origin,
|
public static void usePower(final PerformActionMsg msg, ClientConnection origin,
|
||||||
boolean sendCastToSelf) {
|
boolean sendCastToSelf) {
|
||||||
|
|
||||||
|
PlayerCharacter pc = SessionManager.getPlayerCharacter(origin);
|
||||||
|
|
||||||
|
if(!PlayerManager.isFlying(pc)) //cant be sitting if flying
|
||||||
|
CombatManager.toggleSit(false,origin);
|
||||||
|
|
||||||
|
if(pc.isMoving())
|
||||||
|
pc.stopMovement(pc.getMovementLoc());
|
||||||
|
|
||||||
if (usePowerA(msg, origin, sendCastToSelf)) {
|
if (usePowerA(msg, origin, sendCastToSelf)) {
|
||||||
// Cast failed for some reason, reset timer
|
// Cast failed for some reason, reset timer
|
||||||
|
|
||||||
@@ -173,13 +179,10 @@ public enum PowersManager {
|
|||||||
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.PRIMARY);
|
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.PRIMARY);
|
||||||
|
|
||||||
// Send Fail to cast message
|
// Send Fail to cast message
|
||||||
PlayerCharacter pc = SessionManager
|
|
||||||
.getPlayerCharacter(origin);
|
|
||||||
|
|
||||||
if (pc != null) {
|
if (pc != null) {
|
||||||
sendPowerMsg(pc, 2, msg);
|
sendPowerMsg(pc, 2, msg);
|
||||||
if (pc.isCasting()) {
|
if (pc.isCasting()) {
|
||||||
pc.update();
|
pc.update(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
pc.setIsCasting(false);
|
pc.setIsCasting(false);
|
||||||
@@ -291,7 +294,7 @@ public enum PowersManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//check for movement buffs while flying
|
//check for movement buffs while flying
|
||||||
if(playerCharacter.isFlying()) {
|
if(PlayerManager.isFlying(playerCharacter)) {
|
||||||
switch(pb.token){
|
switch(pb.token){
|
||||||
case 429005674:
|
case 429005674:
|
||||||
case 429505739:
|
case 429505739:
|
||||||
@@ -591,7 +594,7 @@ public enum PowersManager {
|
|||||||
|
|
||||||
// make person casting stand up if spell (unless they're casting a chant which does not make them stand up)
|
// make person casting stand up if spell (unless they're casting a chant which does not make them stand up)
|
||||||
if (pb.isSpell() && !pb.isChant() && playerCharacter.isSit()) {
|
if (pb.isSpell() && !pb.isChant() && playerCharacter.isSit()) {
|
||||||
playerCharacter.update();
|
playerCharacter.update(false);
|
||||||
playerCharacter.setSit(false);
|
playerCharacter.setSit(false);
|
||||||
UpdateStateMsg updateStateMsg = new UpdateStateMsg(playerCharacter);
|
UpdateStateMsg updateStateMsg = new UpdateStateMsg(playerCharacter);
|
||||||
DispatchMessage.dispatchMsgToInterestArea(playerCharacter, updateStateMsg, DispatchChannel.PRIMARY, MBServerStatics.CHARACTER_LOAD_RANGE, true, false);
|
DispatchMessage.dispatchMsgToInterestArea(playerCharacter, updateStateMsg, DispatchChannel.PRIMARY, MBServerStatics.CHARACTER_LOAD_RANGE, true, false);
|
||||||
@@ -614,7 +617,7 @@ public enum PowersManager {
|
|||||||
|
|
||||||
|
|
||||||
if (time > 100) {
|
if (time > 100) {
|
||||||
playerCharacter.update();
|
playerCharacter.update(false);
|
||||||
playerCharacter.setIsCasting(true);
|
playerCharacter.setIsCasting(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -784,15 +787,19 @@ public enum PowersManager {
|
|||||||
if (playerCharacter == null || msg == null)
|
if (playerCharacter == null || msg == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if((msg.getPowerUsedID() == 429495514 || msg.getPowerUsedID() == 429407306) && playerCharacter.getRace().getName().toLowerCase().contains("shade")){
|
//if((msg.getPowerUsedID() == 429495514 || msg.getPowerUsedID() == 429407306) && playerCharacter.getRace().getName().toLowerCase().contains("shade")){
|
||||||
//msg.setPowerUsedID(407015607);
|
// //use sneak instead of hide
|
||||||
applyPower(playerCharacter,playerCharacter,playerCharacter.loc,429397210,msg.getNumTrains(),false);
|
// PowersBase pb = PowersManager.getPowerByToken(429397210);
|
||||||
}
|
// int offsetTrains = (40 - msg.getNumTrains()) ;
|
||||||
|
// applyPower(playerCharacter,playerCharacter,playerCharacter.loc,429397210,msg.getNumTrains(),false);
|
||||||
|
// applyPower(playerCharacter,playerCharacter,playerCharacter.loc,427857146,offsetTrains,false);
|
||||||
|
//}
|
||||||
if(msg.getPowerUsedID() == 429494441) {//wildkins chase
|
if(msg.getPowerUsedID() == 429494441) {//wildkins chase
|
||||||
playerCharacter.removeEffectBySource(EffectSourceType.Root,40,true);
|
playerCharacter.removeEffectBySource(EffectSourceType.Root,40,true);
|
||||||
|
playerCharacter.removeEffectBySource(EffectSourceType.Snare,40,true);
|
||||||
}
|
}
|
||||||
if (playerCharacter.isCasting()) {
|
if (playerCharacter.isCasting()) {
|
||||||
playerCharacter.update();
|
playerCharacter.update(false);
|
||||||
playerCharacter.updateStamRegen(-100);
|
playerCharacter.updateStamRegen(-100);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1356,7 +1363,7 @@ public enum PowersManager {
|
|||||||
if (pc == null)
|
if (pc == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
PlayerCharacter source = PlayerCharacter.getFromCache(msg.getSourceID());
|
PlayerCharacter source = PlayerManager.getFromCache(msg.getSourceID());
|
||||||
if (source == null)
|
if (source == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@@ -2318,7 +2325,7 @@ public enum PowersManager {
|
|||||||
|
|
||||||
// set player is not casting for regens
|
// set player is not casting for regens
|
||||||
if (pc.isCasting()) {
|
if (pc.isCasting()) {
|
||||||
pc.update();
|
pc.update(false);
|
||||||
}
|
}
|
||||||
pc.setIsCasting(false);
|
pc.setIsCasting(false);
|
||||||
|
|
||||||
@@ -2690,7 +2697,7 @@ public enum PowersManager {
|
|||||||
|
|
||||||
public static void cancelOnStun(AbstractCharacter ac) {
|
public static void cancelOnStun(AbstractCharacter ac) {
|
||||||
if(ac.getObjectType().equals(GameObjectType.PlayerCharacter)){
|
if(ac.getObjectType().equals(GameObjectType.PlayerCharacter)){
|
||||||
PlayerCharacter.GroundPlayer((PlayerCharacter)ac);
|
//PlayerCharacter.GroundPlayer((PlayerCharacter)ac);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -113,9 +113,18 @@ public enum SimulationManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if ((_cityPulseTime != 0)
|
if ((_cityPulseTime != 0) && (System.currentTimeMillis() > _cityPulseTime)) {
|
||||||
&& (System.currentTimeMillis() > _cityPulseTime))
|
try {
|
||||||
pulseCities();
|
pulseCities();
|
||||||
|
}catch(Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
ArenaManager.pulseArenas();
|
||||||
|
}catch(Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Logger.error(
|
Logger.error(
|
||||||
"Fatal error in City Pulse: DISABLED. Error Message : "
|
"Fatal error in City Pulse: DISABLED. Error Message : "
|
||||||
@@ -151,7 +160,7 @@ public enum SimulationManager {
|
|||||||
|
|
||||||
if (player == null)
|
if (player == null)
|
||||||
continue;
|
continue;
|
||||||
player.update();
|
player.update(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
_updatePulseTime = System.currentTimeMillis() + 500;
|
_updatePulseTime = System.currentTimeMillis() + 500;
|
||||||
|
|||||||
@@ -151,7 +151,7 @@ public enum TradeManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public static void invalidTradeRequest(InvalidTradeRequestMsg msg) {
|
public static void invalidTradeRequest(InvalidTradeRequestMsg msg) {
|
||||||
PlayerCharacter requester = PlayerCharacter.getFromCache(msg.getRequesterID());
|
PlayerCharacter requester = PlayerManager.getFromCache(msg.getRequesterID());
|
||||||
Dispatch dispatch;
|
Dispatch dispatch;
|
||||||
|
|
||||||
dispatch = Dispatch.borrow(requester, msg);
|
dispatch = Dispatch.borrow(requester, msg);
|
||||||
|
|||||||
@@ -4,14 +4,13 @@ public class ZergManager {
|
|||||||
|
|
||||||
public static float getCurrentMultiplier(int count, int maxCount){
|
public static float getCurrentMultiplier(int count, int maxCount){
|
||||||
switch(maxCount) {
|
switch(maxCount) {
|
||||||
case 3:
|
case 3: return getMultiplier3Man(count);
|
||||||
return getMultiplier3Man(count);
|
case 5: return getMultiplier5Man(count);
|
||||||
case 5:
|
case 10: return getMultiplier10Man(count);
|
||||||
return getMultiplier5Man(count);
|
case 20: return getMultiplier20Man(count);
|
||||||
case 10:
|
case 30: return getMultiplier30Man(count);
|
||||||
return getMultiplier10Man(count);
|
case 40: return getMultiplier40Man(count);
|
||||||
default:
|
default: return 1.0f; //unlimited
|
||||||
return getMultiplier20Man(count);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public static float getMultiplier3Man(int count) {
|
public static float getMultiplier3Man(int count) {
|
||||||
@@ -22,15 +21,11 @@ public class ZergManager {
|
|||||||
return 0.0f;
|
return 0.0f;
|
||||||
|
|
||||||
switch(count){
|
switch(count){
|
||||||
case 4:
|
case 4: return 0.63f;
|
||||||
return 0.75f;
|
case 5: return 0.40f;
|
||||||
case 5:
|
case 6: return 0.25f;
|
||||||
return 0.60f;
|
default: return 1.0f;
|
||||||
case 6:
|
|
||||||
return 0.37f;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
return 1.0f;
|
|
||||||
}
|
}
|
||||||
public static float getMultiplier5Man(int count) {
|
public static float getMultiplier5Man(int count) {
|
||||||
if(count < 6)
|
if(count < 6)
|
||||||
@@ -40,19 +35,13 @@ public class ZergManager {
|
|||||||
return 0.0f;
|
return 0.0f;
|
||||||
|
|
||||||
switch(count){
|
switch(count){
|
||||||
case 6:
|
case 6: return 0.75f;
|
||||||
return 0.75f;
|
case 7: return 0.57f;
|
||||||
case 7:
|
case 8: return 0.44f;
|
||||||
return 0.67f;
|
case 9: return 0.33f;
|
||||||
case 8:
|
case 10: return 0.25f;
|
||||||
return 0.56f;
|
default: return 1.0f;
|
||||||
case 9:
|
|
||||||
return 0.43f;
|
|
||||||
case 10:
|
|
||||||
return 0.25f;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
return 1.0f;
|
|
||||||
}
|
}
|
||||||
public static float getMultiplier10Man(int count) {
|
public static float getMultiplier10Man(int count) {
|
||||||
if(count < 11)
|
if(count < 11)
|
||||||
@@ -62,31 +51,145 @@ public class ZergManager {
|
|||||||
return 0.0f;
|
return 0.0f;
|
||||||
|
|
||||||
switch(count){
|
switch(count){
|
||||||
case 11:
|
case 11: return 0.86f;
|
||||||
return 0.75f;
|
case 12: return 0.75f;
|
||||||
case 12:
|
case 13: return 0.65f;
|
||||||
return 0.71f;
|
case 14: return 0.57f;
|
||||||
case 13:
|
case 15: return 0.50f;
|
||||||
return 0.67f;
|
case 16: return 0.44f;
|
||||||
case 14:
|
case 17: return 0.38f;
|
||||||
return 0.62f;
|
case 18: return 0.33f;
|
||||||
case 15:
|
case 19: return 0.29f;
|
||||||
return 0.56f;
|
case 20: return 0.25f;
|
||||||
case 16:
|
default: return 1.0f;
|
||||||
return 0.50f;
|
|
||||||
case 17:
|
|
||||||
return 0.43f;
|
|
||||||
case 18:
|
|
||||||
return 0.35f;
|
|
||||||
case 19:
|
|
||||||
return 0.25f;
|
|
||||||
case 20:
|
|
||||||
return 0.14f;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
return 1.0f;
|
|
||||||
}
|
}
|
||||||
public static float getMultiplier20Man(int count) {
|
public static float getMultiplier20Man(int count) {
|
||||||
return getMultiplier10Man(count * 2);
|
if(count < 21)
|
||||||
|
return 1.0f;
|
||||||
|
|
||||||
|
if(count > 40)
|
||||||
|
return 0.0f;
|
||||||
|
|
||||||
|
switch (count)
|
||||||
|
{
|
||||||
|
case 21: return 0.93f;
|
||||||
|
case 22: return 0.86f;
|
||||||
|
case 23: return 0.80f;
|
||||||
|
case 24: return 0.75f;
|
||||||
|
case 25: return 0.70f;
|
||||||
|
case 26: return 0.65f;
|
||||||
|
case 27: return 0.61f;
|
||||||
|
case 28: return 0.57f;
|
||||||
|
case 29: return 0.53f;
|
||||||
|
case 30: return 0.50f;
|
||||||
|
case 31: return 0.47f;
|
||||||
|
case 32: return 0.44f;
|
||||||
|
case 33: return 0.41f;
|
||||||
|
case 34: return 0.38f;
|
||||||
|
case 35: return 0.36f;
|
||||||
|
case 36: return 0.33f;
|
||||||
|
case 37: return 0.31f;
|
||||||
|
case 38: return 0.29f;
|
||||||
|
case 39: return 0.27f;
|
||||||
|
case 40: return 0.25f;
|
||||||
|
default: return 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
public static float getMultiplier30Man(int count) {
|
||||||
|
if(count < 31)
|
||||||
|
return 1.0f;
|
||||||
|
|
||||||
|
if(count > 60)
|
||||||
|
return 0.0f;
|
||||||
|
|
||||||
|
switch (count)
|
||||||
|
{
|
||||||
|
case 31: return 0.95f;
|
||||||
|
case 32: return 0.91f;
|
||||||
|
case 33: return 0.86f;
|
||||||
|
case 34: return 0.82f;
|
||||||
|
case 35: return 0.79f;
|
||||||
|
case 36: return 0.75f;
|
||||||
|
case 37: return 0.72f;
|
||||||
|
case 38: return 0.68f;
|
||||||
|
case 39: return 0.65f;
|
||||||
|
case 40: return 0.63f;
|
||||||
|
case 41: return 0.60f;
|
||||||
|
case 42: return 0.57f;
|
||||||
|
case 43: return 0.55f;
|
||||||
|
case 44: return 0.52f;
|
||||||
|
case 45: return 0.50f;
|
||||||
|
case 46: return 0.48f;
|
||||||
|
case 47: return 0.46f;
|
||||||
|
case 48: return 0.44f;
|
||||||
|
case 49: return 0.42f;
|
||||||
|
case 50: return 0.40f;
|
||||||
|
case 51: return 0.38f;
|
||||||
|
case 52: return 0.37f;
|
||||||
|
case 53: return 0.35f;
|
||||||
|
case 54: return 0.33f;
|
||||||
|
case 55: return 0.32f;
|
||||||
|
case 56: return 0.30f;
|
||||||
|
case 57: return 0.29f;
|
||||||
|
case 58: return 0.28f;
|
||||||
|
case 59: return 0.26f;
|
||||||
|
case 60: return 0.25f;
|
||||||
|
default: return 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
public static float getMultiplier40Man(int count) {
|
||||||
|
if(count < 41)
|
||||||
|
return 1.0f;
|
||||||
|
|
||||||
|
if(count > 80)
|
||||||
|
return 0.0f;
|
||||||
|
|
||||||
|
switch (count)
|
||||||
|
{
|
||||||
|
case 41: return 0.96f;
|
||||||
|
case 42: return 0.93f;
|
||||||
|
case 43: return 0.90f;
|
||||||
|
case 44: return 0.86f;
|
||||||
|
case 45: return 0.83f;
|
||||||
|
case 46: return 0.80f;
|
||||||
|
case 47: return 0.78f;
|
||||||
|
case 48: return 0.75f;
|
||||||
|
case 49: return 0.72f;
|
||||||
|
case 50: return 0.70f;
|
||||||
|
case 51: return 0.68f;
|
||||||
|
case 52: return 0.65f;
|
||||||
|
case 53: return 0.63f;
|
||||||
|
case 54: return 0.61f;
|
||||||
|
case 55: return 0.59f;
|
||||||
|
case 56: return 0.57f;
|
||||||
|
case 57: return 0.55f;
|
||||||
|
case 58: return 0.53f;
|
||||||
|
case 59: return 0.52f;
|
||||||
|
case 60: return 0.50f;
|
||||||
|
case 61: return 0.48f;
|
||||||
|
case 62: return 0.47f;
|
||||||
|
case 63: return 0.45f;
|
||||||
|
case 64: return 0.44f;
|
||||||
|
case 65: return 0.42f;
|
||||||
|
case 66: return 0.41f;
|
||||||
|
case 67: return 0.40f;
|
||||||
|
case 68: return 0.38f;
|
||||||
|
case 69: return 0.37f;
|
||||||
|
case 70: return 0.36f;
|
||||||
|
case 71: return 0.35f;
|
||||||
|
case 72: return 0.33f;
|
||||||
|
case 73: return 0.32f;
|
||||||
|
case 74: return 0.31f;
|
||||||
|
case 75: return 0.30f;
|
||||||
|
case 76: return 0.29f;
|
||||||
|
case 77: return 0.28f;
|
||||||
|
case 78: return 0.27f;
|
||||||
|
case 79: return 0.26f;
|
||||||
|
case 80: return 0.25f;
|
||||||
|
default: return 1.0f;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.jobs;
|
|||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.job.AbstractScheduleJob;
|
import engine.job.AbstractScheduleJob;
|
||||||
import engine.objects.AbstractGameObject;
|
import engine.objects.AbstractGameObject;
|
||||||
import engine.objects.Building;
|
import engine.objects.Building;
|
||||||
@@ -39,7 +40,7 @@ public class DatabaseUpdateJob extends AbstractScheduleJob {
|
|||||||
|
|
||||||
switch (this.type) {
|
switch (this.type) {
|
||||||
case "Skills":
|
case "Skills":
|
||||||
pc.updateSkillsAndPowersToDatabase();
|
PlayerManager.updateSkillsAndPowersToDatabase(pc);
|
||||||
break;
|
break;
|
||||||
case "Stats":
|
case "Stats":
|
||||||
DbManager.PlayerCharacterQueries.UPDATE_CHARACTER_STATS(pc);
|
DbManager.PlayerCharacterQueries.UPDATE_CHARACTER_STATS(pc);
|
||||||
|
|||||||
@@ -11,7 +11,7 @@ package engine.jobs;
|
|||||||
|
|
||||||
import engine.Enum.ModType;
|
import engine.Enum.ModType;
|
||||||
import engine.Enum.SourceType;
|
import engine.Enum.SourceType;
|
||||||
import engine.gameManager.PowersManager;
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.job.AbstractScheduleJob;
|
import engine.job.AbstractScheduleJob;
|
||||||
import engine.job.JobContainer;
|
import engine.job.JobContainer;
|
||||||
import engine.net.client.msg.ErrorPopupMsg;
|
import engine.net.client.msg.ErrorPopupMsg;
|
||||||
@@ -64,7 +64,7 @@ public class FinishSummonsJob extends AbstractScheduleJob {
|
|||||||
if (this.source.region != null)
|
if (this.source.region != null)
|
||||||
this.target.setRegion(this.source.region);
|
this.target.setRegion(this.source.region);
|
||||||
//teleport target to source
|
//teleport target to source
|
||||||
target.teleport(source.getLoc());
|
PlayerManager.teleport(target, source.getLoc());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
package engine.jobs;
|
package engine.jobs;
|
||||||
|
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.job.AbstractScheduleJob;
|
import engine.job.AbstractScheduleJob;
|
||||||
import engine.math.Bounds;
|
import engine.math.Bounds;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
@@ -69,7 +70,7 @@ public class StuckJob extends AbstractScheduleJob {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
player.teleport(stuckLoc);
|
PlayerManager.teleport(player, stuckLoc);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -9,6 +9,7 @@
|
|||||||
|
|
||||||
package engine.jobs;
|
package engine.jobs;
|
||||||
|
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.job.AbstractScheduleJob;
|
import engine.job.AbstractScheduleJob;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -52,7 +53,7 @@ public class TeleportJob extends AbstractScheduleJob {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
|
|
||||||
if (this.setSafeMode)
|
if (this.setSafeMode)
|
||||||
pc.setSafeMode();
|
pc.setSafeMode();
|
||||||
|
|||||||
@@ -52,7 +52,7 @@ public class ItemTableEntry {
|
|||||||
itemTableEntryList = LootManager._itemTables.get(itemTable);
|
itemTableEntryList = LootManager._itemTables.get(itemTable);
|
||||||
|
|
||||||
if(itemTableEntryList != null && itemTableEntryList.size() > 1){
|
if(itemTableEntryList != null && itemTableEntryList.size() > 1){
|
||||||
id = itemTableEntryList.get(ThreadLocalRandom.current().nextInt(0,itemTableEntryList.size() - 1)).cacheID;
|
id = itemTableEntryList.get(ThreadLocalRandom.current().nextInt(0, itemTableEntryList.size())).cacheID;
|
||||||
}
|
}
|
||||||
return id;
|
return id;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -220,7 +220,7 @@ public class Bounds {
|
|||||||
//player is inside building region, skip collision check. we only do collision from the outside.
|
//player is inside building region, skip collision check. we only do collision from the outside.
|
||||||
if (player.region != null && player.region.parentBuildingID == building.getObjectUUID())
|
if (player.region != null && player.region.parentBuildingID == building.getObjectUUID())
|
||||||
continue;
|
continue;
|
||||||
if (building.getBounds().colliders == null)
|
if (building.getBounds() == null || building.getBounds().colliders == null)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
for (Colliders collider : building.getBounds().colliders) {
|
for (Colliders collider : building.getBounds().colliders) {
|
||||||
|
|||||||
@@ -9,7 +9,6 @@
|
|||||||
package engine.mobileAI;
|
package engine.mobileAI;
|
||||||
|
|
||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.Enum.DispatchChannel;
|
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.gameManager.*;
|
import engine.gameManager.*;
|
||||||
import engine.math.Vector3f;
|
import engine.math.Vector3f;
|
||||||
@@ -17,9 +16,7 @@ import engine.math.Vector3fImmutable;
|
|||||||
import engine.mobileAI.Threads.MobAIThread;
|
import engine.mobileAI.Threads.MobAIThread;
|
||||||
import engine.mobileAI.utilities.CombatUtilities;
|
import engine.mobileAI.utilities.CombatUtilities;
|
||||||
import engine.mobileAI.utilities.MovementUtilities;
|
import engine.mobileAI.utilities.MovementUtilities;
|
||||||
import engine.net.DispatchMessage;
|
|
||||||
import engine.net.client.msg.PerformActionMsg;
|
import engine.net.client.msg.PerformActionMsg;
|
||||||
import engine.net.client.msg.PowerProjectileMsg;
|
|
||||||
import engine.objects.*;
|
import engine.objects.*;
|
||||||
import engine.powers.ActionsBase;
|
import engine.powers.ActionsBase;
|
||||||
import engine.powers.PowersBase;
|
import engine.powers.PowersBase;
|
||||||
@@ -85,7 +82,7 @@ public class MobAI {
|
|||||||
if(mob.StrongholdGuardian || mob.StrongholdEpic){
|
if(mob.StrongholdGuardian || mob.StrongholdEpic){
|
||||||
// attempt to ground all players in attack range
|
// attempt to ground all players in attack range
|
||||||
for(int i : mob.playerAgroMap.keySet()){
|
for(int i : mob.playerAgroMap.keySet()){
|
||||||
PlayerCharacter tar = PlayerCharacter.getFromCache(i);
|
PlayerCharacter tar = PlayerManager.getFromCache(i);
|
||||||
if(tar != null && tar.loc.distanceSquared(mob.loc) < 80){
|
if(tar != null && tar.loc.distanceSquared(mob.loc) < 80){
|
||||||
PowersManager.applyPower(mob,tar,tar.loc, 111111,40,false);
|
PowersManager.applyPower(mob,tar,tar.loc, 111111,40,false);
|
||||||
}
|
}
|
||||||
@@ -166,6 +163,9 @@ public class MobAI {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
|
if(mob == null || target == null)
|
||||||
|
return;
|
||||||
|
|
||||||
if (target.getRank() == -1 || !target.isVulnerable() || BuildingManager.getBuildingFromCache(target.getObjectUUID()) == null) {
|
if (target.getRank() == -1 || !target.isVulnerable() || BuildingManager.getBuildingFromCache(target.getObjectUUID()) == null) {
|
||||||
mob.setCombatTarget(null);
|
mob.setCombatTarget(null);
|
||||||
return;
|
return;
|
||||||
@@ -176,7 +176,7 @@ public class MobAI {
|
|||||||
if (playercity != null)
|
if (playercity != null)
|
||||||
for (Mob guard : playercity.getParent().zoneMobSet)
|
for (Mob guard : playercity.getParent().zoneMobSet)
|
||||||
if (guard.BehaviourType != null && guard.BehaviourType.ordinal() == Enum.MobBehaviourType.GuardCaptain.ordinal())
|
if (guard.BehaviourType != null && guard.BehaviourType.ordinal() == Enum.MobBehaviourType.GuardCaptain.ordinal())
|
||||||
if (guard.getCombatTarget() == null && !guard.getGuild().equals(mob.getGuild()))
|
if (guard.getCombatTarget() == null && guard.getGuild() != null && mob.getGuild() != null && !guard.getGuild().equals(mob.getGuild()))
|
||||||
guard.setCombatTarget(mob);
|
guard.setCombatTarget(mob);
|
||||||
|
|
||||||
if (mob.isSiege())
|
if (mob.isSiege())
|
||||||
@@ -598,6 +598,9 @@ public class MobAI {
|
|||||||
|
|
||||||
if (mob == null)
|
if (mob == null)
|
||||||
return;
|
return;
|
||||||
|
if(mob.isAlive())
|
||||||
|
if(!mob.getMovementLoc().equals(Vector3fImmutable.ZERO))
|
||||||
|
mob.setLoc(mob.getMovementLoc());
|
||||||
|
|
||||||
if (mob.getTimestamps().containsKey("lastExecution") == false)
|
if (mob.getTimestamps().containsKey("lastExecution") == false)
|
||||||
mob.getTimestamps().put("lastExecution", System.currentTimeMillis());
|
mob.getTimestamps().put("lastExecution", System.currentTimeMillis());
|
||||||
@@ -721,7 +724,7 @@ public class MobAI {
|
|||||||
for (Entry playerEntry : loadedPlayers.entrySet()) {
|
for (Entry playerEntry : loadedPlayers.entrySet()) {
|
||||||
|
|
||||||
int playerID = (int) playerEntry.getKey();
|
int playerID = (int) playerEntry.getKey();
|
||||||
PlayerCharacter loadedPlayer = PlayerCharacter.getFromCache(playerID);
|
PlayerCharacter loadedPlayer = PlayerManager.getFromCache(playerID);
|
||||||
|
|
||||||
//Player is null, let's remove them from the list.
|
//Player is null, let's remove them from the list.
|
||||||
|
|
||||||
@@ -922,7 +925,15 @@ public class MobAI {
|
|||||||
|
|
||||||
private static void CheckToSendMobHome(Mob mob) {
|
private static void CheckToSendMobHome(Mob mob) {
|
||||||
|
|
||||||
|
if(mob.isNecroPet())
|
||||||
|
return;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
|
||||||
|
//trebs dont recall
|
||||||
|
if(mob.isSiege())
|
||||||
|
return;
|
||||||
|
|
||||||
if(mob.BehaviourType.equals(Enum.MobBehaviourType.Pet1)){
|
if(mob.BehaviourType.equals(Enum.MobBehaviourType.Pet1)){
|
||||||
if(mob.loc.distanceSquared(mob.getOwner().loc) > 60 * 60)
|
if(mob.loc.distanceSquared(mob.getOwner().loc) > 60 * 60)
|
||||||
mob.teleport(mob.getOwner().loc);
|
mob.teleport(mob.getOwner().loc);
|
||||||
@@ -966,7 +977,7 @@ public class MobAI {
|
|||||||
mob.setCombatTarget(null);
|
mob.setCombatTarget(null);
|
||||||
|
|
||||||
for (Entry playerEntry : mob.playerAgroMap.entrySet())
|
for (Entry playerEntry : mob.playerAgroMap.entrySet())
|
||||||
PlayerCharacter.getFromCache((int) playerEntry.getKey()).setHateValue(0);
|
PlayerManager.getFromCache((int) playerEntry.getKey()).setHateValue(0);
|
||||||
mob.setCombatTarget(null);
|
mob.setCombatTarget(null);
|
||||||
}
|
}
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@@ -1044,9 +1055,22 @@ public class MobAI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void checkToDropGuardAggro(Mob mob){
|
||||||
|
City city = mob.guardedCity;
|
||||||
|
|
||||||
|
if(city == null)
|
||||||
|
return;
|
||||||
|
if(mob.combatTarget == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(city._playerMemory.contains(mob.combatTarget.getObjectUUID()) && mob.combatTarget.getObjectType().equals(Enum.GameObjectType.PlayerCharacter))
|
||||||
|
mob.setCombatTarget(null);
|
||||||
|
}
|
||||||
|
|
||||||
public static void GuardCaptainLogic(Mob mob) {
|
public static void GuardCaptainLogic(Mob mob) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
checkToDropGuardAggro(mob);
|
||||||
if (mob.getCombatTarget() == null)
|
if (mob.getCombatTarget() == null)
|
||||||
CheckForPlayerGuardAggro(mob);
|
CheckForPlayerGuardAggro(mob);
|
||||||
|
|
||||||
@@ -1071,6 +1095,8 @@ public class MobAI {
|
|||||||
public static void GuardMinionLogic(Mob mob) {
|
public static void GuardMinionLogic(Mob mob) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
checkToDropGuardAggro(mob);
|
||||||
|
|
||||||
boolean isComanded = mob.npcOwner.isAlive();
|
boolean isComanded = mob.npcOwner.isAlive();
|
||||||
if (!isComanded) {
|
if (!isComanded) {
|
||||||
GuardCaptainLogic(mob);
|
GuardCaptainLogic(mob);
|
||||||
@@ -1091,6 +1117,8 @@ public class MobAI {
|
|||||||
public static void GuardWallArcherLogic(Mob mob) {
|
public static void GuardWallArcherLogic(Mob mob) {
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
checkToDropGuardAggro(mob);
|
||||||
|
|
||||||
if (mob.getCombatTarget() == null)
|
if (mob.getCombatTarget() == null)
|
||||||
CheckForPlayerGuardAggro(mob);
|
CheckForPlayerGuardAggro(mob);
|
||||||
else
|
else
|
||||||
@@ -1187,7 +1215,7 @@ public class MobAI {
|
|||||||
for (Entry playerEntry : loadedPlayers.entrySet()) {
|
for (Entry playerEntry : loadedPlayers.entrySet()) {
|
||||||
|
|
||||||
int playerID = (int) playerEntry.getKey();
|
int playerID = (int) playerEntry.getKey();
|
||||||
PlayerCharacter loadedPlayer = PlayerCharacter.getFromCache(playerID);
|
PlayerCharacter loadedPlayer = PlayerManager.getFromCache(playerID);
|
||||||
|
|
||||||
//Player is null, let's remove them from the list.
|
//Player is null, let's remove them from the list.
|
||||||
|
|
||||||
@@ -1348,7 +1376,7 @@ public class MobAI {
|
|||||||
|
|
||||||
for (Entry playerEntry : mob.playerAgroMap.entrySet()) {
|
for (Entry playerEntry : mob.playerAgroMap.entrySet()) {
|
||||||
|
|
||||||
PlayerCharacter potentialTarget = PlayerCharacter.getFromCache((int) playerEntry.getKey());
|
PlayerCharacter potentialTarget = PlayerManager.getFromCache((int) playerEntry.getKey());
|
||||||
|
|
||||||
if (potentialTarget.equals(mob.getCombatTarget()))
|
if (potentialTarget.equals(mob.getCombatTarget()))
|
||||||
continue;
|
continue;
|
||||||
|
|||||||
@@ -85,7 +85,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (pc == null)
|
if (pc == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
pc.update();
|
pc.update(false);
|
||||||
if (msg.getSpeed() == 2)
|
if (msg.getSpeed() == 2)
|
||||||
pc.setWalkMode(false);
|
pc.setWalkMode(false);
|
||||||
else
|
else
|
||||||
@@ -114,7 +114,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (pc == null)
|
if (pc == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
pc.update();
|
pc.update(false);
|
||||||
|
|
||||||
pc.setSit(msg.toggleSitStand());
|
pc.setSit(msg.toggleSitStand());
|
||||||
|
|
||||||
@@ -603,19 +603,19 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case MBServerStatics.STAT_STR_ID:
|
case MBServerStatics.STAT_STR_ID:
|
||||||
pc.addStr(msg.getAmount());
|
PlayerManager.addStr(pc, msg.getAmount());
|
||||||
break;
|
break;
|
||||||
case MBServerStatics.STAT_DEX_ID:
|
case MBServerStatics.STAT_DEX_ID:
|
||||||
pc.addDex(msg.getAmount());
|
PlayerManager.addDex(pc, msg.getAmount());
|
||||||
break;
|
break;
|
||||||
case MBServerStatics.STAT_CON_ID:
|
case MBServerStatics.STAT_CON_ID:
|
||||||
pc.addCon(msg.getAmount());
|
PlayerManager.addCon(pc, msg.getAmount());
|
||||||
break;
|
break;
|
||||||
case MBServerStatics.STAT_INT_ID:
|
case MBServerStatics.STAT_INT_ID:
|
||||||
pc.addInt(msg.getAmount());
|
PlayerManager.addInt(pc, msg.getAmount());
|
||||||
break;
|
break;
|
||||||
case MBServerStatics.STAT_SPI_ID:
|
case MBServerStatics.STAT_SPI_ID:
|
||||||
pc.addSpi(msg.getAmount());
|
PlayerManager.addSpi(pc, msg.getAmount());
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -641,7 +641,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
// ResetAfterDeath player
|
// ResetAfterDeath player
|
||||||
sourcePlayer.respawnLock.writeLock().lock();
|
sourcePlayer.respawnLock.writeLock().lock();
|
||||||
try {
|
try {
|
||||||
sourcePlayer.respawn(true, false, true);
|
PlayerManager.respawn(sourcePlayer, true, false, true);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Logger.error(e);
|
Logger.error(e);
|
||||||
@@ -705,7 +705,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
switch (targetType) {
|
switch (targetType) {
|
||||||
case PlayerCharacter:
|
case PlayerCharacter:
|
||||||
|
|
||||||
characterTarget = PlayerCharacter.getFromCache(msg.getTargetID());
|
characterTarget = PlayerManager.getFromCache(msg.getTargetID());
|
||||||
if (characterTarget == null)
|
if (characterTarget == null)
|
||||||
return;
|
return;
|
||||||
if (characterTarget.isAlive())
|
if (characterTarget.isAlive())
|
||||||
@@ -719,7 +719,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
lwrm = new LootWindowResponseMsg(characterTarget.getObjectType().ordinal(), characterTarget.getObjectUUID(), characterTarget.getInventory(true));
|
lwrm = new LootWindowResponseMsg(characterTarget.getObjectType().ordinal(), characterTarget.getObjectUUID(), characterTarget.getInventory(true));
|
||||||
break;
|
break;
|
||||||
case NPC:
|
case NPC:
|
||||||
characterTarget = NPC.getFromCache(msg.getTargetID());
|
characterTarget = NPCManager.getFromCache(msg.getTargetID());
|
||||||
if (characterTarget == null)
|
if (characterTarget == null)
|
||||||
return;
|
return;
|
||||||
break;
|
break;
|
||||||
@@ -809,7 +809,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (targetType == GameObjectType.PlayerCharacter.ordinal() || targetType == GameObjectType.Mob.ordinal()) {
|
if (targetType == GameObjectType.PlayerCharacter.ordinal() || targetType == GameObjectType.Mob.ordinal()) {
|
||||||
|
|
||||||
if (targetType == GameObjectType.PlayerCharacter.ordinal()) {
|
if (targetType == GameObjectType.PlayerCharacter.ordinal()) {
|
||||||
tar = PlayerCharacter.getFromCache(targetID);
|
tar = PlayerManager.getFromCache(targetID);
|
||||||
|
|
||||||
if (tar == null)
|
if (tar == null)
|
||||||
return;
|
return;
|
||||||
@@ -818,7 +818,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
} else if (targetType == GameObjectType.NPC.ordinal())
|
} else if (targetType == GameObjectType.NPC.ordinal())
|
||||||
tar = NPC.getFromCache(targetID);
|
tar = NPCManager.getFromCache(targetID);
|
||||||
else if (targetType == GameObjectType.Mob.ordinal())
|
else if (targetType == GameObjectType.Mob.ordinal())
|
||||||
tar = Mob.getFromCache(targetID);
|
tar = Mob.getFromCache(targetID);
|
||||||
if (tar == null)
|
if (tar == null)
|
||||||
@@ -1013,9 +1013,9 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
AbstractCharacter tar = null;
|
AbstractCharacter tar = null;
|
||||||
|
|
||||||
if (targetType == GameObjectType.PlayerCharacter.ordinal())
|
if (targetType == GameObjectType.PlayerCharacter.ordinal())
|
||||||
tar = PlayerCharacter.getFromCache(msg.getTargetID());
|
tar = PlayerManager.getFromCache(msg.getTargetID());
|
||||||
else if (targetType == GameObjectType.NPC.ordinal())
|
else if (targetType == GameObjectType.NPC.ordinal())
|
||||||
tar = NPC.getFromCache(msg.getTargetID());
|
tar = NPCManager.getFromCache(msg.getTargetID());
|
||||||
else if (targetType == GameObjectType.Mob.ordinal())
|
else if (targetType == GameObjectType.Mob.ordinal())
|
||||||
tar = Mob.getFromCache(msg.getTargetID());
|
tar = Mob.getFromCache(msg.getTargetID());
|
||||||
|
|
||||||
@@ -1150,7 +1150,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (sourcePlayer == null)
|
if (sourcePlayer == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(msg.getNPCID());
|
NPC npc = NPCManager.getFromCache(msg.getNPCID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
@@ -1166,7 +1166,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
|
|
||||||
if (con == null)
|
if (con == null)
|
||||||
return;
|
return;
|
||||||
float bargain = sourcePlayer.getBargain();
|
float bargain = PlayerManager.getBargain(sourcePlayer);
|
||||||
|
|
||||||
float profit = npc.getBuyPercent(sourcePlayer) + bargain;
|
float profit = npc.getBuyPercent(sourcePlayer) + bargain;
|
||||||
|
|
||||||
@@ -1199,7 +1199,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (itemMan == null)
|
if (itemMan == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(msg.getNPCID());
|
NPC npc = NPCManager.getFromCache(msg.getNPCID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
@@ -1271,7 +1271,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
float durabilityMax = sell.getDurabilityMax();
|
float durabilityMax = sell.getDurabilityMax();
|
||||||
float damagedModifier = durabilityCurrent / durabilityMax;
|
float damagedModifier = durabilityCurrent / durabilityMax;
|
||||||
cost *= damagedModifier;
|
cost *= damagedModifier;
|
||||||
float bargain = player.getBargain();
|
float bargain = PlayerManager.getBargain(player);
|
||||||
|
|
||||||
float profit = npc.getBuyPercent(player) + bargain;
|
float profit = npc.getBuyPercent(player) + bargain;
|
||||||
|
|
||||||
@@ -1363,7 +1363,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (sourcePlayer == null)
|
if (sourcePlayer == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(msg.getNpcID());
|
NPC npc = NPCManager.getFromCache(msg.getNpcID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
@@ -1391,7 +1391,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (itemMan == null) {
|
if (itemMan == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
NPC npc = NPC.getFromCache(msg.getNPCID());
|
NPC npc = NPCManager.getFromCache(msg.getNPCID());
|
||||||
if (npc == null) {
|
if (npc == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@@ -1422,7 +1422,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
int cost = me.getMagicValue();
|
int cost = me.getMagicValue();
|
||||||
float bargain = sourcePlayer.getBargain();
|
float bargain = PlayerManager.getBargain(sourcePlayer);
|
||||||
switch(npc.getContractID()){
|
switch(npc.getContractID()){
|
||||||
case 1201:
|
case 1201:
|
||||||
cost = ItemBase.getDiscPrice(ib.getUUID());
|
cost = ItemBase.getDiscPrice(ib.getUUID());
|
||||||
@@ -1503,7 +1503,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
int cost = buy.getBaseValue();
|
int cost = buy.getBaseValue();
|
||||||
if (buy.isID() || buy.isCustomValue())
|
if (buy.isID() || buy.isCustomValue())
|
||||||
cost = buy.getMagicValue();
|
cost = buy.getMagicValue();
|
||||||
float bargain = sourcePlayer.getBargain();
|
float bargain = PlayerManager.getBargain(sourcePlayer);
|
||||||
float profit = npc.getSellPercent(sourcePlayer) - bargain;
|
float profit = npc.getSellPercent(sourcePlayer) - bargain;
|
||||||
if (profit < 1)
|
if (profit < 1)
|
||||||
profit = 1;
|
profit = 1;
|
||||||
@@ -1623,7 +1623,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
if (player == null)
|
if (player == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(msg.getNPCID());
|
NPC npc = NPCManager.getFromCache(msg.getNPCID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
@@ -1681,8 +1681,12 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
int cost = (int)((toRepair.getMagicValue()/max*(max - dur)) + (npc.getRepairCost() * npc.buyPercent));
|
int pointsToRepair = max - dur;
|
||||||
|
double damageRatio = (double)1.0d - (toRepair.getDurabilityMax() - toRepair.getDurabilityCurrent()) / toRepair.getDurabilityMax();
|
||||||
|
int modifiedValue = (int)(damageRatio * toRepair.getMagicValue());
|
||||||
|
int costPerPoint = modifiedValue / toRepair.getDurabilityMax();
|
||||||
|
int modifiedRepairCost = (int)(pointsToRepair * costPerPoint)+ npc.getSpecialPrice();
|
||||||
|
int cost = (int)(modifiedRepairCost * 1 + npc.buyPercent) + npc.getSpecialPrice();
|
||||||
Building b = (!npc.isStatic()) ? npc.getBuilding() : null;
|
Building b = (!npc.isStatic()) ? npc.getBuilding() : null;
|
||||||
|
|
||||||
if (b != null)
|
if (b != null)
|
||||||
@@ -1817,7 +1821,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
long type = player.getTimeStamp("LastRecallType");
|
long type = player.getTimeStamp("LastRecallType");
|
||||||
|
|
||||||
if (type == 1) { //recall to bind
|
if (type == 1) { //recall to bind
|
||||||
player.teleport(player.getBindLoc());
|
PlayerManager.teleport(player, player.getBindLoc());
|
||||||
player.setSafeMode();
|
player.setSafeMode();
|
||||||
} else { //recall to rg
|
} else { //recall to rg
|
||||||
float dist = 9999999999f;
|
float dist = 9999999999f;
|
||||||
@@ -1838,7 +1842,7 @@ public class ClientMessagePump implements NetMsgHandler {
|
|||||||
//nearest runegate found. teleport characterTarget
|
//nearest runegate found. teleport characterTarget
|
||||||
|
|
||||||
if (rg != null) {
|
if (rg != null) {
|
||||||
player.teleport(rg.getLoc());
|
PlayerManager.teleport(player, rg.getLoc());
|
||||||
player.setSafeMode();
|
player.setSafeMode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -13,10 +13,7 @@ import engine.Enum;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.Enum.GuildHistoryType;
|
import engine.Enum.GuildHistoryType;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.GuildManager;
|
|
||||||
import engine.gameManager.SessionManager;
|
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -83,7 +80,7 @@ public class AcceptInviteToGuildHandler extends AbstractClientMsgHandler {
|
|||||||
player.setGuild(guild);
|
player.setGuild(guild);
|
||||||
|
|
||||||
// Cleanup guild stuff
|
// Cleanup guild stuff
|
||||||
player.resetGuildStatuses();
|
PlayerManager.resetGuildStatuses(player);
|
||||||
|
|
||||||
Dispatch dispatch = Dispatch.borrow(player, msg);
|
Dispatch dispatch = Dispatch.borrow(player, msg);
|
||||||
DispatchMessage.dispatchMsgDispatch(dispatch, Enum.DispatchChannel.SECONDARY);
|
DispatchMessage.dispatchMsgDispatch(dispatch, Enum.DispatchChannel.SECONDARY);
|
||||||
|
|||||||
@@ -53,7 +53,7 @@ public class ArcLoginNotifyMsgHandler extends AbstractClientMsgHandler {
|
|||||||
GroupManager.RefreshOthersGroupList(player);
|
GroupManager.RefreshOthersGroupList(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
player.setEnteredWorld(true);
|
PlayerManager.setEnteredWorld(player, true);
|
||||||
// Set player active
|
// Set player active
|
||||||
player.resetRegenUpdateTime();
|
player.resetRegenUpdateTime();
|
||||||
player.setActive(true);
|
player.setActive(true);
|
||||||
|
|||||||
@@ -144,7 +144,7 @@ public class AssetSupportMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (player == null)
|
if (player == null)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
vendor = NPC.getFromCache(msg.getNpcID());
|
vendor = NPCManager.getFromCache(msg.getNpcID());
|
||||||
|
|
||||||
if (msg.getMessageType() != 6 && msg.getMessageType() != 7) {
|
if (msg.getMessageType() != 6 && msg.getMessageType() != 7) {
|
||||||
if (vendor == null)
|
if (vendor == null)
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import engine.Enum.GuildHistoryType;
|
|||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -55,7 +56,7 @@ public class BanishUnbanishHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
boolean success = false;
|
boolean success = false;
|
||||||
Guild guild = source.getGuild();
|
Guild guild = source.getGuild();
|
||||||
PlayerCharacter realizedTarget = PlayerCharacter.getFromCache(target);
|
PlayerCharacter realizedTarget = PlayerManager.getFromCache(target);
|
||||||
|
|
||||||
if (realizedTarget != null) {
|
if (realizedTarget != null) {
|
||||||
// Guild leader can't leave guild. must pass GL or disband
|
// Guild leader can't leave guild. must pass GL or disband
|
||||||
@@ -83,7 +84,7 @@ public class BanishUnbanishHandler extends AbstractClientMsgHandler {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (guild.getGuildLeaderUUID() != target) {
|
if (guild.getGuildLeaderUUID() != target) {
|
||||||
PlayerCharacter toBanish = PlayerCharacter.getPlayerCharacter(target);
|
PlayerCharacter toBanish = PlayerManager.getPlayerCharacter(target);
|
||||||
if (toBanish == null)
|
if (toBanish == null)
|
||||||
return true;
|
return true;
|
||||||
//already added previously.
|
//already added previously.
|
||||||
@@ -110,7 +111,7 @@ public class BanishUnbanishHandler extends AbstractClientMsgHandler {
|
|||||||
//DbManager.GuildQueries.ADD_TO_BANISHED_FROM_GUILDLIST(guild.getobjectUUID(), target);
|
//DbManager.GuildQueries.ADD_TO_BANISHED_FROM_GUILDLIST(guild.getobjectUUID(), target);
|
||||||
|
|
||||||
// Send left guild message to rest of guild
|
// Send left guild message to rest of guild
|
||||||
String targetName = PlayerCharacter.getFirstName(target);
|
String targetName = PlayerManager.getFirstName(target);
|
||||||
ChatManager.chatGuildInfo(guild,
|
ChatManager.chatGuildInfo(guild,
|
||||||
targetName + " has been banished from " + guild.getName() + '.');
|
targetName + " has been banished from " + guild.getName() + '.');
|
||||||
GuildListMsg guildListMsg = new GuildListMsg(guild);
|
GuildListMsg guildListMsg = new GuildListMsg(guild);
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.handlers;
|
|||||||
|
|
||||||
import engine.Enum.DispatchChannel;
|
import engine.Enum.DispatchChannel;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
import engine.net.client.msg.ChangeAltitudeMsg;
|
import engine.net.client.msg.ChangeAltitudeMsg;
|
||||||
@@ -42,18 +43,21 @@ public class ChangeAltitudeHandler extends AbstractClientMsgHandler {
|
|||||||
if (!AbstractCharacter.CanFly(pc))
|
if (!AbstractCharacter.CanFly(pc))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (pc.isSwimming())
|
if (PlayerManager.isSwimming(pc))
|
||||||
return false;
|
return false;
|
||||||
if (pc.region != null && !pc.region.isOutside())
|
if (pc.region != null && !pc.region.isOutside())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
|
||||||
// Find out if we already have an altitude timer running and if so
|
// Find out if we already have an altitude timer running and if so
|
||||||
// do not process more alt change requests
|
// do not process more alt change requests
|
||||||
|
|
||||||
|
pc.updateFlight();
|
||||||
|
|
||||||
if (pc.getTakeOffTime() != 0)
|
if (pc.getTakeOffTime() != 0)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
pc.setTakeOffTime(System.currentTimeMillis());
|
||||||
|
|
||||||
|
|
||||||
// remove all movement timers and jobs
|
// remove all movement timers and jobs
|
||||||
//TODO: test if they can fly
|
//TODO: test if they can fly
|
||||||
@@ -67,7 +71,7 @@ public class ChangeAltitudeHandler extends AbstractClientMsgHandler {
|
|||||||
if (pc.getAltitude() == 0 && !msg.up())
|
if (pc.getAltitude() == 0 && !msg.up())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
pc.update();
|
pc.update(false);
|
||||||
pc.stopMovement(pc.getLoc());
|
pc.stopMovement(pc.getLoc());
|
||||||
msg.setStartAlt(pc.getAltitude());
|
msg.setStartAlt(pc.getAltitude());
|
||||||
if (msg.up()) {
|
if (msg.up()) {
|
||||||
@@ -132,7 +136,7 @@ public class ChangeAltitudeHandler extends AbstractClientMsgHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (msg.up()) {
|
if (msg.up()) {
|
||||||
pc.update();
|
pc.update(false);
|
||||||
pc.setDesiredAltitude(targetAlt);
|
pc.setDesiredAltitude(targetAlt);
|
||||||
pc.setTakeOffTime(System.currentTimeMillis());
|
pc.setTakeOffTime(System.currentTimeMillis());
|
||||||
} else {
|
} else {
|
||||||
@@ -158,7 +162,7 @@ public class ChangeAltitudeHandler extends AbstractClientMsgHandler {
|
|||||||
} else
|
} else
|
||||||
pc.setDesiredAltitude(targetAlt);
|
pc.setDesiredAltitude(targetAlt);
|
||||||
|
|
||||||
pc.update();
|
pc.update(false);
|
||||||
|
|
||||||
|
|
||||||
pc.setTakeOffTime(System.currentTimeMillis());
|
pc.setTakeOffTime(System.currentTimeMillis());
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import engine.Enum.GameObjectType;
|
|||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -97,9 +98,9 @@ public class ChangeGuildLeaderHandler extends AbstractClientMsgHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
targetPlayer.setGuildLeader(true);
|
PlayerManager.setGuildLeader(targetPlayer, true);
|
||||||
targetPlayer.setInnerCouncil(true);
|
PlayerManager.setInnerCouncil(targetPlayer, true);
|
||||||
targetPlayer.setFullMember(true);
|
PlayerManager.setFullMember(targetPlayer, true);
|
||||||
targetPlayer.incVer();
|
targetPlayer.incVer();
|
||||||
targetName = targetPlayer.getFirstName();
|
targetName = targetPlayer.getFirstName();
|
||||||
updateTarget = true;
|
updateTarget = true;
|
||||||
@@ -113,9 +114,9 @@ public class ChangeGuildLeaderHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
|
|
||||||
//updateOldGuildLeader
|
//updateOldGuildLeader
|
||||||
sourcePlayer.setInnerCouncil(true);
|
PlayerManager.setInnerCouncil(sourcePlayer, true);
|
||||||
sourcePlayer.setFullMember(true);
|
PlayerManager.setFullMember(sourcePlayer, true);
|
||||||
sourcePlayer.setGuildLeader(false);
|
PlayerManager.setGuildLeader(sourcePlayer, false);
|
||||||
sourcePlayer.incVer();
|
sourcePlayer.incVer();
|
||||||
|
|
||||||
GuildInfoMsg guildInfoMsg = new GuildInfoMsg(sourcePlayer, sourcePlayer.getGuild(), 2);
|
GuildInfoMsg guildInfoMsg = new GuildInfoMsg(sourcePlayer, sourcePlayer.getGuild(), 2);
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import engine.Enum.GameObjectType;
|
|||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -63,14 +64,14 @@ public class ChangeRankHandler extends AbstractClientMsgHandler {
|
|||||||
Enum.GuildType t = Enum.GuildType.getGuildTypeFromInt(sourcePlayer.getGuild().getCharter());
|
Enum.GuildType t = Enum.GuildType.getGuildTypeFromInt(sourcePlayer.getGuild().getCharter());
|
||||||
|
|
||||||
if (targetPlayer != null) {
|
if (targetPlayer != null) {
|
||||||
targetPlayer.setGuildTitle(msg.getNewRank());
|
PlayerManager.setGuildTitle(targetPlayer, msg.getNewRank());
|
||||||
|
|
||||||
targetName = targetPlayer.getFirstName();
|
targetName = targetPlayer.getFirstName();
|
||||||
isMale = targetPlayer.getRace().getRaceType().getCharacterSex().equals(Enum.CharacterSex.MALE);
|
isMale = targetPlayer.getRace().getRaceType().getCharacterSex().equals(Enum.CharacterSex.MALE);
|
||||||
} else {
|
} else {
|
||||||
DbManager.GuildQueries.UPDATE_GUILD_RANK_OFFLINE(msg.getPlayerUUID(), msg.getNewRank(), sourcePlayer.getGuild().getObjectUUID());
|
DbManager.GuildQueries.UPDATE_GUILD_RANK_OFFLINE(msg.getPlayerUUID(), msg.getNewRank(), sourcePlayer.getGuild().getObjectUUID());
|
||||||
|
|
||||||
targetName = PlayerCharacter.getFirstName(msg.getPlayerUUID());
|
targetName = PlayerManager.getFirstName(msg.getPlayerUUID());
|
||||||
isMale = true;
|
isMale = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -98,7 +99,7 @@ public class ChangeRankHandler extends AbstractClientMsgHandler {
|
|||||||
taxUpdate = (updateMask & 1) > 0;
|
taxUpdate = (updateMask & 1) > 0;
|
||||||
|
|
||||||
if (targetName == null && updateMask > 0)
|
if (targetName == null && updateMask > 0)
|
||||||
targetName = PlayerCharacter.getFirstName(msg.getPlayerUUID());
|
targetName = PlayerManager.getFirstName(msg.getPlayerUUID());
|
||||||
} else {
|
} else {
|
||||||
icUpdate = (GuildStatusController.isInnerCouncil(targetPlayer.getGuildStatus()) != (msg.getIc() > 0)) && GuildStatusController.isGuildLeader(sourcePlayer.getGuildStatus());
|
icUpdate = (GuildStatusController.isInnerCouncil(targetPlayer.getGuildStatus()) != (msg.getIc() > 0)) && GuildStatusController.isGuildLeader(sourcePlayer.getGuildStatus());
|
||||||
recruitUpdate = (GuildStatusController.isRecruiter(targetPlayer.getGuildStatus()) != (msg.getRec() > 0)) && GuildStatusController.isGuildLeader(sourcePlayer.getGuildStatus());
|
recruitUpdate = (GuildStatusController.isRecruiter(targetPlayer.getGuildStatus()) != (msg.getRec() > 0)) && GuildStatusController.isGuildLeader(sourcePlayer.getGuildStatus());
|
||||||
@@ -106,16 +107,16 @@ public class ChangeRankHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
//This logic branch only executes if targetPlayer has passed a null check...
|
//This logic branch only executes if targetPlayer has passed a null check...
|
||||||
if (icUpdate) {
|
if (icUpdate) {
|
||||||
targetPlayer.setInnerCouncil(msg.getIc() > 0);
|
PlayerManager.setInnerCouncil(targetPlayer, msg.getIc() > 0);
|
||||||
targetPlayer.setFullMember(true);
|
PlayerManager.setFullMember(targetPlayer, true);
|
||||||
targetPlayer.incVer();
|
targetPlayer.incVer();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (recruitUpdate)
|
if (recruitUpdate)
|
||||||
targetPlayer.setRecruiter(msg.getRec() > 0);
|
PlayerManager.setRecruiter(targetPlayer, msg.getRec() > 0);
|
||||||
|
|
||||||
if (taxUpdate)
|
if (taxUpdate)
|
||||||
targetPlayer.setTaxCollector(msg.getTax() > 0);
|
PlayerManager.setTaxCollector(targetPlayer, msg.getTax() > 0);
|
||||||
|
|
||||||
if (targetName == null)
|
if (targetName == null)
|
||||||
targetName = targetPlayer.getFirstName();
|
targetName = targetPlayer.getFirstName();
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ import engine.db.archive.GuildRecord;
|
|||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -98,8 +99,8 @@ public class DisbandGuildHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
//Save Guild data
|
//Save Guild data
|
||||||
|
|
||||||
player.setGuildLeader(false);
|
PlayerManager.setGuildLeader(player, false);
|
||||||
player.setInnerCouncil(false);
|
PlayerManager.setInnerCouncil(player, false);
|
||||||
guild.setGuildLeaderUUID(0);
|
guild.setGuildLeaderUUID(0);
|
||||||
guild.setNation(null);
|
guild.setNation(null);
|
||||||
|
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.handlers;
|
|||||||
|
|
||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -60,7 +61,7 @@ public class GuildControlHandler extends AbstractClientMsgHandler {
|
|||||||
PlayerCharacter player = SessionManager.getPlayerCharacter(origin);
|
PlayerCharacter player = SessionManager.getPlayerCharacter(origin);
|
||||||
|
|
||||||
//If we don't get a valid PC for whatever reason.. just ignore it.
|
//If we don't get a valid PC for whatever reason.. just ignore it.
|
||||||
PlayerCharacter pc = PlayerCharacter.getFromCache(msg.getUnknown03());
|
PlayerCharacter pc = PlayerManager.getFromCache(msg.getUnknown03());
|
||||||
|
|
||||||
if (pc != null) {
|
if (pc != null) {
|
||||||
dispatch = Dispatch.borrow(player, new GuildListMsg(pc));
|
dispatch = Dispatch.borrow(player, new GuildListMsg(pc));
|
||||||
|
|||||||
@@ -15,10 +15,7 @@ import engine.Enum.GuildHistoryType;
|
|||||||
import engine.Enum.ItemType;
|
import engine.Enum.ItemType;
|
||||||
import engine.Enum.OwnerType;
|
import engine.Enum.OwnerType;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.GuildManager;
|
|
||||||
import engine.gameManager.SessionManager;
|
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -130,10 +127,10 @@ public class GuildCreationFinalizeHandler extends AbstractClientMsgHandler {
|
|||||||
GuildManager.joinGuild(player, newGuild, GuildHistoryType.CREATE);
|
GuildManager.joinGuild(player, newGuild, GuildHistoryType.CREATE);
|
||||||
|
|
||||||
newGuild.setGuildLeader(player);
|
newGuild.setGuildLeader(player);
|
||||||
player.setGuildLeader(true);
|
PlayerManager.setGuildLeader(player, true);
|
||||||
player.setInnerCouncil(true);
|
PlayerManager.setInnerCouncil(player, true);
|
||||||
player.setFullMember(true);
|
PlayerManager.setFullMember(player, true);
|
||||||
player.setGuildTitle(charterType.getNumberOfRanks() - 1);
|
PlayerManager.setGuildTitle(player, charterType.getNumberOfRanks() - 1);
|
||||||
player.getCharItemManager().delete(charter);
|
player.getCharItemManager().delete(charter);
|
||||||
player.getCharItemManager().updateInventory();
|
player.getCharItemManager().updateInventory();
|
||||||
player.incVer();
|
player.incVer();
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.handlers;
|
|||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -43,7 +44,7 @@ public class GuildInfoHandler extends AbstractClientMsgHandler {
|
|||||||
} else if (msg.getMsgType() == 5) {
|
} else if (msg.getMsgType() == 5) {
|
||||||
|
|
||||||
if (msg.getObjectType() == GameObjectType.PlayerCharacter.ordinal()) {
|
if (msg.getObjectType() == GameObjectType.PlayerCharacter.ordinal()) {
|
||||||
PlayerCharacter pc = PlayerCharacter.getPlayerCharacter(msg.getObjectID());
|
PlayerCharacter pc = PlayerManager.getPlayerCharacter(msg.getObjectID());
|
||||||
dispatch = Dispatch.borrow(sourcePlayer, new GuildInfoMsg(pc, pc.getGuild(), 5));
|
dispatch = Dispatch.borrow(sourcePlayer, new GuildInfoMsg(pc, pc.getGuild(), 5));
|
||||||
DispatchMessage.dispatchMsgDispatch(dispatch, engine.Enum.DispatchChannel.SECONDARY);
|
DispatchMessage.dispatchMsgDispatch(dispatch, engine.Enum.DispatchChannel.SECONDARY);
|
||||||
} else {
|
} else {
|
||||||
|
|||||||
@@ -13,6 +13,7 @@ package engine.net.client.handlers;
|
|||||||
import engine.Enum.DispatchChannel;
|
import engine.Enum.DispatchChannel;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -52,7 +53,7 @@ public class HirelingServiceMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (building == null)
|
if (building == null)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(msg.npcID);
|
NPC npc = NPCManager.getFromCache(msg.npcID);
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return true;
|
return true;
|
||||||
@@ -61,7 +62,7 @@ public class HirelingServiceMsgHandler extends AbstractClientMsgHandler {
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
|
|
||||||
npc.setRepairCost(msg.repairCost);
|
npc.setSpecialPrice(msg.repairCost);
|
||||||
ManageNPCMsg outMsg = new ManageNPCMsg(npc);
|
ManageNPCMsg outMsg = new ManageNPCMsg(npc);
|
||||||
Dispatch dispatch = Dispatch.borrow(player, msg);
|
Dispatch dispatch = Dispatch.borrow(player, msg);
|
||||||
|
|
||||||
|
|||||||
@@ -17,7 +17,6 @@ import engine.powers.PowersBase;
|
|||||||
import engine.server.MBServerStatics;
|
import engine.server.MBServerStatics;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Objects;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @Author:
|
* @Author:
|
||||||
@@ -347,7 +346,7 @@ public class MerchantMsgHandler extends AbstractClientMsgHandler {
|
|||||||
TeleportJob tj = new TeleportJob(player, npc, teleportLoc, origin, true);
|
TeleportJob tj = new TeleportJob(player, npc, teleportLoc, origin, true);
|
||||||
JobScheduler.getInstance().scheduleJob(tj, time * 1000);
|
JobScheduler.getInstance().scheduleJob(tj, time * 1000);
|
||||||
} else if (joinedGuild) {
|
} else if (joinedGuild) {
|
||||||
player.teleport(teleportLoc);
|
PlayerManager.teleport(player, teleportLoc);
|
||||||
player.setSafeMode();
|
player.setSafeMode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -416,7 +415,7 @@ public class MerchantMsgHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
player = SessionManager.getPlayerCharacter(origin);
|
player = SessionManager.getPlayerCharacter(origin);
|
||||||
msg = (MerchantMsg) baseMsg;
|
msg = (MerchantMsg) baseMsg;
|
||||||
npc = NPC.getNPC(msg.getNPCID());
|
npc = NPCManager.getNPC(msg.getNPCID());
|
||||||
|
|
||||||
// Early exit if something goes awry
|
// Early exit if something goes awry
|
||||||
|
|
||||||
|
|||||||
@@ -45,7 +45,7 @@ public class MinionTrainingMsgHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
if (minionMsg.getNpcType() == Enum.GameObjectType.NPC.ordinal()) {
|
if (minionMsg.getNpcType() == Enum.GameObjectType.NPC.ordinal()) {
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(minionMsg.getNpcID());
|
NPC npc = NPCManager.getFromCache(minionMsg.getNpcID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -417,7 +417,7 @@ public class ObjectActionMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (!toCommand.isSiege())
|
if (!toCommand.isSiege())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
if (player.commandSiegeMinion(toCommand)) {
|
if (PlayerManager.commandSiegeMinion(player, toCommand)) {
|
||||||
itemMan.consume(item);
|
itemMan.consume(item);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|||||||
@@ -4,9 +4,7 @@ import engine.Enum;
|
|||||||
import engine.Enum.DispatchChannel;
|
import engine.Enum.DispatchChannel;
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.SessionManager;
|
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -71,9 +69,9 @@ public class OpenFriendsCondemnListMsgHandler extends AbstractClientMsgHandler {
|
|||||||
}
|
}
|
||||||
AbstractCharacter toAdd = null;
|
AbstractCharacter toAdd = null;
|
||||||
if (msg.getPlayerType() == GameObjectType.PlayerCharacter.ordinal())
|
if (msg.getPlayerType() == GameObjectType.PlayerCharacter.ordinal())
|
||||||
toAdd = PlayerCharacter.getFromCache(msg.getPlayerID());
|
toAdd = PlayerManager.getFromCache(msg.getPlayerID());
|
||||||
else if (msg.getPlayerType() == GameObjectType.NPC.ordinal())
|
else if (msg.getPlayerType() == GameObjectType.NPC.ordinal())
|
||||||
toAdd = NPC.getFromCache(msg.getPlayerID());
|
toAdd = NPCManager.getFromCache(msg.getPlayerID());
|
||||||
else if (msg.getPlayerType() == GameObjectType.Mob.ordinal())
|
else if (msg.getPlayerType() == GameObjectType.Mob.ordinal())
|
||||||
toAdd = Mob.getFromCache(msg.getPlayerID());
|
toAdd = Mob.getFromCache(msg.getPlayerID());
|
||||||
else {
|
else {
|
||||||
@@ -214,7 +212,7 @@ public class OpenFriendsCondemnListMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (msg.getPlayerType() != GameObjectType.PlayerCharacter.ordinal())
|
if (msg.getPlayerType() != GameObjectType.PlayerCharacter.ordinal())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
PlayerCharacter playerCharacter = PlayerCharacter.getFromCache(msg.getPlayerID());
|
PlayerCharacter playerCharacter = PlayerManager.getFromCache(msg.getPlayerID());
|
||||||
|
|
||||||
if (playerCharacter == null)
|
if (playerCharacter == null)
|
||||||
return true;
|
return true;
|
||||||
@@ -303,7 +301,7 @@ public class OpenFriendsCondemnListMsgHandler extends AbstractClientMsgHandler {
|
|||||||
//Check to see if the invited is already on the friends list.
|
//Check to see if the invited is already on the friends list.
|
||||||
switch (msg.getInviteType()) {
|
switch (msg.getInviteType()) {
|
||||||
case 7:
|
case 7:
|
||||||
playerCharacter = PlayerCharacter.getFromCache(msg.getPlayerID());
|
playerCharacter = PlayerManager.getFromCache(msg.getPlayerID());
|
||||||
if (playerCharacter == null)
|
if (playerCharacter == null)
|
||||||
return true;
|
return true;
|
||||||
if (sourceBuilding.getFriends().containsKey(playerCharacter.getObjectUUID()))
|
if (sourceBuilding.getFriends().containsKey(playerCharacter.getObjectUUID()))
|
||||||
|
|||||||
@@ -91,7 +91,7 @@ public class OrderNPCMsgHandler extends AbstractClientMsgHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
ManageCityAssetsMsg mca = new ManageCityAssetsMsg();
|
ManageCityAssetsMsg mca = new ManageCityAssetsMsg();
|
||||||
mca.actionType = NPC.SVR_CLOSE_WINDOW;
|
mca.actionType = NPCManager.SVR_CLOSE_WINDOW;
|
||||||
mca.setTargetType(building.getObjectType().ordinal());
|
mca.setTargetType(building.getObjectType().ordinal());
|
||||||
mca.setTargetID(building.getObjectUUID());
|
mca.setTargetID(building.getObjectUUID());
|
||||||
origin.sendMsg(mca);
|
origin.sendMsg(mca);
|
||||||
@@ -110,7 +110,7 @@ public class OrderNPCMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (player == null)
|
if (player == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
npc = NPC.getFromCache(msg.getNpcUUID());
|
npc = NPCManager.getFromCache(msg.getNpcUUID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
@@ -120,7 +120,7 @@ public class OrderNPCMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (building == null)
|
if (building == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPCProfits profit = NPC.GetNPCProfits(npc);
|
NPCProfits profit = NPCManager.GetNPCProfits(npc);
|
||||||
|
|
||||||
if (profit == null)
|
if (profit == null)
|
||||||
return;
|
return;
|
||||||
@@ -155,7 +155,7 @@ public class OrderNPCMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (player == null)
|
if (player == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
npc = NPC.getFromCache(orderNPCMsg.getNpcUUID());
|
npc = NPCManager.getFromCache(orderNPCMsg.getNpcUUID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
@@ -165,7 +165,7 @@ public class OrderNPCMsgHandler extends AbstractClientMsgHandler {
|
|||||||
if (building == null)
|
if (building == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPCProfits profit = NPC.GetNPCProfits(npc);
|
NPCProfits profit = NPCManager.GetNPCProfits(npc);
|
||||||
|
|
||||||
if (profit == null)
|
if (profit == null)
|
||||||
return;
|
return;
|
||||||
@@ -428,7 +428,7 @@ public class OrderNPCMsgHandler extends AbstractClientMsgHandler {
|
|||||||
|
|
||||||
if (orderNPCMsg.getObjectType() == GameObjectType.NPC.ordinal()) {
|
if (orderNPCMsg.getObjectType() == GameObjectType.NPC.ordinal()) {
|
||||||
|
|
||||||
npc = NPC.getFromCache(orderNPCMsg.getNpcUUID());
|
npc = NPCManager.getFromCache(orderNPCMsg.getNpcUUID());
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -8,6 +8,7 @@ import engine.db.archive.CharacterRecord;
|
|||||||
import engine.db.archive.DataWarehouse;
|
import engine.db.archive.DataWarehouse;
|
||||||
import engine.db.archive.PvpRecord;
|
import engine.db.archive.PvpRecord;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
@@ -57,7 +58,7 @@ public class RequestEnterWorldHandler extends AbstractClientMsgHandler {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
player.setEnteredWorld(false);
|
PlayerManager.setEnteredWorld(player, false);
|
||||||
|
|
||||||
Account acc = SessionManager.getAccount(origin);
|
Account acc = SessionManager.getAccount(origin);
|
||||||
|
|
||||||
@@ -118,7 +119,7 @@ public class RequestEnterWorldHandler extends AbstractClientMsgHandler {
|
|||||||
try {
|
try {
|
||||||
if (!player.isAlive()) {
|
if (!player.isAlive()) {
|
||||||
Logger.info("respawning player on enter world.");
|
Logger.info("respawning player on enter world.");
|
||||||
player.respawn(true, true, true);
|
PlayerManager.respawn(player, true, true, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.net.client.handlers;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -63,7 +64,7 @@ public class SwearInHandler extends AbstractClientMsgHandler {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Swear target in and send message to guild
|
// Swear target in and send message to guild
|
||||||
target.setFullMember(true);
|
PlayerManager.setFullMember(target, true);
|
||||||
target.incVer();
|
target.incVer();
|
||||||
|
|
||||||
ChatManager.chatGuildInfo(source, target.getFirstName() + " has been sworn in as a full member!");
|
ChatManager.chatGuildInfo(source, target.getFirstName() + " has been sworn in as a full member!");
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import engine.Enum;
|
|||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
import engine.net.client.msg.ClientNetMsg;
|
import engine.net.client.msg.ClientNetMsg;
|
||||||
import engine.net.client.msg.ErrorPopupMsg;
|
import engine.net.client.msg.ErrorPopupMsg;
|
||||||
@@ -35,7 +36,7 @@ public class TransferAssetMsgHandler extends AbstractClientMsgHandler {
|
|||||||
int TargetType = transferAssetMsg.getTargetType(); //ToDue later
|
int TargetType = transferAssetMsg.getTargetType(); //ToDue later
|
||||||
|
|
||||||
Building building = BuildingManager.getBuildingFromCache(Buildingid);
|
Building building = BuildingManager.getBuildingFromCache(Buildingid);
|
||||||
PlayerCharacter newOwner = PlayerCharacter.getFromCache(TargetID);
|
PlayerCharacter newOwner = PlayerManager.getFromCache(TargetID);
|
||||||
PlayerCharacter player = origin.getPlayerCharacter();
|
PlayerCharacter player = origin.getPlayerCharacter();
|
||||||
|
|
||||||
if (player == null || building == null || newOwner == null)
|
if (player == null || building == null || newOwner == null)
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.net.client.msg;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.*;
|
import engine.net.*;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
import engine.net.client.Protocol;
|
import engine.net.client.Protocol;
|
||||||
@@ -146,6 +147,8 @@ public class ApplyRuneMsg extends ClientNetMsg {
|
|||||||
valid = true;
|
valid = true;
|
||||||
if(runeID == 3035 && baseClassID == 2501)
|
if(runeID == 3035 && baseClassID == 2501)
|
||||||
valid = true;
|
valid = true;
|
||||||
|
if(runeID == 3028 && baseClassID == 2501 && playerCharacter.getRace().getName().contains("Irekei"))
|
||||||
|
valid = true;
|
||||||
if (!valid) {
|
if (!valid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -154,6 +157,7 @@ public class ApplyRuneMsg extends ClientNetMsg {
|
|||||||
ConcurrentHashMap<Integer, Boolean> promotionClasses = rb.getPromotionClass();
|
ConcurrentHashMap<Integer, Boolean> promotionClasses = rb.getPromotionClass();
|
||||||
if (promotionClasses.size() > 0) {
|
if (promotionClasses.size() > 0) {
|
||||||
int promotionClassID = playerCharacter.getPromotionClassID();
|
int promotionClassID = playerCharacter.getPromotionClassID();
|
||||||
|
int baseClassID = playerCharacter.getBaseClassID();
|
||||||
boolean valid = false;
|
boolean valid = false;
|
||||||
for (int validID : promotionClasses.keySet()) {
|
for (int validID : promotionClasses.keySet()) {
|
||||||
if (validID == promotionClassID) {
|
if (validID == promotionClassID) {
|
||||||
@@ -171,6 +175,8 @@ public class ApplyRuneMsg extends ClientNetMsg {
|
|||||||
valid = true;
|
valid = true;
|
||||||
if(runeID == 3028 && (raceID == 2013 || raceID == 2014) && playerCharacter.getBaseClassID() == 2501)
|
if(runeID == 3028 && (raceID == 2013 || raceID == 2014) && playerCharacter.getBaseClassID() == 2501)
|
||||||
valid = true;
|
valid = true;
|
||||||
|
if(runeID == 3035 && baseClassID == 2501)
|
||||||
|
valid = true;
|
||||||
if (!valid) {
|
if (!valid) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -376,23 +382,23 @@ public class ApplyRuneMsg extends ClientNetMsg {
|
|||||||
//add any additional stats to match old amount
|
//add any additional stats to match old amount
|
||||||
int dif = strTotal - (int) playerCharacter.statStrBase;
|
int dif = strTotal - (int) playerCharacter.statStrBase;
|
||||||
if (dif > 0 && strTotal < (int) playerCharacter.statStrMax) {
|
if (dif > 0 && strTotal < (int) playerCharacter.statStrMax) {
|
||||||
playerCharacter.addStr(dif);
|
PlayerManager.addStr(playerCharacter, dif);
|
||||||
}
|
}
|
||||||
dif = dexTotal - (int) playerCharacter.statDexBase;
|
dif = dexTotal - (int) playerCharacter.statDexBase;
|
||||||
if (dif > 0 && dexTotal < (int) playerCharacter.statDexMax) {
|
if (dif > 0 && dexTotal < (int) playerCharacter.statDexMax) {
|
||||||
playerCharacter.addDex(dif);
|
PlayerManager.addDex(playerCharacter, dif);
|
||||||
}
|
}
|
||||||
dif = conTotal - (int) playerCharacter.statConBase;
|
dif = conTotal - (int) playerCharacter.statConBase;
|
||||||
if (dif > 0 && conTotal < (int) playerCharacter.statConMax) {
|
if (dif > 0 && conTotal < (int) playerCharacter.statConMax) {
|
||||||
playerCharacter.addCon(dif);
|
PlayerManager.addCon(playerCharacter, dif);
|
||||||
}
|
}
|
||||||
dif = intTotal - (int) playerCharacter.statIntBase;
|
dif = intTotal - (int) playerCharacter.statIntBase;
|
||||||
if (dif > 0 && intTotal < (int) playerCharacter.statIntMax) {
|
if (dif > 0 && intTotal < (int) playerCharacter.statIntMax) {
|
||||||
playerCharacter.addInt(dif);
|
PlayerManager.addInt(playerCharacter, dif);
|
||||||
}
|
}
|
||||||
dif = spiTotal - (int) playerCharacter.statSpiBase;
|
dif = spiTotal - (int) playerCharacter.statSpiBase;
|
||||||
if (dif > 0 && spiTotal < (int) playerCharacter.statSpiMax) {
|
if (dif > 0 && spiTotal < (int) playerCharacter.statSpiMax) {
|
||||||
playerCharacter.addSpi(dif);
|
PlayerManager.addSpi(playerCharacter, dif);
|
||||||
}
|
}
|
||||||
// recalculate all bonuses/formulas/skills/powers
|
// recalculate all bonuses/formulas/skills/powers
|
||||||
playerCharacter.recalculate();
|
playerCharacter.recalculate();
|
||||||
|
|||||||
@@ -13,6 +13,8 @@ import engine.Enum.GameObjectType;
|
|||||||
import engine.Enum.TransactionType;
|
import engine.Enum.TransactionType;
|
||||||
import engine.exception.SerializationException;
|
import engine.exception.SerializationException;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
import engine.net.ByteBufferWriter;
|
import engine.net.ByteBufferWriter;
|
||||||
@@ -102,12 +104,12 @@ public class ArcViewAssetTransactionsMsg extends ClientNetMsg {
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
case PlayerCharacter:
|
case PlayerCharacter:
|
||||||
PlayerCharacter pc = PlayerCharacter.getPlayerCharacter(transaction.getTargetUUID());
|
PlayerCharacter pc = PlayerManager.getPlayerCharacter(transaction.getTargetUUID());
|
||||||
if (pc != null)
|
if (pc != null)
|
||||||
name = pc.getCombinedName();
|
name = pc.getCombinedName();
|
||||||
break;
|
break;
|
||||||
case NPC:
|
case NPC:
|
||||||
NPC npc = NPC.getFromCache(transaction.getTargetUUID());
|
NPC npc = NPCManager.getFromCache(transaction.getTargetUUID());
|
||||||
if (npc != null) {
|
if (npc != null) {
|
||||||
|
|
||||||
if (npc.getBuilding() != null)
|
if (npc.getBuilding() != null)
|
||||||
|
|||||||
@@ -11,6 +11,8 @@ package engine.net.client.msg;
|
|||||||
|
|
||||||
import engine.Enum.ItemType;
|
import engine.Enum.ItemType;
|
||||||
import engine.exception.SerializationException;
|
import engine.exception.SerializationException;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.AbstractNetMsg;
|
import engine.net.AbstractNetMsg;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
@@ -91,7 +93,7 @@ public class BuyFromNPCWindowMsg extends ClientNetMsg {
|
|||||||
|
|
||||||
float sellPercent = 1;
|
float sellPercent = 1;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(npcID);
|
NPC npc = NPCManager.getFromCache(npcID);
|
||||||
CharacterItemManager man = null;
|
CharacterItemManager man = null;
|
||||||
ArrayList<Item> inventory = null;
|
ArrayList<Item> inventory = null;
|
||||||
ArrayList<MobEquipment> sellInventory = null;
|
ArrayList<MobEquipment> sellInventory = null;
|
||||||
@@ -100,7 +102,7 @@ public class BuyFromNPCWindowMsg extends ClientNetMsg {
|
|||||||
man = npc.getCharItemManager();
|
man = npc.getCharItemManager();
|
||||||
Contract contract = npc.getContract();
|
Contract contract = npc.getContract();
|
||||||
if (player != null) {
|
if (player != null) {
|
||||||
float barget = player.getBargain();
|
float barget = PlayerManager.getBargain(player);
|
||||||
float profit = npc.getSellPercent(player) - barget;
|
float profit = npc.getSellPercent(player) - barget;
|
||||||
|
|
||||||
if (profit < 1)
|
if (profit < 1)
|
||||||
|
|||||||
@@ -12,6 +12,7 @@ package engine.net.client.msg;
|
|||||||
|
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.ChatManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
@@ -81,7 +82,7 @@ public class IgnoreMsg extends ClientNetMsg {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//FIX THIS, USE OUR CACHE!
|
//FIX THIS, USE OUR CACHE!
|
||||||
PlayerCharacter pcToIgnore = PlayerCharacter.getByFirstName(nameToIgnore);
|
PlayerCharacter pcToIgnore = PlayerManager.getByFirstName(nameToIgnore);
|
||||||
|
|
||||||
if (pcSource == null) {
|
if (pcSource == null) {
|
||||||
return;
|
return;
|
||||||
@@ -114,11 +115,11 @@ public class IgnoreMsg extends ClientNetMsg {
|
|||||||
pcSource.removeIgnoredPlayer(pcToIgnore.getAccount());
|
pcSource.removeIgnoredPlayer(pcToIgnore.getAccount());
|
||||||
ChatManager.chatSystemInfo(pcSource, "Character " + fn + " is no longer ignored.");
|
ChatManager.chatSystemInfo(pcSource, "Character " + fn + " is no longer ignored.");
|
||||||
} else {
|
} else {
|
||||||
if (!PlayerCharacter.isIgnorable()) {
|
if (!PlayerManager.isIgnorable()) {
|
||||||
ChatManager.chatSystemError(pcSource, "This character cannot be ignored.");
|
ChatManager.chatSystemError(pcSource, "This character cannot be ignored.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (PlayerCharacter.isIgnoreListFull()) {
|
if (PlayerManager.isIgnoreListFull()) {
|
||||||
ChatManager.chatSystemError(pcSource, "Your ignore list is already full.");
|
ChatManager.chatSystemError(pcSource, "Your ignore list is already full.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.msg;
|
|||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
import engine.gameManager.PowersManager;
|
import engine.gameManager.PowersManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.AbstractNetMsg;
|
import engine.net.AbstractNetMsg;
|
||||||
@@ -291,7 +292,7 @@ public class ItemProductionMsg extends ClientNetMsg {
|
|||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
NPC vendor = NPC.getFromCache(this.npcUUID);
|
NPC vendor = NPCManager.getFromCache(this.npcUUID);
|
||||||
if (vendor != null) {
|
if (vendor != null) {
|
||||||
if (toRoll.isComplete()) {
|
if (toRoll.isComplete()) {
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
|
|||||||
@@ -392,9 +392,9 @@ public class ManageCityAssetsMsg extends ClientNetMsg {
|
|||||||
writer.putInt(bane.getSiegePhase().ordinal()); //1 challenge //2 standoff //3 war
|
writer.putInt(bane.getSiegePhase().ordinal()); //1 challenge //2 standoff //3 war
|
||||||
writer.put((byte) 0);
|
writer.put((byte) 0);
|
||||||
|
|
||||||
if (!bane.isAccepted() && this.assetManager.getGuild() == banedCity.getGuild() && GuildStatusController.isInnerCouncil(this.assetManager.getGuildStatus()))
|
//if (!bane.isAccepted() && this.assetManager.getGuild() == banedCity.getGuild() && GuildStatusController.isInnerCouncil(this.assetManager.getGuildStatus()))
|
||||||
writer.put((byte) 1); //canSetTime
|
// writer.put((byte) 1); //canSetTime
|
||||||
else
|
//else
|
||||||
writer.put((byte) 0);
|
writer.put((byte) 0);
|
||||||
|
|
||||||
DateTime placedOn = bane.getLiveDate();
|
DateTime placedOn = bane.getLiveDate();
|
||||||
|
|||||||
@@ -178,7 +178,7 @@ public class ManageNPCMsg extends ClientNetMsg {
|
|||||||
|
|
||||||
if (this.targetType == GameObjectType.NPC.ordinal()) {
|
if (this.targetType == GameObjectType.NPC.ordinal()) {
|
||||||
|
|
||||||
npc = NPC.getFromCache(this.targetID);
|
npc = NPCManager.getFromCache(this.targetID);
|
||||||
|
|
||||||
if (npc == null) {
|
if (npc == null) {
|
||||||
Logger.error("Missing NPC of ID " + this.targetID);
|
Logger.error("Missing NPC of ID " + this.targetID);
|
||||||
@@ -233,7 +233,7 @@ public class ManageNPCMsg extends ClientNetMsg {
|
|||||||
writer.put((byte) 0);
|
writer.put((byte) 0);
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
|
|
||||||
NPCProfits profit = NPC.GetNPCProfits(npc);
|
NPCProfits profit = NPCManager.GetNPCProfits(npc);
|
||||||
|
|
||||||
if (profit == null)
|
if (profit == null)
|
||||||
profit = NPCProfits.defaultProfits;
|
profit = NPCProfits.defaultProfits;
|
||||||
@@ -503,7 +503,7 @@ public class ManageNPCMsg extends ClientNetMsg {
|
|||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
writer.putString("Repair items");
|
writer.putString("Repair items");
|
||||||
writer.putString("percent");
|
writer.putString("percent");
|
||||||
writer.putInt(npc.getRepairCost()); //cost for repair
|
writer.putInt(npc.getSpecialPrice()); //cost for repair
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
|
|
||||||
ArrayList<Integer> modPrefixList = npc.getModTypeTable();
|
ArrayList<Integer> modPrefixList = npc.getModTypeTable();
|
||||||
@@ -598,7 +598,7 @@ public class ManageNPCMsg extends ClientNetMsg {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (NPC.ISGuardCaptain(mobA.getContract().getContractID()) == false)
|
if (NPCManager.ISGuardCaptain(mobA.getContract().getContractID()) == false)
|
||||||
maxSlots = 0;
|
maxSlots = 0;
|
||||||
|
|
||||||
writer.putInt(0); //anything other than 0 seems to mess up the client
|
writer.putInt(0); //anything other than 0 seems to mess up the client
|
||||||
|
|||||||
@@ -11,6 +11,8 @@ package engine.net.client.msg;
|
|||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
import engine.net.ByteBufferWriter;
|
import engine.net.ByteBufferWriter;
|
||||||
@@ -619,7 +621,7 @@ public class OpenFriendsCondemnListMsg extends ClientNetMsg {
|
|||||||
writer.putInt(listSize);
|
writer.putInt(listSize);
|
||||||
|
|
||||||
for (BuildingFriends friend : this.friends.values()) {
|
for (BuildingFriends friend : this.friends.values()) {
|
||||||
pc = PlayerCharacter.getFromCache(friend.getPlayerUID());
|
pc = PlayerManager.getFromCache(friend.getPlayerUID());
|
||||||
guild = Guild.getGuild(friend.getGuildUID());
|
guild = Guild.getGuild(friend.getGuildUID());
|
||||||
if (friend.getFriendType() == 7) {
|
if (friend.getFriendType() == 7) {
|
||||||
if (pc != null)
|
if (pc != null)
|
||||||
@@ -718,9 +720,9 @@ public class OpenFriendsCondemnListMsg extends ClientNetMsg {
|
|||||||
AbstractCharacter heraldryCharacter = null;
|
AbstractCharacter heraldryCharacter = null;
|
||||||
int characterType = heraldryMap.get(characterID);
|
int characterType = heraldryMap.get(characterID);
|
||||||
if (characterType == GameObjectType.PlayerCharacter.ordinal())
|
if (characterType == GameObjectType.PlayerCharacter.ordinal())
|
||||||
heraldryCharacter = PlayerCharacter.getFromCache(characterID);
|
heraldryCharacter = PlayerManager.getFromCache(characterID);
|
||||||
else if (characterType == GameObjectType.NPC.ordinal())
|
else if (characterType == GameObjectType.NPC.ordinal())
|
||||||
heraldryCharacter = NPC.getFromCache(characterID);
|
heraldryCharacter = NPCManager.getFromCache(characterID);
|
||||||
else if (characterType == GameObjectType.Mob.ordinal())
|
else if (characterType == GameObjectType.Mob.ordinal())
|
||||||
heraldryCharacter = Mob.getFromCache(characterID);
|
heraldryCharacter = Mob.getFromCache(characterID);
|
||||||
|
|
||||||
|
|||||||
@@ -10,6 +10,8 @@
|
|||||||
package engine.net.client.msg;
|
package engine.net.client.msg;
|
||||||
|
|
||||||
|
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.*;
|
import engine.net.*;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -62,7 +64,7 @@ public class RefineMsg extends ClientNetMsg {
|
|||||||
PlayerCharacter pc = SessionManager.getPlayerCharacter(origin);
|
PlayerCharacter pc = SessionManager.getPlayerCharacter(origin);
|
||||||
if (pc == null)
|
if (pc == null)
|
||||||
return;
|
return;
|
||||||
NPC npc = NPC.getFromCache(msg.npcID);
|
NPC npc = NPCManager.getFromCache(msg.npcID);
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
int type = msg.type;
|
int type = msg.type;
|
||||||
@@ -160,15 +162,15 @@ public class RefineMsg extends ClientNetMsg {
|
|||||||
|
|
||||||
private static boolean refineStat(ClientConnection origin, PlayerCharacter pc, int token, RefineMsg msg) {
|
private static boolean refineStat(ClientConnection origin, PlayerCharacter pc, int token, RefineMsg msg) {
|
||||||
if (token == MBServerStatics.STAT_STR_ID)
|
if (token == MBServerStatics.STAT_STR_ID)
|
||||||
return pc.refineStr();
|
return PlayerManager.refineStr(pc);
|
||||||
if (token == MBServerStatics.STAT_DEX_ID)
|
if (token == MBServerStatics.STAT_DEX_ID)
|
||||||
return pc.refineDex();
|
return PlayerManager.refineDex(pc);
|
||||||
if (token == MBServerStatics.STAT_CON_ID)
|
if (token == MBServerStatics.STAT_CON_ID)
|
||||||
return pc.refineCon();
|
return PlayerManager.refineCon(pc);
|
||||||
if (token == MBServerStatics.STAT_INT_ID)
|
if (token == MBServerStatics.STAT_INT_ID)
|
||||||
return pc.refineInt(msg);
|
return PlayerManager.refineInt(pc, msg);
|
||||||
if (token == MBServerStatics.STAT_SPI_ID)
|
if (token == MBServerStatics.STAT_SPI_ID)
|
||||||
return pc.refineSpi();
|
return PlayerManager.refineSpi(pc);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.msg;
|
|||||||
|
|
||||||
|
|
||||||
import engine.exception.SerializationException;
|
import engine.exception.SerializationException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.AbstractNetMsg;
|
import engine.net.AbstractNetMsg;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
@@ -90,7 +91,7 @@ public class SendOwnPlayerMsg extends ClientNetMsg {
|
|||||||
}
|
}
|
||||||
writer.putVector3f(ch.getLoc());
|
writer.putVector3f(ch.getLoc());
|
||||||
try {
|
try {
|
||||||
PlayerCharacter.serializeForClientMsgFull(this.ch, writer);
|
PlayerManager.serializeForClientMsgFull(this.ch, writer);
|
||||||
} catch (SerializationException e) {
|
} catch (SerializationException e) {
|
||||||
Logger.error(e);
|
Logger.error(e);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.msg;
|
|||||||
|
|
||||||
|
|
||||||
import engine.exception.SerializationException;
|
import engine.exception.SerializationException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
import engine.net.ByteBufferWriter;
|
import engine.net.ByteBufferWriter;
|
||||||
@@ -64,7 +65,7 @@ public class TerritoryChangeMessage extends ClientNetMsg {
|
|||||||
writer.putString(realm.getRealmName());
|
writer.putString(realm.getRealmName());
|
||||||
if (this.realmOwner != null) {
|
if (this.realmOwner != null) {
|
||||||
writer.putString(this.realmOwner.getCombinedName());
|
writer.putString(this.realmOwner.getCombinedName());
|
||||||
writer.putInt(PlayerCharacter.GetPlayerRealmTitle(this.realmOwner));
|
writer.putInt(PlayerManager.GetPlayerRealmTitle(this.realmOwner));
|
||||||
writer.putInt(1);
|
writer.putInt(1);
|
||||||
writer.put((byte) 1);
|
writer.put((byte) 1);
|
||||||
writer.put((byte) 1);
|
writer.put((byte) 1);
|
||||||
|
|||||||
@@ -10,6 +10,8 @@
|
|||||||
package engine.net.client.msg;
|
package engine.net.client.msg;
|
||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.AbstractNetMsg;
|
import engine.net.AbstractNetMsg;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
@@ -89,7 +91,7 @@ public class TrackWindowMsg extends ClientNetMsg {
|
|||||||
for (int i = 0; i < size; i++) {
|
for (int i = 0; i < size; i++) {
|
||||||
int objectType = reader.getInt();
|
int objectType = reader.getInt();
|
||||||
int objectID = reader.getInt();
|
int objectID = reader.getInt();
|
||||||
this.source = PlayerCharacter.getFromCache(objectID);
|
this.source = PlayerManager.getFromCache(objectID);
|
||||||
reader.getString(); //name
|
reader.getString(); //name
|
||||||
reader.get(); //always 00?
|
reader.get(); //always 00?
|
||||||
reader.getInt(); //guildObjectType
|
reader.getInt(); //guildObjectType
|
||||||
@@ -106,9 +108,9 @@ public class TrackWindowMsg extends ClientNetMsg {
|
|||||||
//Get the Character from it's Object Type and ID
|
//Get the Character from it's Object Type and ID
|
||||||
AbstractCharacter ac = null;
|
AbstractCharacter ac = null;
|
||||||
if (objectType == GameObjectType.PlayerCharacter.ordinal())
|
if (objectType == GameObjectType.PlayerCharacter.ordinal())
|
||||||
ac = PlayerCharacter.getFromCache(objectID);
|
ac = PlayerManager.getFromCache(objectID);
|
||||||
else if (objectType == GameObjectType.NPC.ordinal())
|
else if (objectType == GameObjectType.NPC.ordinal())
|
||||||
ac = NPC.getFromCache(objectID);
|
ac = NPCManager.getFromCache(objectID);
|
||||||
else if (objectType == GameObjectType.Mob.ordinal())
|
else if (objectType == GameObjectType.Mob.ordinal())
|
||||||
ac = Mob.getFromCache(objectID);
|
ac = Mob.getFromCache(objectID);
|
||||||
|
|
||||||
|
|||||||
@@ -12,10 +12,7 @@ package engine.net.client.msg;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.Enum.ProtectionState;
|
import engine.Enum.ProtectionState;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.ChatManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.PowersManager;
|
|
||||||
import engine.gameManager.SessionManager;
|
|
||||||
import engine.net.*;
|
import engine.net.*;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
import engine.net.client.Protocol;
|
import engine.net.client.Protocol;
|
||||||
@@ -65,7 +62,7 @@ public class TrainMsg extends ClientNetMsg {
|
|||||||
if (playerCharacter == null)
|
if (playerCharacter == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
NPC npc = NPC.getFromCache(msg.npcID);
|
NPC npc = NPCManager.getFromCache(msg.npcID);
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
return;
|
return;
|
||||||
|
|||||||
@@ -12,10 +12,7 @@ package engine.net.client.msg;
|
|||||||
import engine.Enum.DispatchChannel;
|
import engine.Enum.DispatchChannel;
|
||||||
import engine.Enum.GuildHistoryType;
|
import engine.Enum.GuildHistoryType;
|
||||||
import engine.exception.MsgSendException;
|
import engine.exception.MsgSendException;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.GuildManager;
|
|
||||||
import engine.gameManager.SessionManager;
|
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.net.*;
|
import engine.net.*;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -83,7 +80,7 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Get NPC that player is talking to
|
// Get NPC that player is talking to
|
||||||
NPC npc = NPC.getFromCache(msg.vendorObjectID);
|
NPC npc = NPCManager.getFromCache(msg.vendorObjectID);
|
||||||
int npcClassID;
|
int npcClassID;
|
||||||
|
|
||||||
if (npc == null)
|
if (npc == null)
|
||||||
@@ -96,11 +93,6 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if(npc.contractUUID == 1502040){ //enrollment officer
|
|
||||||
PlayerCharacter.unboxPlayer(playerCharacter);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Restrict disc trainers to only characters who have
|
// Restrict disc trainers to only characters who have
|
||||||
// tht disc applied.
|
// tht disc applied.
|
||||||
|
|
||||||
@@ -119,11 +111,22 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
|
|
||||||
VendorDialog vd = null;
|
VendorDialog vd = null;
|
||||||
Contract contract = npc.getContract();
|
Contract contract = npc.getContract();
|
||||||
|
if(npc.contractUUID == 1502043){
|
||||||
|
vd = Contract.HandleArenaMaster(msg.unknown03,npc,playerCharacter);
|
||||||
|
msg.updateMessage(3, vd);
|
||||||
|
}else if(npc.contractUUID == 1502040){ //enrollment officer
|
||||||
|
//PlayerCharacter.unboxPlayer(playerCharacter);
|
||||||
|
vd = Contract.HandleEnrollmentOfficer(msg.unknown03,npc,playerCharacter);
|
||||||
|
msg.updateMessage(3, vd);
|
||||||
|
}else if(contract.getContractID() == 1502042){
|
||||||
|
vd = Contract.HandleBaneCommanderOptions(msg.unknown03, npc, playerCharacter);
|
||||||
|
msg.updateMessage(3, vd);
|
||||||
|
}else {
|
||||||
|
|
||||||
if (contract == null)
|
if (contract == null)
|
||||||
vd = VendorDialog.getHostileVendorDialog();
|
vd = VendorDialog.getHostileVendorDialog();
|
||||||
else if (npc.getBuilding() != null) {
|
else if (npc.getBuilding() != null) {
|
||||||
if (BuildingManager.IsPlayerHostile(npc.getBuilding(), playerCharacter))
|
if (npc.getBuilding() != null && BuildingManager.IsPlayerHostile(npc.getBuilding(), playerCharacter))
|
||||||
vd = VendorDialog.getHostileVendorDialog();
|
vd = VendorDialog.getHostileVendorDialog();
|
||||||
else
|
else
|
||||||
vd = contract.getVendorDialog();
|
vd = contract.getVendorDialog();
|
||||||
@@ -131,14 +134,13 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
vd = contract.getVendorDialog();
|
vd = contract.getVendorDialog();
|
||||||
if (vd == null)
|
if (vd == null)
|
||||||
vd = VendorDialog.getHostileVendorDialog();
|
vd = VendorDialog.getHostileVendorDialog();
|
||||||
|
|
||||||
if (msg.messageType == 1 || msg.unknown03 == vd.getObjectUUID()) {
|
if (msg.messageType == 1 || msg.unknown03 == vd.getObjectUUID()) {
|
||||||
msg.updateMessage(3, vd);
|
msg.updateMessage(3, vd);
|
||||||
} else {
|
} else {
|
||||||
if (VendorDialogMsg.handleSpecialCase(msg, npc, playerCharacter, vd, origin))
|
if (VendorDialogMsg.handleSpecialCase(msg, npc, playerCharacter, vd, origin))
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
vd = VendorDialog.getVendorDialog(msg.unknown03);
|
//vd = VendorDialog.getVendorDialog(msg.unknown03);
|
||||||
msg.updateMessage(3, vd);
|
msg.updateMessage(3, vd);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -432,7 +434,7 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
if (level >= minLevel && level <= maxLevel) {
|
if (level >= minLevel && level <= maxLevel) {
|
||||||
if (useSquare)
|
if (useSquare)
|
||||||
loc = getSquare(loc);
|
loc = getSquare(loc);
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
pc.setSafeMode();
|
pc.setSafeMode();
|
||||||
// PowersManager.applyPower(pc, pc, new Vector3f(0f,
|
// PowersManager.applyPower(pc, pc, new Vector3f(0f,
|
||||||
// 0f, 0f), -1661758934, 40, false);
|
// 0f, 0f), -1661758934, 40, false);
|
||||||
@@ -458,7 +460,7 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
// teleport player
|
// teleport player
|
||||||
if (useSquare)
|
if (useSquare)
|
||||||
loc = getSquare(loc);
|
loc = getSquare(loc);
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
pc.setSafeMode();
|
pc.setSafeMode();
|
||||||
// PowersManager.applyPower(pc, pc, new
|
// PowersManager.applyPower(pc, pc, new
|
||||||
// Vector3f(0f, 0f, 0f), -1661758934, 40, false);
|
// Vector3f(0f, 0f, 0f), -1661758934, 40, false);
|
||||||
@@ -466,10 +468,10 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
// join guild
|
// join guild
|
||||||
GuildManager.joinGuild(pc, guild, GuildHistoryType.JOIN);
|
GuildManager.joinGuild(pc, guild, GuildHistoryType.JOIN);
|
||||||
|
|
||||||
pc.resetGuildStatuses();
|
PlayerManager.resetGuildStatuses(pc);
|
||||||
|
|
||||||
if (guild.isNPCGuild())
|
if (guild.isNPCGuild())
|
||||||
pc.setFullMember(true);
|
PlayerManager.setFullMember(pc, true);
|
||||||
|
|
||||||
if (useSquare)
|
if (useSquare)
|
||||||
loc = loc.add(30, 0, 0);
|
loc = loc.add(30, 0, 0);
|
||||||
@@ -478,7 +480,7 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
// guild not found, just teleport
|
// guild not found, just teleport
|
||||||
if (useSquare)
|
if (useSquare)
|
||||||
loc = getSquare(loc);
|
loc = getSquare(loc);
|
||||||
pc.teleport(loc);
|
PlayerManager.teleport(pc, loc);
|
||||||
pc.setSafeMode();
|
pc.setSafeMode();
|
||||||
// PowersManager.applyPower(pc, pc, new
|
// PowersManager.applyPower(pc, pc, new
|
||||||
// Vector3f(0f, 0f, 0f), -1661758934, 50, false);
|
// Vector3f(0f, 0f, 0f), -1661758934, 50, false);
|
||||||
@@ -570,6 +572,7 @@ public class VendorDialogMsg extends ClientNetMsg {
|
|||||||
case 2519:
|
case 2519:
|
||||||
case 2520:
|
case 2520:
|
||||||
case 2521:
|
case 2521:
|
||||||
|
case 2523:
|
||||||
valid = true;
|
valid = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -10,6 +10,7 @@
|
|||||||
package engine.net.client.msg;
|
package engine.net.client.msg;
|
||||||
|
|
||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.*;
|
import engine.net.*;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
@@ -233,8 +234,8 @@ public class WhoResponseMsg extends ClientNetMsg {
|
|||||||
writer.putInt(pc.getObjectUUID());
|
writer.putInt(pc.getObjectUUID());
|
||||||
writer.putString(pc.getFirstName());
|
writer.putString(pc.getFirstName());
|
||||||
writer.putString(pc.getLastName());
|
writer.putString(pc.getLastName());
|
||||||
writer.putInt(pc.getRaceToken());
|
writer.putInt(PlayerManager.getRaceToken(pc));
|
||||||
writer.putInt(pc.getClassToken());
|
writer.putInt(PlayerManager.getClassToken(pc));
|
||||||
writer.putInt(pc.getLevel());
|
writer.putInt(pc.getLevel());
|
||||||
writer.putInt(0); // unknown 0
|
writer.putInt(0); // unknown 0
|
||||||
writer.putInt(pc.isMale() ? 1 : 2); //gender?
|
writer.putInt(pc.isMale() ? 1 : 2); //gender?
|
||||||
|
|||||||
@@ -11,6 +11,8 @@ package engine.net.client.msg.guild;
|
|||||||
|
|
||||||
|
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
import engine.net.ByteBufferWriter;
|
import engine.net.ByteBufferWriter;
|
||||||
@@ -193,7 +195,7 @@ class GuildInfoMessageType2 extends GuildInfoMessageType {
|
|||||||
writer.putString(g.getName());
|
writer.putString(g.getName());
|
||||||
|
|
||||||
if (this.objectType == GameObjectType.PlayerCharacter.ordinal()) {
|
if (this.objectType == GameObjectType.PlayerCharacter.ordinal()) {
|
||||||
PlayerCharacter pc = PlayerCharacter.getFromCache(this.objectID);
|
PlayerCharacter pc = PlayerManager.getFromCache(this.objectID);
|
||||||
|
|
||||||
if (pc != null) {
|
if (pc != null) {
|
||||||
writer.putInt(GuildStatusController.getRank(pc.getGuildStatus()));
|
writer.putInt(GuildStatusController.getRank(pc.getGuildStatus()));
|
||||||
@@ -254,7 +256,7 @@ class GuildInfoMessageType4 extends GuildInfoMessageType {
|
|||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
PlayerCharacter pc = PlayerCharacter.getFromCache(this.objectID);
|
PlayerCharacter pc = PlayerManager.getFromCache(this.objectID);
|
||||||
if (this.g == null || pc == null) {
|
if (this.g == null || pc == null) {
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
writer.putInt(0);
|
writer.putInt(0);
|
||||||
@@ -294,11 +296,11 @@ class GuildInfoMessageType4 extends GuildInfoMessageType {
|
|||||||
AbstractCharacter guildLeader;
|
AbstractCharacter guildLeader;
|
||||||
String guildLeaderName = "";
|
String guildLeaderName = "";
|
||||||
if (g.isNPCGuild()) {
|
if (g.isNPCGuild()) {
|
||||||
guildLeader = NPC.getFromCache(g.getGuildLeaderUUID());
|
guildLeader = NPCManager.getFromCache(g.getGuildLeaderUUID());
|
||||||
if (guildLeader != null)
|
if (guildLeader != null)
|
||||||
guildLeaderName = guildLeader.getName();
|
guildLeaderName = guildLeader.getName();
|
||||||
} else {
|
} else {
|
||||||
guildLeader = PlayerCharacter.getFromCache(g.getGuildLeaderUUID());
|
guildLeader = PlayerManager.getFromCache(g.getGuildLeaderUUID());
|
||||||
if (guildLeader != null)
|
if (guildLeader != null)
|
||||||
guildLeaderName = ((PlayerCharacter) guildLeader).getCombinedName();
|
guildLeaderName = ((PlayerCharacter) guildLeader).getCombinedName();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.msg.guild;
|
|||||||
|
|
||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
@@ -204,7 +205,7 @@ class GuildListMessageType2 extends GuildListMessageType {
|
|||||||
writer.putInt(GuildStatusController.getTitle(pc.getGuildStatus())); //Title Maybe?
|
writer.putInt(GuildStatusController.getTitle(pc.getGuildStatus())); //Title Maybe?
|
||||||
writer.putInt(GuildStatusController.getRank(pc.getGuildStatus())); //Rank?
|
writer.putInt(GuildStatusController.getRank(pc.getGuildStatus())); //Rank?
|
||||||
|
|
||||||
writer.putInt(pc.getRaceToken()); //race token
|
writer.putInt(PlayerManager.getRaceToken(pc)); //race token
|
||||||
writer.putInt(pc.getBaseClassToken()); //class token
|
writer.putInt(pc.getBaseClassToken()); //class token
|
||||||
|
|
||||||
writer.putInt(2); //PAD
|
writer.putInt(2); //PAD
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ package engine.net.client.msg.login;
|
|||||||
|
|
||||||
|
|
||||||
import engine.exception.SerializationException;
|
import engine.exception.SerializationException;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.net.AbstractConnection;
|
import engine.net.AbstractConnection;
|
||||||
import engine.net.AbstractNetMsg;
|
import engine.net.AbstractNetMsg;
|
||||||
import engine.net.ByteBufferReader;
|
import engine.net.ByteBufferReader;
|
||||||
@@ -162,9 +163,9 @@ public class CharSelectScreenMsg extends ClientNetMsg {
|
|||||||
for (int i = 0; i < this.numChars; ++i) {
|
for (int i = 0; i < this.numChars; ++i) {
|
||||||
try {
|
try {
|
||||||
if (!fromCommit)
|
if (!fromCommit)
|
||||||
PlayerCharacter.serializeForClientMsgLogin(this.chars.get(i), writer);
|
PlayerManager.serializeForClientMsgLogin(this.chars.get(i), writer);
|
||||||
else
|
else
|
||||||
PlayerCharacter.serializeForClientMsgCommit(this.chars.get(i), writer);
|
PlayerManager.serializeForClientMsgCommit(this.chars.get(i), writer);
|
||||||
} catch (SerializationException e) {
|
} catch (SerializationException e) {
|
||||||
Logger.error("failed to serialize character " + this.chars.get(i).getObjectUUID());
|
Logger.error("failed to serialize character " + this.chars.get(i).getObjectUUID());
|
||||||
// Handled already.
|
// Handled already.
|
||||||
|
|||||||
@@ -14,10 +14,7 @@ import engine.Enum.*;
|
|||||||
import engine.InterestManagement.InterestManager;
|
import engine.InterestManagement.InterestManager;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.exception.SerializationException;
|
import engine.exception.SerializationException;
|
||||||
import engine.gameManager.CombatManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.ConfigManager;
|
|
||||||
import engine.gameManager.MovementManager;
|
|
||||||
import engine.gameManager.PowersManager;
|
|
||||||
import engine.job.AbstractJob;
|
import engine.job.AbstractJob;
|
||||||
import engine.job.JobContainer;
|
import engine.job.JobContainer;
|
||||||
import engine.job.JobScheduler;
|
import engine.job.JobScheduler;
|
||||||
@@ -31,7 +28,6 @@ import engine.net.ByteBufferWriter;
|
|||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.msg.UpdateStateMsg;
|
import engine.net.client.msg.UpdateStateMsg;
|
||||||
import engine.powers.EffectsBase;
|
import engine.powers.EffectsBase;
|
||||||
import engine.powers.effectmodifiers.AbstractEffectModifier;
|
|
||||||
import engine.server.MBServerStatics;
|
import engine.server.MBServerStatics;
|
||||||
import org.pmw.tinylog.Logger;
|
import org.pmw.tinylog.Logger;
|
||||||
|
|
||||||
@@ -61,7 +57,7 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
protected short statIntCurrent;
|
protected short statIntCurrent;
|
||||||
protected short statSpiCurrent;
|
protected short statSpiCurrent;
|
||||||
protected short unusedStatPoints;
|
protected short unusedStatPoints;
|
||||||
protected int exp;
|
public int exp;
|
||||||
public int buildingUUID;
|
public int buildingUUID;
|
||||||
public Building building;
|
public Building building;
|
||||||
|
|
||||||
@@ -71,8 +67,8 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
public int guildUUID;
|
public int guildUUID;
|
||||||
public Guild guild;
|
public Guild guild;
|
||||||
protected byte runningTrains;
|
protected byte runningTrains;
|
||||||
protected ConcurrentHashMap<Integer, CharacterPower> powers;
|
public ConcurrentHashMap<Integer, CharacterPower> powers;
|
||||||
protected ConcurrentHashMap<String, CharacterSkill> skills;
|
public ConcurrentHashMap<String, CharacterSkill> skills;
|
||||||
// Variables NOT to be stored in db
|
// Variables NOT to be stored in db
|
||||||
protected boolean sit = false;
|
protected boolean sit = false;
|
||||||
protected boolean walkMode;
|
protected boolean walkMode;
|
||||||
@@ -84,11 +80,11 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
// ticking down so that mobs/players following dont just move away to your projected location
|
// ticking down so that mobs/players following dont just move away to your projected location
|
||||||
protected Vector3fImmutable nextEndLoc = Vector3fImmutable.ZERO;
|
protected Vector3fImmutable nextEndLoc = Vector3fImmutable.ZERO;
|
||||||
protected float speed;
|
protected float speed;
|
||||||
protected AtomicFloat stamina = new AtomicFloat();
|
public AtomicFloat stamina = new AtomicFloat();
|
||||||
protected float staminaMax;
|
protected float staminaMax;
|
||||||
protected AtomicFloat mana = new AtomicFloat();
|
public AtomicFloat mana = new AtomicFloat();
|
||||||
protected float manaMax; // Health/Mana/Stamina
|
protected float manaMax; // Health/Mana/Stamina
|
||||||
protected AtomicBoolean isAlive = new AtomicBoolean(true);
|
public AtomicBoolean isAlive = new AtomicBoolean(true);
|
||||||
protected Resists resists = new Resists("Genric");
|
protected Resists resists = new Resists("Genric");
|
||||||
protected ConcurrentHashMap<String, JobContainer> timers;
|
protected ConcurrentHashMap<String, JobContainer> timers;
|
||||||
protected ConcurrentHashMap<String, Long> timestamps;
|
protected ConcurrentHashMap<String, Long> timestamps;
|
||||||
@@ -106,7 +102,7 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
protected boolean isActive; // <-Do not use this for deleting character!
|
protected boolean isActive; // <-Do not use this for deleting character!
|
||||||
protected float altitude = 0; // 0=on terrain, 1=tier 1, 2=tier 2, etc.
|
protected float altitude = 0; // 0=on terrain, 1=tier 1, 2=tier 2, etc.
|
||||||
protected ConcurrentHashMap<Integer, JobContainer> recycleTimers;
|
protected ConcurrentHashMap<Integer, JobContainer> recycleTimers;
|
||||||
protected PlayerBonuses bonuses;
|
public PlayerBonuses bonuses;
|
||||||
protected JobContainer lastChant;
|
protected JobContainer lastChant;
|
||||||
protected boolean isCasting = false;
|
protected boolean isCasting = false;
|
||||||
protected long lastSetLocUpdate = 0L;
|
protected long lastSetLocUpdate = 0L;
|
||||||
@@ -367,13 +363,13 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
|
|
||||||
switch (abstractCharacter.getObjectType()) {
|
switch (abstractCharacter.getObjectType()) {
|
||||||
case PlayerCharacter:
|
case PlayerCharacter:
|
||||||
PlayerCharacter.serializePlayerForClientMsgOtherPlayer((PlayerCharacter) abstractCharacter, writer, asciiLastName);
|
PlayerManager.serializePlayerForClientMsgOtherPlayer((PlayerCharacter) abstractCharacter, writer, asciiLastName);
|
||||||
break;
|
break;
|
||||||
case Mob:
|
case Mob:
|
||||||
Mob.serializeMobForClientMsgOtherPlayer((Mob) abstractCharacter, writer);
|
Mob.serializeMobForClientMsgOtherPlayer((Mob) abstractCharacter, writer);
|
||||||
break;
|
break;
|
||||||
case NPC:
|
case NPC:
|
||||||
NPC.serializeNpcForClientMsgOtherPlayer((NPC) abstractCharacter, writer, asciiLastName);
|
NPCManager.serializeNpcForClientMsgOtherPlayer((NPC) abstractCharacter, writer, asciiLastName);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -449,7 +445,7 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
playerCharacter.calculateItemBonuses();
|
playerCharacter.calculateItemBonuses();
|
||||||
|
|
||||||
//recalculate formulas
|
//recalculate formulas
|
||||||
PlayerCharacter.recalculatePlayerStatsOnLoad(playerCharacter);
|
PlayerManager.recalculatePlayerStatsOnLoad(playerCharacter);
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
Logger.error(e);
|
Logger.error(e);
|
||||||
@@ -750,7 +746,7 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this.getObjectType().equals(GameObjectType.PlayerCharacter))
|
if (this.getObjectType().equals(GameObjectType.PlayerCharacter))
|
||||||
if (((PlayerCharacter) this).isLastSwimming())
|
if (PlayerManager.isLastSwimming(((PlayerCharacter) this)))
|
||||||
return 1; //swimming
|
return 1; //swimming
|
||||||
|
|
||||||
return 2; //ground
|
return 2; //ground
|
||||||
@@ -765,8 +761,12 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
public abstract Vector3fImmutable getBindLoc();
|
public abstract Vector3fImmutable getBindLoc();
|
||||||
|
|
||||||
public final void setBindLoc(final Vector3fImmutable value) {
|
public final void setBindLoc(final Vector3fImmutable value) {
|
||||||
|
if(this.getObjectType().equals(GameObjectType.PlayerCharacter) && this.guild.getNation().equals(Guild.getErrantGuild())){
|
||||||
|
this.bindLoc = Vector3fImmutable.getRandomPointOnCircle(BuildingManager.getBuilding(27977).loc,20f);
|
||||||
|
}else {
|
||||||
this.bindLoc = value;
|
this.bindLoc = value;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public final Vector3fImmutable getFaceDir() {
|
public final Vector3fImmutable getFaceDir() {
|
||||||
return this.faceDir;
|
return this.faceDir;
|
||||||
@@ -1559,7 +1559,15 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
Effect eff = this.effects.get(s);
|
Effect eff = this.effects.get(s);
|
||||||
if (eff == null)
|
if (eff == null)
|
||||||
continue;
|
continue;
|
||||||
if (eff.cancelOnMove() && eff.cancel()) {
|
|
||||||
|
Boolean override = false;
|
||||||
|
if(this.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
||||||
|
PlayerCharacter pc = (PlayerCharacter) this;
|
||||||
|
if (eff.getEffectsBase().getIDString().equals("INVIS-B") && s.equals("Invisible") && pc.getRace().getName().contains("Shade"))
|
||||||
|
override = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!override && eff.cancelOnMove() && eff.cancel()) {
|
||||||
//System.out.println("canceling on Move");
|
//System.out.println("canceling on Move");
|
||||||
eff.cancelJob();
|
eff.cancelJob();
|
||||||
this.effects.remove(s);
|
this.effects.remove(s);
|
||||||
@@ -1699,7 +1707,7 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
|
|
||||||
if (CanFly(player) == false &&
|
if (CanFly(player) == false &&
|
||||||
player.getMovementState().equals(MovementState.FLYING))
|
player.getMovementState().equals(MovementState.FLYING))
|
||||||
PlayerCharacter.GroundPlayer(player);
|
PlayerManager.GroundPlayer(player);
|
||||||
}
|
}
|
||||||
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
@@ -1841,7 +1849,7 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//updates
|
//updates
|
||||||
public void update() {
|
public void update(Boolean newSystem) {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateRegen() {
|
public void updateRegen() {
|
||||||
@@ -1861,16 +1869,16 @@ public abstract class AbstractCharacter extends AbstractWorldObject {
|
|||||||
try {
|
try {
|
||||||
switch (updateType) {
|
switch (updateType) {
|
||||||
case ALL:
|
case ALL:
|
||||||
update();
|
update(false);
|
||||||
break;
|
break;
|
||||||
case REGEN:
|
case REGEN:
|
||||||
updateRegen();
|
updateRegen();
|
||||||
break;
|
break;
|
||||||
case LOCATION:
|
case LOCATION:
|
||||||
update();
|
update(false);
|
||||||
break;
|
break;
|
||||||
case MOVEMENTSTATE:
|
case MOVEMENTSTATE:
|
||||||
update();
|
update(false);
|
||||||
break;
|
break;
|
||||||
case FLIGHT:
|
case FLIGHT:
|
||||||
updateFlight();
|
updateFlight();
|
||||||
|
|||||||
@@ -12,6 +12,8 @@ package engine.objects;
|
|||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.BuildingManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.NPCManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.job.JobContainer;
|
import engine.job.JobContainer;
|
||||||
import engine.job.JobScheduler;
|
import engine.job.JobScheduler;
|
||||||
import engine.jobs.DatabaseUpdateJob;
|
import engine.jobs.DatabaseUpdateJob;
|
||||||
@@ -107,10 +109,10 @@ public abstract class AbstractGameObject {
|
|||||||
|
|
||||||
switch (objectType) {
|
switch (objectType) {
|
||||||
case PlayerCharacter:
|
case PlayerCharacter:
|
||||||
return PlayerCharacter.getPlayerCharacter(tableID);
|
return PlayerManager.getPlayerCharacter(tableID);
|
||||||
|
|
||||||
case NPC:
|
case NPC:
|
||||||
return NPC.getNPC(tableID);
|
return NPCManager.getNPC(tableID);
|
||||||
|
|
||||||
case Mob:
|
case Mob:
|
||||||
return Mob.getMob(tableID);
|
return Mob.getMob(tableID);
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ import engine.Enum.GameObjectType;
|
|||||||
import engine.Enum.GridObjectType;
|
import engine.Enum.GridObjectType;
|
||||||
import engine.InterestManagement.HeightMap;
|
import engine.InterestManagement.HeightMap;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.job.AbstractScheduleJob;
|
import engine.job.AbstractScheduleJob;
|
||||||
import engine.job.JobContainer;
|
import engine.job.JobContainer;
|
||||||
import engine.job.JobScheduler;
|
import engine.job.JobScheduler;
|
||||||
@@ -39,7 +40,7 @@ import java.util.concurrent.locks.ReentrantReadWriteLock;
|
|||||||
|
|
||||||
public abstract class AbstractWorldObject extends AbstractGameObject {
|
public abstract class AbstractWorldObject extends AbstractGameObject {
|
||||||
|
|
||||||
protected final ReadWriteLock locationLock = new ReentrantReadWriteLock(true);
|
public final ReadWriteLock locationLock = new ReentrantReadWriteLock(true);
|
||||||
protected final ReadWriteLock updateLock = new ReentrantReadWriteLock(true);
|
protected final ReadWriteLock updateLock = new ReentrantReadWriteLock(true);
|
||||||
public float healthMax;
|
public float healthMax;
|
||||||
public ConcurrentHashMap<String, Effect> effects = new ConcurrentHashMap<>(MBServerStatics.CHM_INIT_CAP, MBServerStatics.CHM_LOAD, MBServerStatics.CHM_THREAD_LOW);
|
public ConcurrentHashMap<String, Effect> effects = new ConcurrentHashMap<>(MBServerStatics.CHM_INIT_CAP, MBServerStatics.CHM_LOAD, MBServerStatics.CHM_THREAD_LOW);
|
||||||
@@ -49,7 +50,7 @@ public abstract class AbstractWorldObject extends AbstractGameObject {
|
|||||||
public Regions landingRegion = null;
|
public Regions landingRegion = null;
|
||||||
public Vector3fImmutable lastLoc = Vector3fImmutable.ZERO;
|
public Vector3fImmutable lastLoc = Vector3fImmutable.ZERO;
|
||||||
public Vector3fImmutable loc = new Vector3fImmutable(0.0f, 0.0f, 0.0f);
|
public Vector3fImmutable loc = new Vector3fImmutable(0.0f, 0.0f, 0.0f);
|
||||||
protected AtomicFloat health = new AtomicFloat();
|
public AtomicFloat health = new AtomicFloat();
|
||||||
protected boolean load = true;
|
protected boolean load = true;
|
||||||
protected GridObjectType gridObjectType;
|
protected GridObjectType gridObjectType;
|
||||||
protected float altitude = 0;
|
protected float altitude = 0;
|
||||||
@@ -150,7 +151,7 @@ public abstract class AbstractWorldObject extends AbstractGameObject {
|
|||||||
Regions region = null;
|
Regions region = null;
|
||||||
|
|
||||||
if (worldObject.getObjectType().equals(GameObjectType.PlayerCharacter))
|
if (worldObject.getObjectType().equals(GameObjectType.PlayerCharacter))
|
||||||
if (((PlayerCharacter) worldObject).isFlying())
|
if (PlayerManager.isFlying(((PlayerCharacter) worldObject)))
|
||||||
return null;
|
return null;
|
||||||
//Find building
|
//Find building
|
||||||
for (AbstractWorldObject awo : WorldGrid.getObjectsInRangePartial(worldObject.getLoc(), MBServerStatics.STRUCTURE_LOAD_RANGE, MBServerStatics.MASK_BUILDING)) {
|
for (AbstractWorldObject awo : WorldGrid.getObjectsInRangePartial(worldObject.getLoc(), MBServerStatics.STRUCTURE_LOAD_RANGE, MBServerStatics.MASK_BUILDING)) {
|
||||||
@@ -270,8 +271,8 @@ public abstract class AbstractWorldObject extends AbstractGameObject {
|
|||||||
this.effects.remove(name);
|
this.effects.remove(name);
|
||||||
if (this.getObjectType().equals(GameObjectType.PlayerCharacter))
|
if (this.getObjectType().equals(GameObjectType.PlayerCharacter))
|
||||||
if (name.equals("Flight")) {
|
if (name.equals("Flight")) {
|
||||||
((PlayerCharacter) this).update();
|
((PlayerCharacter) this).update(false);
|
||||||
PlayerCharacter.GroundPlayer((PlayerCharacter) this);
|
PlayerManager.GroundPlayer((PlayerCharacter) this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
applyAllBonuses();
|
applyAllBonuses();
|
||||||
@@ -385,8 +386,8 @@ public abstract class AbstractWorldObject extends AbstractGameObject {
|
|||||||
if (source.equals("Flight")) {
|
if (source.equals("Flight")) {
|
||||||
//ground player
|
//ground player
|
||||||
if (this.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
if (this.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
||||||
((PlayerCharacter) this).update();
|
((PlayerCharacter) this).update(false);
|
||||||
PlayerCharacter.GroundPlayer((PlayerCharacter) this);
|
PlayerManager.GroundPlayer((PlayerCharacter) this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@@ -414,8 +415,8 @@ public abstract class AbstractWorldObject extends AbstractGameObject {
|
|||||||
if (source.equals("Flight")) {
|
if (source.equals("Flight")) {
|
||||||
//ground player
|
//ground player
|
||||||
if (this.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
if (this.getObjectType().equals(GameObjectType.PlayerCharacter)) {
|
||||||
((PlayerCharacter) this).update();
|
((PlayerCharacter) this).update(false);
|
||||||
PlayerCharacter.GroundPlayer((PlayerCharacter) this);
|
PlayerManager.GroundPlayer((PlayerCharacter) this);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,7 @@ import engine.Enum.DispatchChannel;
|
|||||||
import engine.Enum.ItemContainerType;
|
import engine.Enum.ItemContainerType;
|
||||||
import engine.gameManager.ConfigManager;
|
import engine.gameManager.ConfigManager;
|
||||||
import engine.gameManager.DbManager;
|
import engine.gameManager.DbManager;
|
||||||
|
import engine.gameManager.PlayerManager;
|
||||||
import engine.gameManager.SessionManager;
|
import engine.gameManager.SessionManager;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -163,7 +164,7 @@ public class Account extends AbstractGameObject {
|
|||||||
ArrayList<PlayerCharacter> playerList = DbManager.PlayerCharacterQueries.GET_CHARACTERS_FOR_ACCOUNT(this.getObjectUUID());
|
ArrayList<PlayerCharacter> playerList = DbManager.PlayerCharacterQueries.GET_CHARACTERS_FOR_ACCOUNT(this.getObjectUUID());
|
||||||
|
|
||||||
for (PlayerCharacter player : playerList) {
|
for (PlayerCharacter player : playerList) {
|
||||||
PlayerCharacter.initializePlayer(player);
|
PlayerManager.initializePlayer(player);
|
||||||
this.characterMap.putIfAbsent(player.getObjectUUID(), player);
|
this.characterMap.putIfAbsent(player.getObjectUUID(), player);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -0,0 +1,82 @@
|
|||||||
|
package engine.objects;
|
||||||
|
|
||||||
|
import engine.InterestManagement.WorldGrid;
|
||||||
|
import engine.gameManager.ArenaManager;
|
||||||
|
import engine.gameManager.ChatManager;
|
||||||
|
import engine.gameManager.MovementManager;
|
||||||
|
import engine.math.Vector3fImmutable;
|
||||||
|
import engine.server.MBServerStatics;
|
||||||
|
|
||||||
|
import java.util.HashSet;
|
||||||
|
|
||||||
|
public class Arena {
|
||||||
|
public PlayerCharacter player1;
|
||||||
|
public PlayerCharacter player2;
|
||||||
|
public Long startTime;
|
||||||
|
public Vector3fImmutable loc;
|
||||||
|
|
||||||
|
public Arena(){
|
||||||
|
|
||||||
|
}
|
||||||
|
public Boolean disqualify() {
|
||||||
|
HashSet<AbstractWorldObject> inRange = WorldGrid.getObjectsInRangePartial(this.loc, 250f, MBServerStatics.MASK_PLAYER);
|
||||||
|
HashSet<AbstractWorldObject> warningRange = WorldGrid.getObjectsInRangePartial(this.loc, 500f, MBServerStatics.MASK_PLAYER);
|
||||||
|
for(AbstractWorldObject obj : warningRange){
|
||||||
|
PlayerCharacter pc = (PlayerCharacter)obj;
|
||||||
|
if(pc.equals(this.player1) || pc.equals(this.player2))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
ChatManager.chatSystemInfo(pc, "WARNING!! You are entering an arena zone!");
|
||||||
|
}
|
||||||
|
//boot out all non competitors
|
||||||
|
for(AbstractWorldObject obj : inRange){
|
||||||
|
if(obj.equals(this.player1))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if(obj.equals(this.player2))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
PlayerCharacter intruder = (PlayerCharacter)obj;
|
||||||
|
MovementManager.translocate(intruder,new Vector3fImmutable(88853,32,45079),Regions.GetRegionForTeleport(new Vector3fImmutable(88853,32,45079)));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!inRange.contains(this.player1) && inRange.contains(this.player2)) {
|
||||||
|
ArenaManager.endArena(this,this.player2,this.player1,"Player Has Left Arena");
|
||||||
|
return true;
|
||||||
|
} else if (!inRange.contains(this.player2) && inRange.contains(this.player1)) {
|
||||||
|
ArenaManager.endArena(this,this.player1,this.player2,"Player Has Left Arena");
|
||||||
|
return true;
|
||||||
|
}else if (!inRange.contains(this.player2) && !inRange.contains(this.player1)) {
|
||||||
|
ArenaManager.endArena(this,null,null,"Both Parties Have Left The Arena");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Boolean checkToComplete(){
|
||||||
|
|
||||||
|
if(this.startTime == null)
|
||||||
|
this.startTime = System.currentTimeMillis();
|
||||||
|
|
||||||
|
if(System.currentTimeMillis() - this.startTime < 10000L)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if(this.disqualify())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
if(!this.player1.isAlive() && this.player2.isAlive()){
|
||||||
|
ArenaManager.endArena(this,this.player2,this.player1,"Player Has Died");
|
||||||
|
return true;
|
||||||
|
} else if(this.player1.isAlive() && !this.player2.isAlive()){
|
||||||
|
ArenaManager.endArena(this,this.player1,this.player2,"Player Has Died");
|
||||||
|
return true;
|
||||||
|
} else if(!this.player1.isAlive() && !this.player2.isAlive()){
|
||||||
|
ArenaManager.endArena(this,null,null,"Both Players Have Died");
|
||||||
|
return true;
|
||||||
|
} else if(this.startTime + 300000L < System.currentTimeMillis()){
|
||||||
|
ArenaManager.endArena(this,null,null,"Time Has Elapsed");
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
+145
-10
@@ -14,19 +14,19 @@ import engine.Enum.ProtectionState;
|
|||||||
import engine.Enum.SiegePhase;
|
import engine.Enum.SiegePhase;
|
||||||
import engine.Enum.SiegeResult;
|
import engine.Enum.SiegeResult;
|
||||||
import engine.InterestManagement.HeightMap;
|
import engine.InterestManagement.HeightMap;
|
||||||
|
import engine.InterestManagement.InterestManager;
|
||||||
import engine.InterestManagement.WorldGrid;
|
import engine.InterestManagement.WorldGrid;
|
||||||
import engine.db.archive.BaneRecord;
|
import engine.db.archive.BaneRecord;
|
||||||
import engine.db.archive.DataWarehouse;
|
import engine.db.archive.DataWarehouse;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.ChatManager;
|
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.ZoneManager;
|
|
||||||
import engine.job.JobScheduler;
|
import engine.job.JobScheduler;
|
||||||
import engine.jobs.ActivateBaneJob;
|
import engine.jobs.ActivateBaneJob;
|
||||||
import engine.jobs.BaneDefaultTimeJob;
|
import engine.jobs.BaneDefaultTimeJob;
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
import engine.net.client.ClientConnection;
|
import engine.net.client.ClientConnection;
|
||||||
|
import engine.net.client.msg.CityDataMsg;
|
||||||
import engine.net.client.msg.PlaceAssetMsg;
|
import engine.net.client.msg.PlaceAssetMsg;
|
||||||
import engine.net.client.msg.chat.ChatSystemMsg;
|
import engine.net.client.msg.chat.ChatSystemMsg;
|
||||||
import engine.server.MBServerStatics;
|
import engine.server.MBServerStatics;
|
||||||
@@ -37,6 +37,7 @@ import java.sql.ResultSet;
|
|||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
|
import java.util.HashSet;
|
||||||
import java.util.concurrent.ConcurrentHashMap;
|
import java.util.concurrent.ConcurrentHashMap;
|
||||||
|
|
||||||
public final class Bane {
|
public final class Bane {
|
||||||
@@ -48,6 +49,10 @@ public final class Bane {
|
|||||||
private DateTime placementDate = null;
|
private DateTime placementDate = null;
|
||||||
private DateTime liveDate = null;
|
private DateTime liveDate = null;
|
||||||
private BaneDefaultTimeJob defaultTimeJob;
|
private BaneDefaultTimeJob defaultTimeJob;
|
||||||
|
public boolean timeSet = false;
|
||||||
|
public boolean daySet = false;
|
||||||
|
public boolean capSet = false;
|
||||||
|
public int capSize = 10;
|
||||||
|
|
||||||
// Internal cache for banes
|
// Internal cache for banes
|
||||||
private ActivateBaneJob activateBaneJob;
|
private ActivateBaneJob activateBaneJob;
|
||||||
@@ -64,6 +69,12 @@ public final class Bane {
|
|||||||
this.ownerUUID = rs.getInt("ownerUUID");
|
this.ownerUUID = rs.getInt("ownerUUID");
|
||||||
this.stoneUUID = rs.getInt("stoneUUID");
|
this.stoneUUID = rs.getInt("stoneUUID");
|
||||||
|
|
||||||
|
this.timeSet = rs.getInt("time_set") == 1;
|
||||||
|
this.daySet = rs.getInt("day_set") == 1;
|
||||||
|
this.capSet = rs.getInt("cap_set") == 1;
|
||||||
|
this.capSize = rs.getInt("cap_size");
|
||||||
|
|
||||||
|
|
||||||
sqlDateTime = rs.getTimestamp("placementDate");
|
sqlDateTime = rs.getTimestamp("placementDate");
|
||||||
|
|
||||||
if (sqlDateTime != null)
|
if (sqlDateTime != null)
|
||||||
@@ -100,12 +111,11 @@ public final class Bane {
|
|||||||
abtj = new ActivateBaneJob(cityUUID);
|
abtj = new ActivateBaneJob(cityUUID);
|
||||||
JobScheduler.getInstance().scheduleJob(abtj, this.liveDate.getMillis());
|
JobScheduler.getInstance().scheduleJob(abtj, this.liveDate.getMillis());
|
||||||
this.activateBaneJob = abtj;
|
this.activateBaneJob = abtj;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.liveDate == null)
|
//add bane commander NPC
|
||||||
setDefaultTime();
|
//summonBaneCommander(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean summonBanestone(PlayerCharacter player, ClientConnection origin, int rank) {
|
public static boolean summonBanestone(PlayerCharacter player, ClientConnection origin, int rank) {
|
||||||
@@ -251,7 +261,7 @@ public final class Bane {
|
|||||||
Vector3fImmutable movePlayerOutsideStone = player.getLoc();
|
Vector3fImmutable movePlayerOutsideStone = player.getLoc();
|
||||||
movePlayerOutsideStone = movePlayerOutsideStone.setX(movePlayerOutsideStone.x + 10);
|
movePlayerOutsideStone = movePlayerOutsideStone.setX(movePlayerOutsideStone.x + 10);
|
||||||
movePlayerOutsideStone = movePlayerOutsideStone.setZ(movePlayerOutsideStone.z + 10);
|
movePlayerOutsideStone = movePlayerOutsideStone.setZ(movePlayerOutsideStone.z + 10);
|
||||||
player.teleport(movePlayerOutsideStone);
|
PlayerManager.teleport(player, movePlayerOutsideStone);
|
||||||
|
|
||||||
// Notify players
|
// Notify players
|
||||||
|
|
||||||
@@ -266,9 +276,58 @@ public final class Bane {
|
|||||||
BaneRecord baneRecord = BaneRecord.borrow(bane, Enum.RecordEventType.PENDING);
|
BaneRecord baneRecord = BaneRecord.borrow(bane, Enum.RecordEventType.PENDING);
|
||||||
DataWarehouse.pushToWarehouse(baneRecord);
|
DataWarehouse.pushToWarehouse(baneRecord);
|
||||||
|
|
||||||
|
//add bane commander NPC
|
||||||
|
summonBaneCommander(bane);
|
||||||
|
|
||||||
|
try {
|
||||||
|
//update map for all players online
|
||||||
|
for (PlayerCharacter playerCharacter : SessionManager.getAllActivePlayerCharacters()) {
|
||||||
|
CityDataMsg cityDataMsg = new CityDataMsg(SessionManager.getSession(playerCharacter), false);
|
||||||
|
cityDataMsg.updateMines(true);
|
||||||
|
cityDataMsg.updateCities(true);
|
||||||
|
Dispatch dispatch = Dispatch.borrow(playerCharacter, cityDataMsg);
|
||||||
|
DispatchMessage.dispatchMsgDispatch(dispatch, Enum.DispatchChannel.SECONDARY);
|
||||||
|
}
|
||||||
|
}catch(Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static void summonBaneCommander(Bane bane){
|
||||||
|
Vector3fImmutable spawnLoc = Vector3fImmutable.getRandomPointOnCircle(bane.getStone().loc,6);
|
||||||
|
NPC baneCommander;
|
||||||
|
int commanderuuid = DbManager.NPCQueries.BANE_COMMANDER_EXISTS(bane.getStone().getObjectUUID());
|
||||||
|
|
||||||
|
if(commanderuuid == 0) {
|
||||||
|
//add bane commander NPC
|
||||||
|
int contractID = 1502042;
|
||||||
|
baneCommander = NPCManager.createNPC("Bane Commander", contractID, spawnLoc, bane.getCity().getGuild(), ZoneManager.findSmallestZone(bane.getStone().loc), (short) 70, bane.getStone());
|
||||||
|
try {
|
||||||
|
NPCManager.slotCharacterInBuilding(baneCommander);
|
||||||
|
}catch(Exception e){
|
||||||
|
|
||||||
|
}
|
||||||
|
WorldGrid.addObject(baneCommander,spawnLoc.x,spawnLoc.z);
|
||||||
|
WorldGrid.updateObject(baneCommander);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
baneCommander = NPCManager.getNPC(commanderuuid);
|
||||||
|
}
|
||||||
|
//try {
|
||||||
|
// NPCManager.slotCharacterInBuilding(baneCommander);
|
||||||
|
//}catch (Exception e){
|
||||||
|
//swallow it
|
||||||
|
//}
|
||||||
|
baneCommander.runAfterLoad();
|
||||||
|
//baneCommander.setLoc(spawnLoc);
|
||||||
|
InterestManager.setObjectDirty(baneCommander);
|
||||||
|
|
||||||
|
baneCommander.updateLocation();
|
||||||
|
}
|
||||||
|
|
||||||
public static Bane getBane(int cityUUID) {
|
public static Bane getBane(int cityUUID) {
|
||||||
|
|
||||||
Bane outBane;
|
Bane outBane;
|
||||||
@@ -381,8 +440,12 @@ public final class Bane {
|
|||||||
defaultTime = defaultTime.minuteOfHour().setCopy(0);
|
defaultTime = defaultTime.minuteOfHour().setCopy(0);
|
||||||
defaultTime = defaultTime.secondOfMinute().setCopy(0);
|
defaultTime = defaultTime.secondOfMinute().setCopy(0);
|
||||||
|
|
||||||
if (currentTime.isAfter(timeToSetDefault))
|
if (currentTime.isAfter(timeToSetDefault)){
|
||||||
this.setLiveDate(defaultTime);
|
DbManager.BaneQueries.SET_BANE_CAP_NEW(20,this.getCityUUID());
|
||||||
|
DbManager.BaneQueries.SET_BANE_TIME_NEW(9,this.getCityUUID());
|
||||||
|
DbManager.BaneQueries.SET_BANE_DAY_NEW(3,this.getCityUUID());
|
||||||
|
}
|
||||||
|
//this.setLiveDate(defaultTime);
|
||||||
else {
|
else {
|
||||||
|
|
||||||
if (this.defaultTimeJob != null)
|
if (this.defaultTimeJob != null)
|
||||||
@@ -448,6 +511,16 @@ public final class Bane {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Remove bane commander NPC
|
||||||
|
if(!baneStone.getHirelings().isEmpty()) {
|
||||||
|
NPC npc = (NPC)baneStone.getHirelings().keySet().stream().findFirst().orElse(null);
|
||||||
|
if(npc != null) {
|
||||||
|
DbManager.NPCQueries.DELETE_NPC(npc);
|
||||||
|
DbManager.removeFromCache(npc);
|
||||||
|
WorldGrid.RemoveWorldObject(npc);
|
||||||
|
WorldGrid.removeObject(npc);
|
||||||
|
}
|
||||||
|
}
|
||||||
// Remove object from simulation
|
// Remove object from simulation
|
||||||
|
|
||||||
baneStone.removeFromCache();
|
baneStone.removeFromCache();
|
||||||
@@ -469,6 +542,9 @@ public final class Bane {
|
|||||||
return liveDate;
|
return liveDate;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setLiveDate_NEW(DateTime baneTime) {
|
||||||
|
|
||||||
|
}
|
||||||
public void setLiveDate(DateTime baneTime) {
|
public void setLiveDate(DateTime baneTime) {
|
||||||
|
|
||||||
if (DbManager.BaneQueries.SET_BANE_TIME(baneTime, this.getCity().getObjectUUID())) {
|
if (DbManager.BaneQueries.SET_BANE_TIME(baneTime, this.getCity().getObjectUUID())) {
|
||||||
@@ -644,4 +720,63 @@ public final class Bane {
|
|||||||
return cityUUID;
|
return cityUUID;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void applyZergBuffs(){
|
||||||
|
City city = this.getCity();
|
||||||
|
if(city == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
city.onEnter();
|
||||||
|
|
||||||
|
ArrayList<Integer> attackers = new ArrayList<>();
|
||||||
|
ArrayList<Integer> defenders = new ArrayList<>();
|
||||||
|
Guild attackNation = this.getOwner().getGuild().getNation();
|
||||||
|
Guild defendNation = this.getCity().getGuild().getNation();
|
||||||
|
HashSet<AbstractWorldObject> inSiegeRange = WorldGrid.getObjectsInRangePartial(city.getTOL().loc,1750f,1);
|
||||||
|
for(AbstractWorldObject obj : inSiegeRange){
|
||||||
|
int uuid = obj.getObjectUUID();
|
||||||
|
PlayerCharacter player = PlayerManager.getPlayerCharacter(uuid);
|
||||||
|
if(player == null)
|
||||||
|
continue;
|
||||||
|
Guild playerNation = player.guild.getNation();
|
||||||
|
//separate the players into categories
|
||||||
|
if(playerNation.equals(defendNation))
|
||||||
|
defenders.add(uuid);
|
||||||
|
else if(playerNation.equals(attackNation))
|
||||||
|
attackers.add(uuid);
|
||||||
|
else
|
||||||
|
MovementManager.translocate(player,Vector3fImmutable.getRandomPointOnCircle(ZoneManager.getZoneByUUID(656).getLoc(),30f),Regions.GetRegionForTeleport(ZoneManager.getZoneByUUID(656).getLoc()));
|
||||||
|
}
|
||||||
|
int attackerSize = 0;
|
||||||
|
int defenderSize = 0;
|
||||||
|
for(int uuid : city.baneAttendees.keySet()){
|
||||||
|
PlayerCharacter player = PlayerManager.getPlayerCharacter(uuid);
|
||||||
|
if(player == null)
|
||||||
|
continue;
|
||||||
|
if(player.guild.getNation().equals(defendNation))
|
||||||
|
defenderSize += 1;
|
||||||
|
else if(player.guild.getNation().equals(attackNation))
|
||||||
|
attackerSize += 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
//apply zerg mechanic for attackers
|
||||||
|
float attackerMultiplier = ZergManager.getCurrentMultiplier(attackerSize,this.capSize);
|
||||||
|
float defenderMultiplier = ZergManager.getCurrentMultiplier(defenderSize,this.capSize);
|
||||||
|
for(int uuid : attackers){
|
||||||
|
PlayerCharacter player = PlayerManager.getPlayerCharacter(uuid);
|
||||||
|
if(inSiegeRange.contains(player)) //player is still physically here, needs updated multiplier
|
||||||
|
player.ZergMultiplier = attackerMultiplier;
|
||||||
|
else
|
||||||
|
player.ZergMultiplier = 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(int uuid : defenders){
|
||||||
|
PlayerCharacter player = PlayerManager.getPlayerCharacter(uuid);
|
||||||
|
if(inSiegeRange.contains(player)) //player is still physically here, needs updated multiplier
|
||||||
|
player.ZergMultiplier = defenderMultiplier;
|
||||||
|
else
|
||||||
|
player.ZergMultiplier = 1.0f;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -17,9 +17,7 @@ import engine.InterestManagement.WorldGrid;
|
|||||||
import engine.db.archive.CityRecord;
|
import engine.db.archive.CityRecord;
|
||||||
import engine.db.archive.DataWarehouse;
|
import engine.db.archive.DataWarehouse;
|
||||||
import engine.db.archive.MineRecord;
|
import engine.db.archive.MineRecord;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.gameManager.ZoneManager;
|
|
||||||
import engine.job.JobContainer;
|
import engine.job.JobContainer;
|
||||||
import engine.job.JobScheduler;
|
import engine.job.JobScheduler;
|
||||||
import engine.jobs.DoorCloseJob;
|
import engine.jobs.DoorCloseJob;
|
||||||
@@ -968,9 +966,9 @@ public class Building extends AbstractWorldObject {
|
|||||||
if (this.ownerUUID == 0)
|
if (this.ownerUUID == 0)
|
||||||
return null;
|
return null;
|
||||||
if (this.ownerIsNPC)
|
if (this.ownerIsNPC)
|
||||||
return NPC.getFromCache(this.ownerUUID);
|
return NPCManager.getFromCache(this.ownerUUID);
|
||||||
|
|
||||||
return PlayerCharacter.getFromCache(this.ownerUUID);
|
return PlayerManager.getFromCache(this.ownerUUID);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -1091,11 +1089,11 @@ public class Building extends AbstractWorldObject {
|
|||||||
//LOad Owners in Cache so we do not have to continuely look in the db for owner.
|
//LOad Owners in Cache so we do not have to continuely look in the db for owner.
|
||||||
|
|
||||||
if (this.ownerIsNPC) {
|
if (this.ownerIsNPC) {
|
||||||
if (NPC.getNPC(this.ownerUUID) == null)
|
if (NPCManager.getNPC(this.ownerUUID) == null)
|
||||||
Logger.info("Building UID " + this.getObjectUUID() + " Failed to Load NPC Owner with ID " + this.ownerUUID + " Location " + this.getLoc().toString());
|
Logger.info("Building UID " + this.getObjectUUID() + " Failed to Load NPC Owner with ID " + this.ownerUUID + " Location " + this.getLoc().toString());
|
||||||
|
|
||||||
} else if (this.ownerUUID != 0) {
|
} else if (this.ownerUUID != 0) {
|
||||||
if (PlayerCharacter.getPlayerCharacter(this.ownerUUID) == null) {
|
if (PlayerManager.getPlayerCharacter(this.ownerUUID) == null) {
|
||||||
Logger.info("Building UID " + this.getObjectUUID() + " Failed to Load Player Owner with ID " + this.ownerUUID + " Location " + this.getLoc().toString());
|
Logger.info("Building UID " + this.getObjectUUID() + " Failed to Load Player Owner with ID " + this.ownerUUID + " Location " + this.getLoc().toString());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,10 +12,7 @@ package engine.objects;
|
|||||||
import engine.Enum;
|
import engine.Enum;
|
||||||
import engine.Enum.GameObjectType;
|
import engine.Enum.GameObjectType;
|
||||||
import engine.Enum.ItemType;
|
import engine.Enum.ItemType;
|
||||||
import engine.gameManager.BuildingManager;
|
import engine.gameManager.*;
|
||||||
import engine.gameManager.ChatManager;
|
|
||||||
import engine.gameManager.ConfigManager;
|
|
||||||
import engine.gameManager.DbManager;
|
|
||||||
import engine.math.Vector3fImmutable;
|
import engine.math.Vector3fImmutable;
|
||||||
import engine.net.Dispatch;
|
import engine.net.Dispatch;
|
||||||
import engine.net.DispatchMessage;
|
import engine.net.DispatchMessage;
|
||||||
@@ -424,7 +421,7 @@ public class CharacterItemManager {
|
|||||||
public synchronized boolean tradeRequest(TradeRequestMsg msg) {
|
public synchronized boolean tradeRequest(TradeRequestMsg msg) {
|
||||||
|
|
||||||
PlayerCharacter source = (PlayerCharacter) this.getOwner();
|
PlayerCharacter source = (PlayerCharacter) this.getOwner();
|
||||||
PlayerCharacter target = PlayerCharacter.getFromCache(msg.getPlayerID());
|
PlayerCharacter target = PlayerManager.getFromCache(msg.getPlayerID());
|
||||||
Dispatch dispatch;
|
Dispatch dispatch;
|
||||||
|
|
||||||
if (!canTrade(source, target)) {
|
if (!canTrade(source, target)) {
|
||||||
@@ -450,7 +447,7 @@ public class CharacterItemManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public synchronized boolean invalidTradeRequest(InvalidTradeRequestMsg msg) {
|
public synchronized boolean invalidTradeRequest(InvalidTradeRequestMsg msg) {
|
||||||
PlayerCharacter requester = PlayerCharacter.getFromCache(msg.getRequesterID());
|
PlayerCharacter requester = PlayerManager.getFromCache(msg.getRequesterID());
|
||||||
Dispatch dispatch;
|
Dispatch dispatch;
|
||||||
|
|
||||||
dispatch = Dispatch.borrow(requester, msg);
|
dispatch = Dispatch.borrow(requester, msg);
|
||||||
@@ -495,7 +492,7 @@ public class CharacterItemManager {
|
|||||||
public synchronized boolean acceptTradeRequest(AcceptTradeRequestMsg msg) {
|
public synchronized boolean acceptTradeRequest(AcceptTradeRequestMsg msg) {
|
||||||
|
|
||||||
PlayerCharacter source = (PlayerCharacter) this.getOwner();
|
PlayerCharacter source = (PlayerCharacter) this.getOwner();
|
||||||
PlayerCharacter target = PlayerCharacter.getFromCache(msg.getTargetID());
|
PlayerCharacter target = PlayerManager.getFromCache(msg.getTargetID());
|
||||||
|
|
||||||
Dispatch dispatch;
|
Dispatch dispatch;
|
||||||
|
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user