Arcturus-Community/src/main/java/com/eu/habbo/habbohotel/users/HabboInfo.java
2022-03-19 19:34:21 +00:00

573 lines
18 KiB
Java

package com.eu.habbo.habbohotel.users;
import com.eu.habbo.Emulator;
import com.eu.habbo.habbohotel.catalog.CatalogItem;
import com.eu.habbo.habbohotel.games.Game;
import com.eu.habbo.habbohotel.games.GamePlayer;
import com.eu.habbo.habbohotel.messenger.MessengerCategory;
import com.eu.habbo.habbohotel.navigation.NavigatorSavedSearch;
import com.eu.habbo.habbohotel.permissions.Rank;
import com.eu.habbo.habbohotel.pets.PetTasks;
import com.eu.habbo.habbohotel.pets.RideablePet;
import com.eu.habbo.habbohotel.rooms.Room;
import com.eu.habbo.habbohotel.rooms.RoomTile;
import com.eu.habbo.habbohotel.rooms.RoomUnit;
import com.eu.habbo.messages.outgoing.rooms.users.RoomUserStatusComposer;
import gnu.trove.map.hash.TIntIntHashMap;
import gnu.trove.procedure.TIntIntProcedure;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
public class HabboInfo implements Runnable {
private static final Logger LOGGER = LoggerFactory.getLogger(HabboInfo.class);
public boolean firstVisit = false;
private String username;
private String motto;
private String look;
private HabboGender gender;
private String mail;
private String sso;
private String ipRegister;
private String ipLogin;
private int id;
private int accountCreated;
private Rank rank;
private int credits;
private int lastOnline;
private int homeRoom;
private boolean online;
private int loadingRoom;
private Room currentRoom;
private int roomQueueId;
private RideablePet riding;
private Class<? extends Game> currentGame;
private TIntIntHashMap currencies;
private GamePlayer gamePlayer;
private int photoRoomId;
private int photoTimestamp;
private String photoURL;
private String photoJSON;
private int webPublishTimestamp;
private String machineID;
private List<NavigatorSavedSearch> savedSearches = new ArrayList<>();
private List<MessengerCategory> messengerCategories = new ArrayList<>();
public HabboInfo(ResultSet set) {
try {
this.id = set.getInt("id");
this.username = set.getString("username");
this.motto = set.getString("motto");
this.look = set.getString("look");
this.gender = HabboGender.valueOf(set.getString("gender"));
this.mail = set.getString("mail");
this.sso = set.getString("auth_ticket");
this.ipRegister = set.getString("ip_register");
this.ipLogin = set.getString("ip_current");
this.rank = Emulator.getGameEnvironment().getPermissionsManager().getRank(set.getInt("rank"));
if (this.rank == null) {
LOGGER.error("No existing rank found with id " + set.getInt("rank") + ". Make sure an entry in the permissions table exists.");
LOGGER.warn(this.username + " has an invalid rank with id " + set.getInt("rank") + ". Make sure an entry in the permissions table exists.");
this.rank = Emulator.getGameEnvironment().getPermissionsManager().getRank(1);
}
this.accountCreated = set.getInt("account_created");
this.credits = set.getInt("credits");
this.homeRoom = set.getInt("home_room");
this.lastOnline = set.getInt("last_online");
this.machineID = set.getString("machine_id");
this.online = false;
this.currentRoom = null;
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
this.loadCurrencies();
this.loadSavedSearches();
this.loadMessengerCategories();
}
private void loadCurrencies() {
this.currencies = new TIntIntHashMap();
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("SELECT * FROM users_currency WHERE user_id = ?")) {
statement.setInt(1, this.id);
try (ResultSet set = statement.executeQuery()) {
while (set.next()) {
this.currencies.put(set.getInt("type"), set.getInt("amount"));
}
}
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
private void saveCurrencies() {
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO users_currency (user_id, type, amount) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE amount = ?")) {
this.currencies.forEachEntry(new TIntIntProcedure() {
@Override
public boolean execute(int a, int b) {
try {
statement.setInt(1, HabboInfo.this.getId());
statement.setInt(2, a);
statement.setInt(3, b);
statement.setInt(4, b);
statement.addBatch();
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
return true;
}
});
statement.executeBatch();
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
private void loadSavedSearches() {
this.savedSearches = new ArrayList<>();
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("SELECT * FROM users_saved_searches WHERE user_id = ?")) {
statement.setInt(1, this.id);
try (ResultSet set = statement.executeQuery()) {
while (set.next()) {
this.savedSearches.add(new NavigatorSavedSearch(set.getString("search_code"), set.getString("filter"), set.getInt("id")));
}
}
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
public void addSavedSearch(NavigatorSavedSearch search) {
this.savedSearches.add(search);
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO users_saved_searches (search_code, filter, user_id) VALUES (?, ?, ?)", Statement.RETURN_GENERATED_KEYS)) {
statement.setString(1, search.getSearchCode());
statement.setString(2, search.getFilter());
statement.setInt(3, this.id);
int affectedRows = statement.executeUpdate();
if (affectedRows == 0) {
throw new SQLException("Creating saved search failed, no rows affected.");
}
try (ResultSet generatedKeys = statement.getGeneratedKeys()) {
if (generatedKeys.next()) {
search.setId(generatedKeys.getInt(1));
} else {
throw new SQLException("Creating saved search failed, no ID found.");
}
}
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
public void deleteSavedSearch(NavigatorSavedSearch search) {
this.savedSearches.remove(search);
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("DELETE FROM users_saved_searches WHERE id = ?")) {
statement.setInt(1, search.getId());
statement.execute();
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
private void loadMessengerCategories() {
this.messengerCategories = new ArrayList<>();
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("SELECT * FROM messenger_categories WHERE user_id = ?")) {
statement.setInt(1, this.id);
try (ResultSet set = statement.executeQuery()) {
while (set.next()) {
this.messengerCategories.add(new MessengerCategory(set.getString("name"), set.getInt("user_id"), set.getInt("id")));
}
}
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
public void addMessengerCategory(MessengerCategory category) {
this.messengerCategories.add(category);
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO messenger_categories (name, user_id) VALUES (?, ?)", Statement.RETURN_GENERATED_KEYS)) {
statement.setString(1, category.getName());
statement.setInt(2, this.id);
int affectedRows = statement.executeUpdate();
if (affectedRows == 0) {
throw new SQLException("Creating messenger category failed, no rows affected.");
}
try (ResultSet generatedKeys = statement.getGeneratedKeys()) {
if (generatedKeys.next()) {
category.setId(generatedKeys.getInt(1));
} else {
throw new SQLException("Creating messenger category failed, no ID found.");
}
}
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
public void deleteMessengerCategory(MessengerCategory category) {
this.messengerCategories.remove(category);
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("DELETE FROM messenger_categories WHERE id = ?")) {
statement.setInt(1, category.getId());
statement.execute();
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
public int getCurrencyAmount(int type) {
return this.currencies.get(type);
}
public TIntIntHashMap getCurrencies() {
return this.currencies;
}
public void addCurrencyAmount(int type, int amount) {
this.currencies.adjustOrPutValue(type, amount, amount);
this.run();
}
public void setCurrencyAmount(int type, int amount) {
this.currencies.put(type, amount);
this.run();
}
public int getId() {
return this.id;
}
public String getUsername() {
return this.username;
}
public void setUsername(String username) {
this.username = username;
}
public String getMotto() {
return this.motto;
}
public void setMotto(String motto) {
this.motto = motto;
}
public Rank getRank() {
return this.rank;
}
public void setRank(Rank rank) {
this.rank = rank;
}
public String getLook() {
return this.look;
}
public void setLook(String look) {
this.look = look;
}
public HabboGender getGender() {
return this.gender;
}
public void setGender(HabboGender gender) {
this.gender = gender;
}
public String getMail() {
return this.mail;
}
public void setMail(String mail) {
this.mail = mail;
}
public String getSso() {
return this.sso;
}
public void setSso(String sso) {
this.sso = sso;
}
public String getIpRegister() {
return this.ipRegister;
}
public void setIpRegister(String ipRegister) {
this.ipRegister = ipRegister;
}
public String getIpLogin() {
return this.ipLogin;
}
public void setIpLogin(String ipLogin) {
this.ipLogin = ipLogin;
}
public int getAccountCreated() {
return this.accountCreated;
}
public void setAccountCreated(int accountCreated) {
this.accountCreated = accountCreated;
}
public boolean canBuy(CatalogItem item) {
return this.credits >= item.getCredits() && this.getCurrencies().get(item.getPointsType()) >= item.getPoints();
}
public int getCredits() {
return this.credits;
}
public void setCredits(int credits) {
this.credits = credits;
this.run();
}
public void addCredits(int credits) {
this.credits += credits;
this.run();
}
public int getPixels() {
return this.getCurrencyAmount(0);
}
public void setPixels(int pixels) {
this.setCurrencyAmount(0, pixels);
this.run();
}
public void addPixels(int pixels) {
this.addCurrencyAmount(0, pixels);
this.run();
}
public int getLastOnline() {
return this.lastOnline;
}
public void setLastOnline(int lastOnline) {
this.lastOnline = lastOnline;
}
public int getHomeRoom() {
return this.homeRoom;
}
public void setHomeRoom(int homeRoom) {
this.homeRoom = homeRoom;
}
public boolean isOnline() {
return this.online;
}
public void setOnline(boolean value) {
this.online = value;
}
public int getLoadingRoom() {
return this.loadingRoom;
}
public void setLoadingRoom(int loadingRoom) {
this.loadingRoom = loadingRoom;
}
public Room getCurrentRoom() {
return this.currentRoom;
}
public void setCurrentRoom(Room room) {
this.currentRoom = room;
}
public int getRoomQueueId() {
return this.roomQueueId;
}
public void setRoomQueueId(int roomQueueId) {
this.roomQueueId = roomQueueId;
}
public RideablePet getRiding() {
return this.riding;
}
public void setRiding(RideablePet riding) {
this.riding = riding;
}
public void dismountPet() {
this.dismountPet(false);
}
public void dismountPet(boolean isRemoving) {
if (this.getRiding() == null)
return;
Habbo habbo = this.getCurrentRoom().getHabbo(this.getId());
if (habbo == null)
return;
RideablePet riding = this.getRiding();
riding.setRider(null);
riding.setTask(PetTasks.FREE);
this.setRiding(null);
Room room = this.getCurrentRoom();
if (room != null)
room.giveEffect(habbo, 0, -1);
RoomUnit roomUnit = habbo.getRoomUnit();
if (roomUnit == null)
return;
roomUnit.setZ(riding.getRoomUnit().getZ());
roomUnit.setPreviousLocationZ(riding.getRoomUnit().getZ());
roomUnit.stopWalking();
room.sendComposer(new RoomUserStatusComposer(roomUnit).compose());
List<RoomTile> availableTiles = isRemoving ? new ArrayList<>() : this.getCurrentRoom().getLayout().getWalkableTilesAround(roomUnit.getCurrentLocation());
RoomTile tile = availableTiles.isEmpty() ? roomUnit.getCurrentLocation() : availableTiles.get(0);
roomUnit.setGoalLocation(tile);
roomUnit.statusUpdate(true);
}
public Class<? extends Game> getCurrentGame() {
return this.currentGame;
}
public void setCurrentGame(Class<? extends Game> currentGame) {
this.currentGame = currentGame;
}
public boolean isInGame() {
return this.currentGame != null;
}
public synchronized GamePlayer getGamePlayer() {
return this.gamePlayer;
}
public synchronized void setGamePlayer(GamePlayer gamePlayer) {
this.gamePlayer = gamePlayer;
}
public int getPhotoRoomId() {
return this.photoRoomId;
}
public void setPhotoRoomId(int roomId) {
this.photoRoomId = roomId;
}
public int getPhotoTimestamp() {
return this.photoTimestamp;
}
public void setPhotoTimestamp(int photoTimestamp) {
this.photoTimestamp = photoTimestamp;
}
public String getPhotoURL() {
return this.photoURL;
}
public void setPhotoURL(String photoURL) {
this.photoURL = photoURL;
}
public String getPhotoJSON() {
return this.photoJSON;
}
public void setPhotoJSON(String photoJSON) {
this.photoJSON = photoJSON;
}
public int getWebPublishTimestamp() {
return this.webPublishTimestamp;
}
public void setWebPublishTimestamp(int webPublishTimestamp) {
this.webPublishTimestamp = webPublishTimestamp;
}
public String getMachineID() {
return this.machineID;
}
public void setMachineID(String machineID) {
this.machineID = machineID;
}
public List<NavigatorSavedSearch> getSavedSearches() {
return this.savedSearches;
}
public List<MessengerCategory> getMessengerCategories() { return this.messengerCategories; }
@Override
public void run() {
this.saveCurrencies();
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("UPDATE users SET motto = ?, online = ?, look = ?, gender = ?, credits = ?, last_login = ?, last_online = ?, home_room = ?, ip_current = ?, `rank` = ?, machine_id = ?, username = ? WHERE id = ?")) {
statement.setString(1, this.motto);
statement.setString(2, this.online ? "1" : "0");
statement.setString(3, this.look);
statement.setString(4, this.gender.name());
statement.setInt(5, this.credits);
statement.setInt(7, this.lastOnline);
statement.setInt(6, Emulator.getIntUnixTimestamp());
statement.setInt(8, this.homeRoom);
statement.setString(9, this.ipLogin);
statement.setInt(10, this.rank != null ? this.rank.getId() : 1);
statement.setString(11, this.machineID);
statement.setString(12, this.username);
statement.setInt(13, this.id);
statement.executeUpdate();
} catch (SQLException e) {
LOGGER.error("Caught SQL exception", e);
}
}
public int getBonusRarePoints() {
return this.getCurrencyAmount(Emulator.getConfig().getInt("hotelview.promotional.points.type"));
}
public HabboStats getHabboStats() {
Habbo habbo = Emulator.getGameEnvironment().getHabboManager().getHabbo(this.getId());
if (habbo != null) {
return habbo.getHabboStats();
}
return HabboStats.load(this);
}
}