mirror of
https://git.krews.org/morningstar/Arcturus-Community.git
synced 2024-06-30 12:45:34 +02:00
140 lines
4.5 KiB
Java
140 lines
4.5 KiB
Java
package com.eu.habbo.habbohotel.items.interactions.wired.effects;
|
|
|
|
import com.eu.habbo.Emulator;
|
|
import com.eu.habbo.habbohotel.gameclients.GameClient;
|
|
import com.eu.habbo.habbohotel.games.Game;
|
|
import com.eu.habbo.habbohotel.games.wired.WiredGame;
|
|
import com.eu.habbo.habbohotel.items.Item;
|
|
import com.eu.habbo.habbohotel.items.interactions.InteractionWiredEffect;
|
|
import com.eu.habbo.habbohotel.items.interactions.InteractionWiredTrigger;
|
|
import com.eu.habbo.habbohotel.rooms.Room;
|
|
import com.eu.habbo.habbohotel.rooms.RoomUnit;
|
|
import com.eu.habbo.habbohotel.users.Habbo;
|
|
import com.eu.habbo.habbohotel.wired.WiredEffectType;
|
|
import com.eu.habbo.habbohotel.wired.WiredHandler;
|
|
import com.eu.habbo.messages.ClientMessage;
|
|
import com.eu.habbo.messages.ServerMessage;
|
|
import com.eu.habbo.messages.incoming.wired.WiredSaveException;
|
|
import gnu.trove.procedure.TObjectProcedure;
|
|
|
|
import java.sql.ResultSet;
|
|
import java.sql.SQLException;
|
|
import java.util.ArrayList;
|
|
import java.util.List;
|
|
|
|
public class WiredEffectLeaveTeam extends InteractionWiredEffect {
|
|
public static final WiredEffectType type = WiredEffectType.LEAVE_TEAM;
|
|
|
|
public WiredEffectLeaveTeam(ResultSet set, Item baseItem) throws SQLException {
|
|
super(set, baseItem);
|
|
}
|
|
|
|
public WiredEffectLeaveTeam(int id, int userId, Item item, String extradata, int limitedStack, int limitedSells) {
|
|
super(id, userId, item, extradata, limitedStack, limitedSells);
|
|
}
|
|
|
|
@Override
|
|
public boolean execute(RoomUnit roomUnit, Room room, Object[] stuff) {
|
|
Habbo habbo = room.getHabbo(roomUnit);
|
|
|
|
if (habbo != null) {
|
|
if (habbo.getHabboInfo().getCurrentGame() != null) {
|
|
Game game = room.getGame(habbo.getHabboInfo().getCurrentGame());
|
|
|
|
if (game == null) {
|
|
game = room.getGameOrCreate(WiredGame.class);
|
|
}
|
|
|
|
if (game != null) {
|
|
game.removeHabbo(habbo);
|
|
return true;
|
|
}
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
@Override
|
|
public String getWiredData() {
|
|
return WiredHandler.getGsonBuilder().create().toJson(new JsonData(this.getDelay()));
|
|
}
|
|
|
|
@Override
|
|
public void loadWiredData(ResultSet set, Room room) throws SQLException {
|
|
String wiredData = set.getString("wired_data");
|
|
|
|
if(wiredData.startsWith("{")) {
|
|
JsonData data = WiredHandler.getGsonBuilder().create().fromJson(wiredData, JsonData.class);
|
|
this.setDelay(data.delay);
|
|
}
|
|
else {
|
|
this.setDelay(Integer.valueOf(wiredData));
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void onPickUp() {
|
|
this.setDelay(0);
|
|
}
|
|
|
|
@Override
|
|
public WiredEffectType getType() {
|
|
return type;
|
|
}
|
|
|
|
@Override
|
|
public void serializeWiredData(ServerMessage message, Room room) {
|
|
message.appendBoolean(false);
|
|
message.appendInt(5);
|
|
message.appendInt(0);
|
|
message.appendInt(this.getBaseItem().getSpriteId());
|
|
message.appendInt(this.getId());
|
|
message.appendString("");
|
|
message.appendInt(0);
|
|
message.appendInt(0);
|
|
message.appendInt(this.getType().code);
|
|
message.appendInt(this.getDelay());
|
|
|
|
if (this.requiresTriggeringUser()) {
|
|
List<Integer> invalidTriggers = new ArrayList<>();
|
|
room.getRoomSpecialTypes().getTriggers(this.getX(), this.getY()).forEach(new TObjectProcedure<InteractionWiredTrigger>() {
|
|
@Override
|
|
public boolean execute(InteractionWiredTrigger object) {
|
|
if (!object.isTriggeredByRoomUnit()) {
|
|
invalidTriggers.add(object.getBaseItem().getSpriteId());
|
|
}
|
|
return true;
|
|
}
|
|
});
|
|
message.appendInt(invalidTriggers.size());
|
|
for (Integer i : invalidTriggers) {
|
|
message.appendInt(i);
|
|
}
|
|
} else {
|
|
message.appendInt(0);
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public boolean saveData(ClientMessage packet, GameClient gameClient) throws WiredSaveException {
|
|
packet.readInt();
|
|
packet.readString();
|
|
packet.readInt();
|
|
int delay = packet.readInt();
|
|
|
|
if(delay > Emulator.getConfig().getInt("hotel.wired.max_delay", 20))
|
|
throw new WiredSaveException("Delay too long");
|
|
|
|
this.setDelay(delay);
|
|
return true;
|
|
}
|
|
|
|
static class JsonData {
|
|
int delay;
|
|
|
|
public JsonData(int delay) {
|
|
this.delay = delay;
|
|
}
|
|
}
|
|
}
|