mirror of
https://git.krews.org/morningstar/Arcturus-Community.git
synced 2024-10-24 19:53:04 +02:00
460 lines
15 KiB
Java
460 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 (!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());
|
|
}
|
|
}
|