diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/SQLDB.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/SQLDB.java
index 91fe165bf..c8834c3bc 100644
--- a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/SQLDB.java
+++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/SQLDB.java
@@ -172,7 +172,8 @@ public abstract class SQLDB extends AbstractDatabase {
new RegisterDateMinimizationPatch(),
new BadNukkitRegisterValuePatch(),
new LinkedToSecurityTablePatch(),
- new LinkUsersToPlayersSecurityTablePatch()
+ new LinkUsersToPlayersSecurityTablePatch(),
+ new LitebansTableHeaderPatch()
};
}
diff --git a/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/patches/LitebansTableHeaderPatch.java b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/patches/LitebansTableHeaderPatch.java
new file mode 100644
index 000000000..44e3ab25a
--- /dev/null
+++ b/Plan/common/src/main/java/com/djrapitops/plan/storage/database/transactions/patches/LitebansTableHeaderPatch.java
@@ -0,0 +1,89 @@
+/*
+ * This file is part of Player Analytics (Plan).
+ *
+ * Plan is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Lesser General Public License v3 as published by
+ * the Free Software Foundation, either version 3 of the License, or
+ * (at your option) any later version.
+ *
+ * Plan is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public License
+ * along with Plan. If not, see .
+ */
+package com.djrapitops.plan.storage.database.transactions.patches;
+
+import com.djrapitops.plan.storage.database.queries.QueryStatement;
+import com.djrapitops.plan.storage.database.sql.tables.ExtensionPluginTable;
+import com.djrapitops.plan.storage.database.sql.tables.ExtensionServerTableValueTable;
+import com.djrapitops.plan.storage.database.sql.tables.ExtensionTableProviderTable;
+import com.djrapitops.plan.storage.database.transactions.ExecBatchStatement;
+
+import java.sql.PreparedStatement;
+import java.sql.ResultSet;
+import java.sql.SQLException;
+import java.util.HashSet;
+import java.util.Set;
+
+import static com.djrapitops.plan.storage.database.sql.building.Sql.*;
+
+/**
+ * Removes invalid data caused by https://github.com/plan-player-analytics/Plan/issues/1355.
+ *
+ * @author Rsl1122
+ */
+public class LitebansTableHeaderPatch extends Patch {
+
+ private Set found;
+
+ @Override
+ public boolean hasBeenApplied() {
+ String sql = SELECT + DISTINCT + "pr." + ExtensionTableProviderTable.ID + " as id" +
+ FROM + ExtensionServerTableValueTable.TABLE_NAME + " v" +
+ INNER_JOIN + ExtensionTableProviderTable.TABLE_NAME + " pr on pr." + ExtensionTableProviderTable.ID + "=v." + ExtensionServerTableValueTable.TABLE_ID +
+ INNER_JOIN + ExtensionPluginTable.TABLE_NAME + " p on p." + ExtensionPluginTable.ID + "=pr." + ExtensionTableProviderTable.PLUGIN_ID +
+ WHERE + "p." + ExtensionPluginTable.PLUGIN_NAME + "=?" +
+ AND + "(pr." + ExtensionTableProviderTable.PROVIDER_NAME + "=?" +
+ OR + "pr." + ExtensionTableProviderTable.PROVIDER_NAME + "=?" +
+ OR + "pr." + ExtensionTableProviderTable.PROVIDER_NAME + "=?" +
+ OR + "pr." + ExtensionTableProviderTable.PROVIDER_NAME + "=?)";
+ found = query(new QueryStatement>(sql) {
+ @Override
+ public void prepare(PreparedStatement statement) throws SQLException {
+ statement.setString(1, "Litebans");
+ statement.setString(2, "bans");
+ statement.setString(3, "warns");
+ statement.setString(4, "kicks");
+ statement.setString(5, "mutes");
+ }
+
+ @Override
+ public Set processResults(ResultSet set) throws SQLException {
+ Set ids = new HashSet<>();
+ while (set.next()) {
+ ids.add(set.getInt("id"));
+ }
+ return ids;
+ }
+ });
+ return found.isEmpty();
+ }
+
+ @Override
+ protected void applyPatch() {
+ String sql = DELETE_FROM + ExtensionServerTableValueTable.TABLE_NAME +
+ WHERE + ExtensionServerTableValueTable.TABLE_ID + "=?";
+ execute(new ExecBatchStatement(sql) {
+ @Override
+ public void prepare(PreparedStatement statement) throws SQLException {
+ for (Integer id : found) {
+ statement.setInt(1, id);
+ statement.addBatch();
+ }
+ }
+ });
+ }
+}
diff --git a/Plan/common/src/main/resources/plugin.yml b/Plan/common/src/main/resources/plugin.yml
index 460068dd8..e0e22c36a 100644
--- a/Plan/common/src/main/resources/plugin.yml
+++ b/Plan/common/src/main/resources/plugin.yml
@@ -18,7 +18,7 @@ softdepend:
- GriefPrevention
- GriefPreventionPlus
- Jobs
- - Litebans
+ - LiteBans
- LuckPerms
- mcMMO
- MinigamesLib
diff --git a/Plan/extensions/build.gradle b/Plan/extensions/build.gradle
index 29ba91cf5..500487934 100644
--- a/Plan/extensions/build.gradle
+++ b/Plan/extensions/build.gradle
@@ -17,7 +17,7 @@ dependencies {
compile 'com.djrapitops:Extension-GriefPrevention-Sponge:4.0.1-R0.2'
compile 'com.djrapitops:Extension-GriefPreventionPlus:13.3-R0.2'
compile 'com.djrapitops:Extension-Jobs:4.13.1-R0.1'
- compile 'com.djrapitops:Extension-Litebans:0.3-R0.1'
+ compile 'com.djrapitops:Extension-Litebans:0.3.2-R0.1'
compile 'com.djrapitops:Extension-LuckPerms:5.0-R0.2'
compile 'com.djrapitops:Extension-McMMO:2.1.44-R0.2'
compile 'com.djrapitops:Extension-MinigamesLib:1.14.17-R0.2'