WiredTriggerBotReachedFurni now saves as json

This commit is contained in:
Remco 2021-01-04 08:14:51 -05:00
parent abe70991a0
commit fd90c23a3a

View File

@ -124,22 +124,28 @@ public class WiredTriggerBotReachedFurni extends InteractionWiredTrigger {
@Override
public String getWiredData() {
StringBuilder wiredData = new StringBuilder(this.botName + ":");
if (!this.items.isEmpty()) {
for (HabboItem item : this.items) {
wiredData.append(item.getId()).append(";");
}
}
return wiredData.toString();
return WiredHandler.getGsonBuilder().create().toJson(new JsonData(
this.botName,
this.items.stream().map(HabboItem::getId).collect(Collectors.toList())
));
}
@Override
public void loadWiredData(ResultSet set, Room room) throws SQLException {
this.items.clear();
String wiredData = set.getString("wired_data");
String[] data = set.getString("wired_data").split(":");
if (wiredData.startsWith("{")) {
JsonData data = WiredHandler.getGsonBuilder().create().fromJson(wiredData, JsonData.class);
this.botName = data.botName;
for (Integer id: data.itemIds) {
HabboItem item = room.getHabboItem(id);
if (item != null) {
this.items.add(item);
}
}
} else {
String[] data = wiredData.split(":");
if (data.length == 1) {
this.botName = data[0];
@ -160,10 +166,20 @@ public class WiredTriggerBotReachedFurni extends InteractionWiredTrigger {
}
}
}
}
@Override
public void onPickUp() {
this.items.clear();
this.botName = "";
}
static class JsonData {
String botName;
List<Integer> itemIds;
public JsonData(String botName, List<Integer> itemIds) {
this.executeTime = executeTime;
}
}
}