Log when someone completes a quest and fixed CompleteQuestEvent storing quests
This commit is contained in:
parent
6a5261ff9a
commit
2cefdf8840
|
|
@ -59,7 +59,6 @@ public final class AQuest extends JavaPlugin {
|
||||||
getServer().getPluginManager().registerEvents(new EntityBucketed(), this);
|
getServer().getPluginManager().registerEvents(new EntityBucketed(), this);
|
||||||
getServer().getPluginManager().registerEvents(new EntityBreed(), this);
|
getServer().getPluginManager().registerEvents(new EntityBreed(), this);
|
||||||
getServer().getPluginManager().registerEvents(new DonNotMessWithNPC(), this);
|
getServer().getPluginManager().registerEvents(new DonNotMessWithNPC(), this);
|
||||||
getServer().getPluginManager().registerEvents(new QuestComplete(), this);
|
|
||||||
getServer().getMessenger().registerOutgoingPluginChannel(this, "aquest:player-data");
|
getServer().getMessenger().registerOutgoingPluginChannel(this, "aquest:player-data");
|
||||||
getServer().getMessenger().registerIncomingPluginChannel(this, "aquest:player-data", new PluginMessageListener());
|
getServer().getMessenger().registerIncomingPluginChannel(this, "aquest:player-data", new PluginMessageListener());
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -1,15 +0,0 @@
|
||||||
package com.alttd.altitudequests.events;
|
|
||||||
|
|
||||||
import com.alttd.altitudequests.objects.QuestCompleteEvent;
|
|
||||||
import org.bukkit.event.EventHandler;
|
|
||||||
import org.bukkit.event.EventPriority;
|
|
||||||
import org.bukkit.event.Listener;
|
|
||||||
|
|
||||||
public class QuestComplete implements Listener {
|
|
||||||
|
|
||||||
@EventHandler(ignoreCancelled = true, priority = EventPriority.MONITOR)
|
|
||||||
public void onQuestComplete(QuestCompleteEvent event) {
|
|
||||||
event.getPlayer().sendMiniMessage("<green>You completed a quest gj. - DEBUG</green>", null);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
@ -209,14 +209,29 @@ public abstract class Quest {
|
||||||
checkDone();
|
checkDone();
|
||||||
if (!isDone)
|
if (!isDone)
|
||||||
return;
|
return;
|
||||||
//TODO add completed quest to database
|
saveDone();
|
||||||
saveDone(player);
|
|
||||||
QuestCompleteEvent event = new QuestCompleteEvent(player, this, true);
|
QuestCompleteEvent event = new QuestCompleteEvent(player, this, true);
|
||||||
event.callEvent();
|
event.callEvent();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void saveDone(Player player) {
|
private void saveDone() {
|
||||||
|
try {
|
||||||
|
String sql = "INSERT INTO quest_log " +
|
||||||
|
"(uuid, year, month, day) " +
|
||||||
|
"VALUES (?, ?, ?, ?)";
|
||||||
|
PreparedStatement statement = Database.getDatabase().getConnection().prepareStatement(sql);
|
||||||
|
Calendar calendar = Calendar.getInstance();
|
||||||
|
calendar.setTime(new Date());
|
||||||
|
statement.setString(1, uuid.toString());
|
||||||
|
statement.setInt(2, calendar.get(Calendar.YEAR));
|
||||||
|
statement.setInt(3, calendar.get(Calendar.MONTH));
|
||||||
|
statement.setInt(4, calendar.get(Calendar.DAY_OF_MONTH));
|
||||||
|
} catch (SQLException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
Logger.severe("Error while trying to create quest log table");
|
||||||
|
Logger.severe("Shutting down AltitudeQuests");
|
||||||
|
Bukkit.getPluginManager().disablePlugin(AQuest.getInstance());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Variant getVariant() {
|
public Variant getVariant() {
|
||||||
|
|
|
||||||
|
|
@ -5,15 +5,17 @@ import org.bukkit.event.Event;
|
||||||
import org.bukkit.event.HandlerList;
|
import org.bukkit.event.HandlerList;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
public class QuestCompleteEvent extends Event{
|
public class QuestCompleteEvent extends Event {
|
||||||
private static final HandlerList handlers = new HandlerList();
|
private static final HandlerList handlers = new HandlerList();
|
||||||
final private Player player;
|
final private Player player;
|
||||||
final private Quest quest;
|
final private Variant variant;
|
||||||
|
final private int amount;
|
||||||
final boolean daily;
|
final boolean daily;
|
||||||
|
|
||||||
public QuestCompleteEvent(Player player, Quest quest, boolean daily) {
|
public QuestCompleteEvent(Player player, Quest quest, boolean daily) {
|
||||||
this.player = player;
|
this.player = player;
|
||||||
this.quest = quest;
|
this.variant = quest.getVariant();
|
||||||
|
this.amount = quest.getAmount();
|
||||||
this.daily = daily;
|
this.daily = daily;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -21,8 +23,12 @@ public class QuestCompleteEvent extends Event{
|
||||||
return player;
|
return player;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Quest getQuest() {
|
public Variant getVariant() {
|
||||||
return quest;
|
return variant;
|
||||||
|
}
|
||||||
|
|
||||||
|
public int getAmount() {
|
||||||
|
return amount;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isDaily() {
|
public boolean isDaily() {
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user