Arcturus-Community/src/main/java/com/eu/habbo/habbohotel/users/Habbo.java
2020-06-03 02:30:32 +02:00

465 lines
15 KiB
Java

package com.eu.habbo.habbohotel.users;
import com.eu.habbo.Emulator;
import com.eu.habbo.habbohotel.achievements.AchievementManager;
import com.eu.habbo.habbohotel.bots.Bot;
import com.eu.habbo.habbohotel.gameclients.GameClient;
import com.eu.habbo.habbohotel.messenger.Messenger;
import com.eu.habbo.habbohotel.pets.Pet;
import com.eu.habbo.habbohotel.rooms.*;
import com.eu.habbo.habbohotel.users.inventory.BadgesComponent;
import com.eu.habbo.messages.outgoing.generic.alerts.*;
import com.eu.habbo.messages.outgoing.inventory.*;
import com.eu.habbo.messages.outgoing.rooms.FloodCounterComposer;
import com.eu.habbo.messages.outgoing.rooms.ForwardToRoomComposer;
import com.eu.habbo.messages.outgoing.rooms.users.*;
import com.eu.habbo.messages.outgoing.users.*;
import com.eu.habbo.plugin.events.users.UserCreditsEvent;
import com.eu.habbo.plugin.events.users.UserDisconnectEvent;
import com.eu.habbo.plugin.events.users.UserPointsEvent;
import gnu.trove.TIntCollection;
import gnu.trove.map.hash.THashMap;
import gnu.trove.set.hash.THashSet;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.net.InetSocketAddress;
import java.net.SocketAddress;
import java.sql.ResultSet;
import java.util.*;
import java.util.stream.Collectors;
public class Habbo implements Runnable {
private static final Logger LOGGER = LoggerFactory.getLogger(Habbo.class);
private final HabboInfo habboInfo;
private final HabboStats habboStats;
private final Messenger messenger;
private final HabboInventory habboInventory;
private GameClient client;
private RoomUnit roomUnit;
private volatile boolean update;
private volatile boolean disconnected = false;
private volatile boolean disconnecting = false;
public Habbo(ResultSet set) {
this.client = null;
this.habboInfo = new HabboInfo(set);
this.habboStats = HabboStats.load(this.habboInfo);
this.habboInventory = new HabboInventory(this);
this.messenger = new Messenger();
this.messenger.loadFriends(this);
this.messenger.loadFriendRequests(this);
this.roomUnit = new RoomUnit();
this.roomUnit.setRoomUnitType(RoomUnitType.USER);
this.update = false;
}
public boolean isOnline() {
return this.habboInfo.isOnline();
}
void isOnline(boolean value) {
this.habboInfo.setOnline(value);
this.update();
}
void update() {
this.update = true;
this.run();
}
void needsUpdate(boolean value) {
this.update = value;
}
boolean needsUpdate() {
return this.update;
}
public Messenger getMessenger() {
return this.messenger;
}
public HabboInfo getHabboInfo() {
return this.habboInfo;
}
public HabboStats getHabboStats() {
return this.habboStats;
}
public HabboInventory getInventory() {
return this.habboInventory;
}
public RoomUnit getRoomUnit() {
return this.roomUnit;
}
public void setRoomUnit(RoomUnit roomUnit) {
this.roomUnit = roomUnit;
}
public GameClient getClient() {
return this.client;
}
public void setClient(GameClient client) {
this.client = client;
}
public void connect() {
if (!Emulator.getConfig().getBoolean("networking.tcp.proxy") && this.client.getChannel().remoteAddress() != null) {
SocketAddress address = this.client.getChannel().remoteAddress();
if (address != null) this.habboInfo.setIpLogin(((InetSocketAddress) address).getAddress().getHostAddress());
}
this.habboInfo.setMachineID(this.client.getMachineId());
this.isOnline(true);
this.messenger.connectionChanged(this, true, false);
Emulator.getGameEnvironment().getRoomManager().loadRoomsForHabbo(this);
LOGGER.info("{} logged in from IP {}", this.habboInfo.getUsername(), this.habboInfo.getIpLogin());
}
public synchronized void disconnect() {
if (!Emulator.isShuttingDown) {
if (Emulator.getPluginManager().fireEvent(new UserDisconnectEvent(this)).isCancelled()) return;
}
if (this.disconnected || this.disconnecting)
return;
this.disconnecting = true;
try {
if (this.getHabboInfo().getCurrentRoom() != null) {
Emulator.getGameEnvironment().getRoomManager().leaveRoom(this, this.getHabboInfo().getCurrentRoom());
}
if (this.getHabboInfo().getRoomQueueId() > 0) {
Room room = Emulator.getGameEnvironment().getRoomManager().getRoom(this.getHabboInfo().getRoomQueueId());
if (room != null) {
room.removeFromQueue(this);
}
}
} catch (Exception e) {
LOGGER.error("Caught exception", e);
}
try {
Emulator.getGameEnvironment().getGuideManager().userLogsOut(this);
this.isOnline(false);
this.needsUpdate(true);
this.run();
this.getInventory().dispose();
this.messenger.connectionChanged(this, false, false);
this.messenger.dispose();
this.disconnected = true;
AchievementManager.saveAchievements(this);
this.habboStats.dispose();
} catch (Exception e) {
LOGGER.error("Caught exception", e);
return;
} finally {
Emulator.getGameEnvironment().getRoomManager().unloadRoomsForHabbo(this);
Emulator.getGameEnvironment().getHabboManager().removeHabbo(this);
}
LOGGER.info("{} disconnected.", this.habboInfo.getUsername());
this.client = null;
}
@Override
public void run() {
if (this.needsUpdate()) {
this.habboInfo.run();
this.needsUpdate(false);
}
}
public boolean hasPermission(String key) {
return this.hasPermission(key, false);
}
public boolean hasPermission(String key, boolean hasRoomRights) {
return Emulator.getGameEnvironment().getPermissionsManager().hasPermission(this, key, hasRoomRights);
}
public void giveCredits(int credits) {
if (credits == 0)
return;
UserCreditsEvent event = new UserCreditsEvent(this, credits);
if (Emulator.getPluginManager().fireEvent(event).isCancelled())
return;
this.getHabboInfo().addCredits(event.credits);
if (this.client != null) this.client.sendResponse(new UserCreditsComposer(this.client.getHabbo()));
}
public void givePixels(int pixels) {
if (pixels == 0)
return;
UserPointsEvent event = new UserPointsEvent(this, pixels, 0);
if (Emulator.getPluginManager().fireEvent(event).isCancelled())
return;
this.getHabboInfo().addPixels(event.points);
if (this.client != null) this.client.sendResponse(new UserCurrencyComposer(this.client.getHabbo()));
}
public void givePoints(int points) {
this.givePoints(Emulator.getConfig().getInt("seasonal.primary.type"), points);
}
public void givePoints(int type, int points) {
if (points == 0)
return;
UserPointsEvent event = new UserPointsEvent(this, points, type);
if (Emulator.getPluginManager().fireEvent(event).isCancelled())
return;
this.getHabboInfo().addCurrencyAmount(event.type, event.points);
if (this.client != null) this.client.sendResponse(new UserPointsComposer(this.client.getHabbo().getHabboInfo().getCurrencyAmount(type), event.points, event.type));
}
public void whisper(String message) {
this.whisper(message, this.habboStats.chatColor);
}
public void whisper(String message, RoomChatMessageBubbles bubble) {
if (this.getRoomUnit().isInRoom()) {
this.client.sendResponse(new RoomUserWhisperComposer(new RoomChatMessage(message, this.client.getHabbo().getRoomUnit(), bubble)));
}
}
public void talk(String message) {
this.talk(message, this.habboStats.chatColor);
}
public void talk(String message, RoomChatMessageBubbles bubble) {
if (this.getRoomUnit().isInRoom()) {
this.getHabboInfo().getCurrentRoom().sendComposer(new RoomUserTalkComposer(new RoomChatMessage(message, this.client.getHabbo().getRoomUnit(), bubble)).compose());
}
}
public void shout(String message) {
this.shout(message, this.habboStats.chatColor);
}
public void shout(String message, RoomChatMessageBubbles bubble) {
if (this.getRoomUnit().isInRoom()) {
this.getHabboInfo().getCurrentRoom().sendComposer(new RoomUserShoutComposer(new RoomChatMessage(message, this.client.getHabbo().getRoomUnit(), bubble)).compose());
}
}
public void alert(String message) {
if (Emulator.getConfig().getBoolean("hotel.alert.oldstyle")) {
this.client.sendResponse(new MessagesForYouComposer(new String[]{message}));
} else {
this.client.sendResponse(new GenericAlertComposer(message));
}
}
public void alert(String[] messages) {
this.client.sendResponse(new MessagesForYouComposer(messages));
}
public void alertWithUrl(String message, String url) {
this.client.sendResponse(new StaffAlertWithLinkComposer(message, url));
}
public void goToRoom(int id) {
this.client.sendResponse(new ForwardToRoomComposer(id));
}
public void addFurniture(HabboItem item) {
this.habboInventory.getItemsComponent().addItem(item);
this.client.sendResponse(new AddHabboItemComposer(item));
this.client.sendResponse(new InventoryRefreshComposer());
}
public void addFurniture(THashSet<HabboItem> items) {
this.habboInventory.getItemsComponent().addItems(items);
this.client.sendResponse(new AddHabboItemComposer(items));
this.client.sendResponse(new InventoryRefreshComposer());
}
public void removeFurniture(HabboItem item) {
this.habboInventory.getItemsComponent().removeHabboItem(item);
this.client.sendResponse(new RemoveHabboItemComposer(item.getId()));
}
public void addBot(Bot bot) {
this.habboInventory.getBotsComponent().addBot(bot);
this.client.sendResponse(new AddBotComposer(bot));
}
public void removeBot(Bot bot) {
this.habboInventory.getBotsComponent().removeBot(bot);
this.client.sendResponse(new RemoveBotComposer(bot));
}
public void deleteBot(Bot bot) {
this.removeBot(bot);
bot.getRoom().removeBot(bot);
Emulator.getGameEnvironment().getBotManager().deleteBot(bot);
}
public void addPet(Pet pet) {
this.habboInventory.getPetsComponent().addPet(pet);
this.client.sendResponse(new AddPetComposer(pet));
}
public void removePet(Pet pet) {
this.habboInventory.getPetsComponent().removePet(pet);
this.client.sendResponse(new RemovePetComposer(pet));
}
public boolean addBadge(String code) {
if (this.habboInventory.getBadgesComponent().getBadge(code) == null) {
HabboBadge badge = BadgesComponent.createBadge(code, this);
this.habboInventory.getBadgesComponent().addBadge(badge);
this.client.sendResponse(new AddUserBadgeComposer(badge));
this.client.sendResponse(new AddHabboItemComposer(badge.getId(), AddHabboItemComposer.AddHabboItemCategory.BADGE));
THashMap<String, String> keys = new THashMap<>();
keys.put("display", "BUBBLE");
keys.put("image", "${image.library.url}album1584/" + badge.getCode() + ".gif");
keys.put("message", Emulator.getTexts().getValue("commands.generic.cmd_badge.received"));
this.client.sendResponse(new BubbleAlertComposer(BubbleAlertKeys.RECEIVED_BADGE.key, keys));
return true;
}
return false;
}
public void deleteBadge(HabboBadge badge) {
if (badge != null) {
this.habboInventory.getBadgesComponent().removeBadge(badge);
BadgesComponent.deleteBadge(this.getHabboInfo().getId(), badge.getCode());
this.client.sendResponse(new InventoryBadgesComposer(this));
}
}
public void mute(int seconds, boolean isFlood) {
if (seconds <= 0) {
LOGGER.warn("Tried to mute user for {} seconds, which is invalid.", seconds);
return;
}
if (!this.hasPermission("acc_no_mute")) {
int remaining = this.habboStats.addMuteTime(seconds);
this.client.sendResponse(new FloodCounterComposer(remaining));
this.client.sendResponse(new MutedWhisperComposer(remaining));
Room room = this.client.getHabbo().getHabboInfo().getCurrentRoom();
if (room != null && !isFlood) {
room.sendComposer(new RoomUserIgnoredComposer(this, RoomUserIgnoredComposer.MUTED).compose());
}
}
}
public void unMute() {
this.habboStats.unMute();
this.client.sendResponse(new FloodCounterComposer(3));
Room room = this.client.getHabbo().getHabboInfo().getCurrentRoom();
if (room != null) {
room.sendComposer(new RoomUserIgnoredComposer(this, RoomUserIgnoredComposer.UNIGNORED).compose());
}
}
public int noobStatus() {
return 1;
}
public void clearCaches() {
int timestamp = Emulator.getIntUnixTimestamp();
THashMap<Integer, List<Integer>> newLog = new THashMap<>();
for (Map.Entry<Integer, List<Integer>> ltdLog : this.habboStats.ltdPurchaseLog.entrySet()) {
for (Integer time : ltdLog.getValue()) {
if (time > timestamp) {
if (!newLog.containsKey(ltdLog.getKey())) {
newLog.put(ltdLog.getKey(), new ArrayList<>());
}
newLog.get(ltdLog.getKey()).add(time);
}
}
}
this.habboStats.ltdPurchaseLog = newLog;
}
public void respect(Habbo target) {
if (target != null && target != this.client.getHabbo())
{
target.getHabboStats().respectPointsReceived++;
this.client.getHabbo().getHabboStats().respectPointsGiven++;
this.client.getHabbo().getHabboStats().respectPointsToGive--;
this.client.getHabbo().getHabboInfo().getCurrentRoom().sendComposer(new RoomUserRespectComposer(target).compose());
this.client.getHabbo().getHabboInfo().getCurrentRoom().sendComposer(new RoomUserActionComposer(this.client.getHabbo().getRoomUnit(), RoomUserAction.THUMB_UP).compose());
AchievementManager.progressAchievement(this.client.getHabbo(), Emulator.getGameEnvironment().getAchievementManager().getAchievement("RespectGiven"));
AchievementManager.progressAchievement(target, Emulator.getGameEnvironment().getAchievementManager().getAchievement("RespectEarned"));
this.client.getHabbo().getHabboInfo().getCurrentRoom().unIdle(this.client.getHabbo());
}
}
public Set<Integer> getForbiddenClothing() {
TIntCollection clothingIDs = this.getInventory().getWardrobeComponent().getClothing();
return Emulator.getGameEnvironment().getCatalogManager().clothing.values().stream()
.filter(c -> !clothingIDs.contains(c.id))
.map(c -> c.setId)
.flatMap(c -> Arrays.stream(c).boxed())
.collect(Collectors.toSet());
}
}