Arcturus-Community/src/main/java/com/eu/habbo/habbohotel/wired/WiredHandler.java

524 lines
21 KiB
Java
Raw Normal View History

2018-07-06 15:30:00 +02:00
package com.eu.habbo.habbohotel.wired;
import com.eu.habbo.Emulator;
import com.eu.habbo.habbohotel.catalog.CatalogItem;
import com.eu.habbo.habbohotel.items.Item;
import com.eu.habbo.habbohotel.items.interactions.InteractionWiredCondition;
import com.eu.habbo.habbohotel.items.interactions.InteractionWiredEffect;
import com.eu.habbo.habbohotel.items.interactions.InteractionWiredExtra;
import com.eu.habbo.habbohotel.items.interactions.InteractionWiredTrigger;
import com.eu.habbo.habbohotel.items.interactions.wired.WiredTriggerReset;
import com.eu.habbo.habbohotel.items.interactions.wired.effects.WiredEffectGiveReward;
2019-03-18 02:22:00 +01:00
import com.eu.habbo.habbohotel.items.interactions.wired.effects.WiredEffectTriggerStacks;
2018-07-06 15:30:00 +02:00
import com.eu.habbo.habbohotel.items.interactions.wired.extra.WiredExtraRandom;
import com.eu.habbo.habbohotel.items.interactions.wired.extra.WiredExtraUnseen;
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.habbohotel.users.Habbo;
import com.eu.habbo.habbohotel.users.HabboBadge;
import com.eu.habbo.habbohotel.users.HabboItem;
import com.eu.habbo.messages.outgoing.catalog.PurchaseOKComposer;
2019-03-18 02:22:00 +01:00
import com.eu.habbo.messages.outgoing.wired.WiredRewardAlertComposer;
2018-07-06 15:30:00 +02:00
import com.eu.habbo.messages.outgoing.inventory.AddHabboItemComposer;
import com.eu.habbo.messages.outgoing.inventory.InventoryRefreshComposer;
import com.eu.habbo.messages.outgoing.users.AddUserBadgeComposer;
import com.eu.habbo.plugin.events.furniture.wired.WiredConditionFailedEvent;
import com.eu.habbo.plugin.events.furniture.wired.WiredStackExecutedEvent;
import com.eu.habbo.plugin.events.furniture.wired.WiredStackTriggeredEvent;
import com.eu.habbo.plugin.events.users.UserWiredRewardReceived;
import gnu.trove.set.hash.THashSet;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class WiredHandler
{
//Configuration. Loaded from database & updated accordingly.
public static int MAXIMUM_FURNI_SELECTION = 5;
public static int TELEPORT_DELAY = 500;
public static boolean handle(WiredTriggerType triggerType, RoomUnit roomUnit, Room room, Object[] stuff)
{
2019-03-18 02:22:00 +01:00
if (triggerType == WiredTriggerType.CUSTOM) return false;
2018-07-06 15:30:00 +02:00
boolean talked = false;
2018-12-22 11:39:00 +01:00
if (!Emulator.isReady)
return false;
2018-07-06 15:30:00 +02:00
if (room == null)
return false;
if(!room.isLoaded())
return false;
if(room.getRoomSpecialTypes() == null)
return false;
THashSet<InteractionWiredTrigger> triggers = room.getRoomSpecialTypes().getTriggers(triggerType);
if(triggers == null || triggers.isEmpty())
return false;
List<RoomTile> triggeredTiles = new ArrayList<>();
for(InteractionWiredTrigger trigger : triggers)
{
RoomTile tile = room.getLayout().getTile(trigger.getX(), trigger.getY());
if (triggeredTiles.contains(tile))
continue;
if(handle(trigger, roomUnit, room, stuff))
{
if(triggerType.equals(WiredTriggerType.SAY_SOMETHING))
talked = true;
triggeredTiles.add(tile);
}
}
return talked;
}
2019-03-18 02:22:00 +01:00
public static boolean handleCustomTrigger(Class<? extends InteractionWiredTrigger> triggerType, RoomUnit roomUnit, Room room, Object[] stuff)
{
boolean talked = false;
if (!Emulator.isReady)
return false;
if (room == null)
return false;
if(!room.isLoaded())
return false;
if(room.getRoomSpecialTypes() == null)
return false;
THashSet<InteractionWiredTrigger> triggers = room.getRoomSpecialTypes().getTriggers(WiredTriggerType.CUSTOM);
if(triggers == null || triggers.isEmpty())
return false;
List<RoomTile> triggeredTiles = new ArrayList<>();
for(InteractionWiredTrigger trigger : triggers)
{
if (trigger.getClass() != triggerType) continue;
RoomTile tile = room.getLayout().getTile(trigger.getX(), trigger.getY());
if (triggeredTiles.contains(tile))
continue;
if(handle(trigger, roomUnit, room, stuff))
{
triggeredTiles.add(tile);
}
}
return talked;
}
2018-07-06 15:30:00 +02:00
public static boolean handle(InteractionWiredTrigger trigger, final RoomUnit roomUnit, final Room room, final Object[] stuff)
{
2018-07-08 23:32:00 +02:00
long millis = System.currentTimeMillis();
2018-12-22 11:39:00 +01:00
if(Emulator.isReady && trigger.canExecute(millis) && trigger.execute(roomUnit, room, stuff))
2018-07-06 15:30:00 +02:00
{
2018-12-22 11:39:00 +01:00
trigger.setCooldown(millis);
2018-07-06 15:30:00 +02:00
trigger.activateBox(room);
THashSet<InteractionWiredCondition> conditions = room.getRoomSpecialTypes().getConditions(trigger.getX(), trigger.getY());
THashSet<InteractionWiredEffect> effects = room.getRoomSpecialTypes().getEffects(trigger.getX(), trigger.getY());
if(Emulator.getPluginManager().fireEvent(new WiredStackTriggeredEvent(room, roomUnit, trigger, effects, conditions)).isCancelled())
return false;
2018-12-22 11:39:00 +01:00
if (!conditions.isEmpty())
2018-07-06 15:30:00 +02:00
{
2018-12-22 11:39:00 +01:00
ArrayList<WiredConditionType> matchedConditions = new ArrayList<>(conditions.size());
for (InteractionWiredCondition searchMatched : conditions)
2018-07-06 15:30:00 +02:00
{
2018-12-22 11:39:00 +01:00
if (!matchedConditions.contains(searchMatched.getType()) && searchMatched.operator() == WiredConditionOperator.OR && searchMatched.execute(roomUnit, room, stuff))
{
matchedConditions.add(searchMatched.getType());
}
2018-07-06 15:30:00 +02:00
}
2018-12-22 11:39:00 +01:00
for (InteractionWiredCondition condition : conditions)
2018-07-06 15:30:00 +02:00
{
2018-12-22 11:39:00 +01:00
if ((condition.operator() == WiredConditionOperator.OR && matchedConditions.contains(condition.getType())) ||
(condition.operator() == WiredConditionOperator.AND && condition.execute(roomUnit, room, stuff)))
{
condition.activateBox(room);
}
else
{
if (!Emulator.getPluginManager().fireEvent(new WiredConditionFailedEvent(room, roomUnit, trigger, condition)).isCancelled())
return false;
}
2018-07-06 15:30:00 +02:00
}
}
boolean hasExtraRandom = room.getRoomSpecialTypes().hasExtraType(trigger.getX(), trigger.getY(), WiredExtraRandom.class);
boolean hasExtraUnseen = room.getRoomSpecialTypes().hasExtraType(trigger.getX(), trigger.getY(), WiredExtraUnseen.class);
THashSet<InteractionWiredExtra> extras = room.getRoomSpecialTypes().getExtras(trigger.getX(), trigger.getY());
for (InteractionWiredExtra extra : extras)
{
extra.activateBox(room);
}
List<InteractionWiredEffect> effectList = new ArrayList<>(effects);
if (hasExtraRandom || hasExtraUnseen)
{
Collections.shuffle(effectList);
}
if (hasExtraUnseen)
{
for (InteractionWiredExtra extra : room.getRoomSpecialTypes().getExtras(trigger.getX(), trigger.getY()))
{
if (extra instanceof WiredExtraUnseen)
{
extra.setExtradata(extra.getExtradata().equals("1") ? "0" : "1");
InteractionWiredEffect effect = ((WiredExtraUnseen) extra).getUnseenEffect(effectList);
triggerEffect(effect, roomUnit, room, stuff, millis);
break;
}
}
}
else
{
for (final InteractionWiredEffect effect : effectList)
{
boolean executed = triggerEffect(effect, roomUnit, room, stuff, millis);
if (hasExtraRandom && executed)
{
break;
}
}
}
return !Emulator.getPluginManager().fireEvent(new WiredStackExecutedEvent(room, roomUnit, trigger, effects, conditions)).isCancelled();
}
return false;
}
private static boolean triggerEffect(InteractionWiredEffect effect, RoomUnit roomUnit, Room room, Object[] stuff, long millis)
{
boolean executed = false;
if (effect != null && effect.canExecute(millis))
2018-07-06 15:30:00 +02:00
{
executed = true;
if (!effect.requiresTriggeringUser() || (roomUnit != null && effect.requiresTriggeringUser()))
{
Emulator.getThreading().run(new Runnable()
{
@Override
public void run()
{
if (room.isLoaded())
{
try
{
2019-03-18 02:22:00 +01:00
if (!effect.execute(roomUnit, room, stuff)) return;
2019-04-22 01:42:00 +02:00
effect.setCooldown(millis);
2018-07-06 15:30:00 +02:00
}
catch (Exception e)
{
Emulator.getLogging().logErrorLine(e);
}
effect.activateBox(room);
}
}
}, effect.getDelay() * 500);
}
}
return executed;
}
public static boolean executeEffectsAtTiles(THashSet<RoomTile> tiles, final RoomUnit roomUnit, final Room room, final Object[] stuff)
{
for(RoomTile tile : tiles)
{
if(room != null)
{
THashSet<HabboItem> items = room.getItemsAt(tile);
2019-03-18 02:22:00 +01:00
long millis = room.getCycleTimestamp();
2018-07-06 15:30:00 +02:00
for(final HabboItem item : items)
{
2019-03-18 02:22:00 +01:00
if(item instanceof InteractionWiredEffect && !(item instanceof WiredEffectTriggerStacks))
2018-07-06 15:30:00 +02:00
{
triggerEffect((InteractionWiredEffect) item, roomUnit, room, stuff, millis);
2019-03-18 02:22:00 +01:00
((InteractionWiredEffect) item).setCooldown(millis);
2018-07-06 15:30:00 +02:00
}
}
}
}
return true;
}
public static void dropRewards(int wiredId)
{
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("DELETE FROM wired_rewards_given WHERE wired_item = ?"))
{
statement.setInt(1, wiredId);
statement.execute();
}
catch (SQLException e)
{
Emulator.getLogging().logSQLException(e);
}
}
private static void giveReward(Habbo habbo, WiredEffectGiveReward wiredBox, WiredGiveRewardItem reward)
{
if(wiredBox.limit > 0)
wiredBox.given++;
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("INSERT INTO wired_rewards_given (wired_item, user_id, reward_id, timestamp) VALUES ( ?, ?, ?, ?)"))
{
statement.setInt(1, wiredBox.getId());
statement.setInt(2, habbo.getHabboInfo().getId());
statement.setInt(3, reward.id);
statement.setInt(4, Emulator.getIntUnixTimestamp());
statement.execute();
}
catch (SQLException e)
{
Emulator.getLogging().logSQLException(e);
}
if(reward.badge)
{
UserWiredRewardReceived rewardReceived = new UserWiredRewardReceived(habbo, wiredBox, "badge", reward.data);
if(Emulator.getPluginManager().fireEvent(rewardReceived).isCancelled())
return;
if(rewardReceived.value.isEmpty())
return;
HabboBadge badge = new HabboBadge(0, rewardReceived.value, 0, habbo);
Emulator.getThreading().run(badge);
habbo.getInventory().getBadgesComponent().addBadge(badge);
habbo.getClient().sendResponse(new AddUserBadgeComposer(badge));
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_RECEIVED_BADGE));
}
else
{
String[] data = reward.data.split("#");
if (data.length == 2)
{
UserWiredRewardReceived rewardReceived = new UserWiredRewardReceived(habbo, wiredBox, data[0], data[1]);
if(Emulator.getPluginManager().fireEvent(rewardReceived).isCancelled())
return;
if(rewardReceived.value.isEmpty())
return;
if(rewardReceived.type.equalsIgnoreCase("credits"))
{
int credits = Integer.valueOf(rewardReceived.value);
habbo.giveCredits(credits);
}
else if(rewardReceived.type.equalsIgnoreCase("pixels"))
{
int pixels = Integer.valueOf(rewardReceived.value);
habbo.givePixels(pixels);
}
2018-10-07 00:28:00 +02:00
else if(rewardReceived.type.startsWith("points"))
2018-07-06 15:30:00 +02:00
{
int points = Integer.valueOf(rewardReceived.value);
2018-10-07 00:28:00 +02:00
int type = 5;
try { type = Integer.valueOf(rewardReceived.type.replace("points", "")); } catch ( Exception e) {}
habbo.givePoints(type, points);
2018-07-06 15:30:00 +02:00
}
else if(rewardReceived.type.equalsIgnoreCase("furni"))
{
Item baseItem = Emulator.getGameEnvironment().getItemManager().getItem(Integer.valueOf(rewardReceived.value));
if(baseItem != null)
{
HabboItem item = Emulator.getGameEnvironment().getItemManager().createItem(habbo.getHabboInfo().getId(), baseItem, 0, 0, "");
if(item != null)
{
habbo.getClient().sendResponse(new AddHabboItemComposer(item));
habbo.getClient().getHabbo().getInventory().getItemsComponent().addItem(item);
habbo.getClient().sendResponse(new PurchaseOKComposer(null));
habbo.getClient().sendResponse(new InventoryRefreshComposer());
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_RECEIVED_ITEM));
}
}
}
else if(rewardReceived.type.equalsIgnoreCase("respect"))
{
habbo.getHabboStats().respectPointsReceived += Integer.valueOf(rewardReceived.value);
}
else if (rewardReceived.type.equalsIgnoreCase("cata"))
{
CatalogItem item = Emulator.getGameEnvironment().getCatalogManager().getCatalogItem(Integer.valueOf(rewardReceived.value));
if (item != null)
{
Emulator.getGameEnvironment().getCatalogManager().purchaseItem(null, item, habbo, 1, "", true);
}
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_RECEIVED_ITEM));
}
}
}
}
public static boolean getReward(Habbo habbo, WiredEffectGiveReward wiredBox)
{
if(wiredBox.limit > 0)
{
if(wiredBox.limit - wiredBox.given == 0)
{
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.LIMITED_NO_MORE_AVAILABLE));
return false;
}
}
2019-04-22 01:42:00 +02:00
try (Connection connection = Emulator.getDatabase().getDataSource().getConnection(); PreparedStatement statement = connection.prepareStatement("SELECT COUNT(*) as row_count, wired_rewards_given.* FROM wired_rewards_given WHERE user_id = ? AND wired_item = ? ORDER BY timestamp DESC LIMIT ?"))
2018-07-06 15:30:00 +02:00
{
statement.setInt(1, habbo.getHabboInfo().getId());
statement.setInt(2, wiredBox.getId());
statement.setInt(3, wiredBox.rewardItems.size());
try (ResultSet set = statement.executeQuery())
{
if (set.first())
{
2019-04-22 01:42:00 +02:00
if (set.getInt("row_count") >= 1)
2018-07-06 15:30:00 +02:00
{
2018-09-12 18:45:00 +02:00
if (wiredBox.rewardTime == WiredEffectGiveReward.LIMIT_ONCE)
2018-07-06 15:30:00 +02:00
{
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_ALREADY_RECEIVED));
return false;
}
}
set.beforeFirst();
if (set.next())
{
2018-09-12 18:45:00 +02:00
if (wiredBox.rewardTime == WiredEffectGiveReward.LIMIT_N_MINUTES)
2018-07-06 15:30:00 +02:00
{
if (Emulator.getIntUnixTimestamp() - set.getInt("timestamp") <= 60)
{
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_ALREADY_RECEIVED_THIS_MINUTE));
return false;
}
}
if (wiredBox.uniqueRewards)
{
2019-04-22 01:42:00 +02:00
if (set.getInt("row_count") == wiredBox.rewardItems.size())
2018-07-06 15:30:00 +02:00
{
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_ALL_COLLECTED));
return false;
}
}
2018-09-12 18:45:00 +02:00
if (wiredBox.rewardTime == WiredEffectGiveReward.LIMIT_N_HOURS)
2018-07-06 15:30:00 +02:00
{
if (!(Emulator.getIntUnixTimestamp() - set.getInt("timestamp") >= (3600 * wiredBox.limitationInterval)))
{
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_ALREADY_RECEIVED_THIS_HOUR));
return false;
}
}
2018-09-12 18:45:00 +02:00
if (wiredBox.rewardTime == WiredEffectGiveReward.LIMIT_N_DAY)
2018-07-06 15:30:00 +02:00
{
if (!(Emulator.getIntUnixTimestamp() - set.getInt("timestamp") >= (86400 * wiredBox.limitationInterval)))
{
habbo.getClient().sendResponse(new WiredRewardAlertComposer(WiredRewardAlertComposer.REWARD_ALREADY_RECEIVED_THIS_TODAY));
return false;
}
}
}
if (wiredBox.uniqueRewards)
{
for (WiredGiveRewardItem item : wiredBox.rewardItems)
{
set.beforeFirst();
boolean found = false;
while (set.next())
{
if (set.getInt("reward_id") == item.id)
found = true;
}
if (!found)
{
giveReward(habbo, wiredBox, item);
return true;
}
}
}
else
{
int randomNumber = Emulator.getRandom().nextInt(101);
int count = 0;
for (WiredGiveRewardItem item : wiredBox.rewardItems)
{
if (randomNumber >= count && randomNumber <= (count + item.probability))
{
giveReward(habbo, wiredBox, item);
return true;
}
count += item.probability;
}
}
}
}
}
catch (SQLException e)
{
Emulator.getLogging().logSQLException(e);
}
return false;
}
public static void resetTimers(Room room)
{
if(!room.isLoaded())
return;
THashSet<InteractionWiredTrigger> triggers = room.getRoomSpecialTypes().getTriggers(WiredTriggerType.AT_GIVEN_TIME);
if (triggers != null)
{
for (InteractionWiredTrigger trigger : triggers)
{
((WiredTriggerReset) trigger).resetTimer();
}
}
room.setLastTimerReset(Emulator.getIntUnixTimestamp());
}
}