Files
Server/src/engine/objects/Account.java
T

393 lines
13 KiB
Java
Raw Normal View History

2022-04-30 09:41:17 -04:00
// • ▌ ▄ ·. ▄▄▄· ▄▄ • ▪ ▄▄· ▄▄▄▄· ▄▄▄· ▐▄▄▄ ▄▄▄ .
// ·██ ▐███▪▐█ ▀█ ▐█ ▀ ▪██ ▐█ ▌▪▐█ ▀█▪▐█ ▀█ •█▌ ▐█▐▌·
// ▐█ ▌▐▌▐█·▄█▀▀█ ▄█ ▀█▄▐█·██ ▄▄▐█▀▀█▄▄█▀▀█ ▐█▐ ▐▌▐▀▀▀
// ██ ██▌▐█▌▐█ ▪▐▌▐█▄▪▐█▐█▌▐███▌██▄▪▐█▐█ ▪▐▌██▐ █▌▐█▄▄▌
// ▀▀ █▪▀▀▀ ▀ ▀ ·▀▀▀▀ ▀▀▀·▀▀▀ ·▀▀▀▀ ▀ ▀ ▀▀ █▪ ▀▀▀
// Magicbane Emulator Project © 2013 - 2022
// www.magicbane.com
package engine.objects;
import engine.gameManager.ConfigManager;
import engine.gameManager.DbManager;
2024-03-24 09:56:41 -04:00
import engine.gameManager.NPCManager;
2022-04-30 09:41:17 -04:00
import engine.gameManager.SessionManager;
import engine.mbEnums;
import engine.mbEnums.DispatchChannel;
import engine.mbEnums.ItemContainerType;
2022-04-30 09:41:17 -04:00
import engine.net.Dispatch;
import engine.net.DispatchMessage;
import engine.net.client.ClientConnection;
2024-03-25 11:41:16 -04:00
import engine.net.client.handlers.ItemFromVaultMsgHandler;
import engine.net.client.handlers.ItemToVaultMsgHandler;
2022-04-30 09:41:17 -04:00
import engine.net.client.msg.*;
import engine.util.ByteUtils;
import org.pmw.tinylog.Logger;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.concurrent.ConcurrentHashMap;
public class Account extends AbstractGameObject {
2023-07-15 09:23:48 -04:00
public static ConcurrentHashMap<String, Integer> AccountsMap = new ConcurrentHashMap<>();
private final String uname;
public String discordAccount;
public HashMap<Integer, PlayerCharacter> characterMap = new HashMap<>();
public Item vaultGold = null;
public long lastPasswordCheck = 0;
public mbEnums.AccountStatus status;
2023-07-15 09:23:48 -04:00
private String passwd;
private int lastCharIDUsed;
private String salt;
private byte loginAttempts = 0;
private long lastLoginFailure = System.currentTimeMillis();
private ArrayList<Item> vault = new ArrayList<>();
public Account(ResultSet resultSet) throws SQLException {
super(resultSet);
this.uname = resultSet.getString("acct_uname");
this.passwd = resultSet.getString("acct_passwd");
this.lastCharIDUsed = resultSet.getInt("acct_lastCharUID");
this.salt = resultSet.getString("acct_salt");
this.discordAccount = resultSet.getString("discordAccount");
this.status = mbEnums.AccountStatus.valueOf(resultSet.getString("status"));
2023-07-15 09:23:48 -04:00
}
public ArrayList<Item> getVault() {
return vault;
}
public String getUname() {
return uname;
}
public String getPasswd() {
return passwd;
}
public String getSalt() {
return salt;
}
public int getLastCharIDUsed() {
return lastCharIDUsed;
}
public void setLastCharIDUsed(int lastCharIDUsed) {
this.lastCharIDUsed = lastCharIDUsed;
}
public byte getLoginAttempts() {
return loginAttempts;
}
public long getLastLoginFailure() {
return this.lastLoginFailure;
}
public void setLastLoginFailure() {
this.lastLoginFailure = System.currentTimeMillis();
}
public void setLastCharacter(int uuid) {
this.lastCharIDUsed = uuid;
// this.updateDatabase();
}
public void incrementLoginAttempts() {
++this.loginAttempts;
this.setLastLoginFailure();
}
public void resetLoginAttempts() {
this.loginAttempts = 0;
}
/*
* on successfully matching the password, this method additionally calls to
* associateIpToAccount for IPAddress tracking. dokks
*/
public boolean passIsValid(String pw, String ip, String machineID) throws IllegalArgumentException {
boolean result = false;
// see if it was entered in plain text first, if the plain text matches,
// hash it and save to the database.
try {
pw = ByteUtils.byteArrayToSafeStringHex(MessageDigest
.getInstance("md5").digest(pw.getBytes("UTF-8")))
+ salt;
pw = ByteUtils.byteArrayToSafeStringHex(MessageDigest
.getInstance("md5").digest(pw.getBytes()));
result = this.passwd.equals(pw);
} catch (NoSuchAlgorithmException | UnsupportedEncodingException e) {
Logger.error(e.toString());
}
if (result) {
// TODO: should use an executor here so that we can
// fire and forget this update.
// this is a valid user, so let's also update the
// database with login time and IP.
if ((ip == null) || (ip.length() == 0)) {
throw new IllegalArgumentException();
}
}
return result;
}
public ClientConnection getClientConnection() {
return SessionManager.getClientConnection(this);
}
public PlayerCharacter getPlayerCharacter() {
return SessionManager.getPlayerCharacter(this);
}
@Override
public void updateDatabase() {
DbManager.AccountQueries.updateDatabase(this);
}
//this should be called to handle any after load functions.
public void runAfterLoad() {
try {
if (ConfigManager.serverType.equals(mbEnums.ServerType.LOGINSERVER)) {
2023-07-15 09:23:48 -04:00
ArrayList<PlayerCharacter> playerList = DbManager.PlayerCharacterQueries.GET_CHARACTERS_FOR_ACCOUNT(this.getObjectUUID());
for (PlayerCharacter player : playerList) {
PlayerCharacter.initializePlayer(player);
this.characterMap.putIfAbsent(player.getObjectUUID(), player);
}
playerList.clear();
}
if (ConfigManager.serverType.equals(mbEnums.ServerType.WORLDSERVER)) {
2023-07-15 09:23:48 -04:00
this.vault = DbManager.ItemQueries.GET_ITEMS_FOR_ACCOUNT(this.getObjectUUID());
for (Item item : this.vault) {
if (item.template.item_type.equals(mbEnums.ItemType.GOLD)) {
2023-07-15 09:23:48 -04:00
this.vaultGold = item;
}
}
if (this.vaultGold == null) {
2024-03-28 05:34:50 -04:00
this.vaultGold = Item.newGoldItem(this.getObjectUUID(), ItemContainerType.VAULT);
2023-07-15 09:23:48 -04:00
if (this.vaultGold != null)
this.vault.add(this.vaultGold);
}
}
} catch (Exception e) {
Logger.error(e);
}
}
2024-03-24 10:12:16 -04:00
public synchronized void transferItemFromInventoryToVault(ItemToVaultMsg msg, ClientConnection origin) {
2023-07-15 09:23:48 -04:00
PlayerCharacter player = origin.getPlayerCharacter();
Dispatch dispatch;
if (player == null)
return;
2024-03-24 09:56:41 -04:00
if (!NPCManager.NPCVaultBankRangeCheck(player, origin, "vault")) {
2024-03-25 11:41:16 -04:00
ItemToVaultMsgHandler.forceTransferFromVaultToInventory(msg, origin, "You are out of range of the vault.");
2023-07-15 09:23:48 -04:00
return;
}
int uuid = msg.getUUID();
Item item = Item.getFromCache(uuid);
if (item == null) {
2024-03-25 11:41:16 -04:00
ItemToVaultMsgHandler.forceTransferFromVaultToInventory(msg, origin, "Can't find the item.");
2023-07-15 09:23:48 -04:00
return;
}
//dupe check
2024-03-18 10:01:29 -04:00
if (!item.validForInventory(origin, player, player.charItemManager))
2023-07-15 09:23:48 -04:00
return;
2022-04-30 09:41:17 -04:00
if (item.containerType == mbEnums.ItemContainerType.INVENTORY && player.charItemManager.isVaultOpen()) {
2024-03-18 10:01:29 -04:00
if (!player.charItemManager.hasRoomVault(item.template.item_wt)) {
2024-03-25 11:41:16 -04:00
ItemToVaultMsgHandler.forceTransferFromVaultToInventory(msg, origin, "There is no room in your vault.");
2023-07-15 09:23:48 -04:00
return;
}
2022-04-30 09:41:17 -04:00
2024-03-18 10:01:29 -04:00
if (player.charItemManager.moveItemToVault(item)) {
2023-07-15 09:23:48 -04:00
this.vault.add(item);
dispatch = Dispatch.borrow(player, msg);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
} else
2024-03-25 11:41:16 -04:00
ItemToVaultMsgHandler.forceTransferFromVaultToInventory(msg, origin, "Failed to transfer item.");
2023-07-15 09:23:48 -04:00
}
}
2022-04-30 09:41:17 -04:00
2024-03-24 10:12:16 -04:00
public synchronized void transferItemFromVaultToInventory(ItemFromVaultMsg msg, ClientConnection origin) {
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
PlayerCharacter player = origin.getPlayerCharacter();
Dispatch dispatch;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (player == null)
return;
2022-04-30 09:41:17 -04:00
2024-03-24 09:56:41 -04:00
if (!NPCManager.NPCVaultBankRangeCheck(player, origin, "vault")) {
2024-03-25 11:41:16 -04:00
ItemFromVaultMsgHandler.forceTransferFromInventoryToVault(msg, origin, "You are out of range of the vault.");
2023-07-15 09:23:48 -04:00
return;
}
2022-04-30 09:41:17 -04:00
2024-03-18 10:01:29 -04:00
CharacterItemManager itemManager = player.charItemManager;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager == null) {
2024-03-25 11:41:16 -04:00
ItemFromVaultMsgHandler.forceTransferFromInventoryToVault(msg, origin, "Can't find your item manager.");
2023-07-15 09:23:48 -04:00
return;
}
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
Item item = Item.getFromCache(msg.getUUID());
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (item == null) {
2024-03-25 11:41:16 -04:00
ItemFromVaultMsgHandler.forceTransferFromInventoryToVault(msg, origin, "Can't find the item.");
2023-07-15 09:23:48 -04:00
return;
}
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
//dupe check
if (!item.validForVault(origin, player, itemManager))
return;
2022-04-30 09:41:17 -04:00
if (item.containerType == mbEnums.ItemContainerType.VAULT && itemManager.isVaultOpen()) {
2024-03-03 15:06:44 -05:00
if (!itemManager.hasRoomInventory(item.template.item_wt)) {
2024-03-25 11:41:16 -04:00
ItemFromVaultMsgHandler.forceTransferFromInventoryToVault(msg, origin, "There is no room in your inventory.");
2023-07-15 09:23:48 -04:00
return;
}
if (itemManager.moveItemToInventory(item)) {
this.vault.remove(item);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
dispatch = Dispatch.borrow(player, msg);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
} else
2024-03-25 11:41:16 -04:00
ItemFromVaultMsgHandler.forceTransferFromInventoryToVault(msg, origin, "Failed to transfer item.");
2023-07-15 09:23:48 -04:00
}
}
2022-04-30 09:41:17 -04:00
public synchronized void transferGoldFromVaultToInventory(GoldFromVaultMsg msg, ClientConnection origin) {
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
PlayerCharacter player = origin.getPlayerCharacter();
Dispatch dispatch;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (player == null)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
Account account = player.getAccount();
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (account == null)
return;
2022-04-30 09:41:17 -04:00
2024-03-24 09:56:41 -04:00
if (!NPCManager.NPCVaultBankRangeCheck(player, origin, "vault"))
2023-07-15 09:23:48 -04:00
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
NPC npc = player.getLastNPCDialog();
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (npc == null)
return;
2022-04-30 09:41:17 -04:00
2024-03-18 10:01:29 -04:00
CharacterItemManager itemManager = player.charItemManager;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager == null)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager.isVaultOpen() == false)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager.moveGoldToInventory(itemManager.getGoldVault(), msg.getAmount()) == false)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
OpenVaultMsg open = new OpenVaultMsg(player, npc);
ShowVaultInventoryMsg show = new ShowVaultInventoryMsg(player, account, npc); // 37??
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
UpdateGoldMsg ugm = new UpdateGoldMsg(player);
ugm.configure();
dispatch = Dispatch.borrow(player, ugm);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
UpdateVaultMsg uvm = new UpdateVaultMsg(account);
dispatch = Dispatch.borrow(player, uvm);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
dispatch = Dispatch.borrow(player, open);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
dispatch = Dispatch.borrow(player, show);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
}
2022-04-30 09:41:17 -04:00
public synchronized void transferGoldFromInventoryToVault(GoldToVaultMsg msg, ClientConnection origin) {
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
PlayerCharacter player = origin.getPlayerCharacter();
Dispatch dispatch;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (player == null)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
Account account = player.getAccount();
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (account == null)
return;
2022-04-30 09:41:17 -04:00
2024-03-24 09:56:41 -04:00
if (!NPCManager.NPCVaultBankRangeCheck(player, origin, "vault"))
2023-07-15 09:23:48 -04:00
return;
2022-04-30 09:41:17 -04:00
2024-03-18 10:01:29 -04:00
CharacterItemManager itemManager = player.charItemManager;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager == null)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
NPC npc = player.getLastNPCDialog();
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (npc == null)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
// Cannot have bank and vault open concurrently
// Dupe prevention
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager.isVaultOpen() == false)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
// Something went horribly wrong. Should be log this?
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
if (itemManager.moveGoldToVault(itemManager.getGoldInventory(), msg.getAmount()) == false)
return;
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
UpdateGoldMsg ugm = new UpdateGoldMsg(player);
ugm.configure();
dispatch = Dispatch.borrow(player, ugm);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
UpdateVaultMsg uvm = new UpdateVaultMsg(account);
dispatch = Dispatch.borrow(player, uvm);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
OpenVaultMsg open = new OpenVaultMsg(player, npc);
dispatch = Dispatch.borrow(player, open);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
//
//
ShowVaultInventoryMsg show = new ShowVaultInventoryMsg(player, account, npc); // 37??
dispatch = Dispatch.borrow(player, show);
DispatchMessage.dispatchMsgDispatch(dispatch, DispatchChannel.SECONDARY);
2022-04-30 09:41:17 -04:00
2023-07-15 09:23:48 -04:00
}
2022-04-30 09:41:17 -04:00
}