From 65147e1935ce052dabde7e1421ee364b8156a990 Mon Sep 17 00:00:00 2001 From: Luck Date: Mon, 27 Mar 2017 16:54:59 +0100 Subject: [PATCH] Remove missing permission nodes before adding new ones when saving users/groups with SQL storage --- .../common/storage/backing/SQLBacking.java | 24 +++++++++---------- 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/common/src/main/java/me/lucko/luckperms/common/storage/backing/SQLBacking.java b/common/src/main/java/me/lucko/luckperms/common/storage/backing/SQLBacking.java index 645ebbe1..65222100 100644 --- a/common/src/main/java/me/lucko/luckperms/common/storage/backing/SQLBacking.java +++ b/common/src/main/java/me/lucko/luckperms/common/storage/backing/SQLBacking.java @@ -392,10 +392,10 @@ public class SQLBacking extends AbstractBacking { Set toAdd = diff.getKey(); Set toRemove = diff.getValue(); - if (!toAdd.isEmpty()) { + if (!toRemove.isEmpty()) { try (Connection c = provider.getConnection()) { - try (PreparedStatement ps = c.prepareStatement(prefix.apply(USER_PERMISSIONS_INSERT))) { - for (NodeDataHolder nd : toAdd) { + try (PreparedStatement ps = c.prepareStatement(prefix.apply(USER_PERMISSIONS_DELETE_SPECIFIC))) { + for (NodeDataHolder nd : toRemove) { ps.setString(1, user.getUuid().toString()); ps.setString(2, nd.getPermission()); ps.setBoolean(3, nd.isValue()); @@ -413,10 +413,10 @@ public class SQLBacking extends AbstractBacking { } } - if (!toRemove.isEmpty()) { + if (!toAdd.isEmpty()) { try (Connection c = provider.getConnection()) { - try (PreparedStatement ps = c.prepareStatement(prefix.apply(USER_PERMISSIONS_DELETE_SPECIFIC))) { - for (NodeDataHolder nd : toRemove) { + try (PreparedStatement ps = c.prepareStatement(prefix.apply(USER_PERMISSIONS_INSERT))) { + for (NodeDataHolder nd : toAdd) { ps.setString(1, user.getUuid().toString()); ps.setString(2, nd.getPermission()); ps.setBoolean(3, nd.isValue()); @@ -675,10 +675,10 @@ public class SQLBacking extends AbstractBacking { Set toAdd = diff.getKey(); Set toRemove = diff.getValue(); - if (!toAdd.isEmpty()) { + if (!toRemove.isEmpty()) { try (Connection c = provider.getConnection()) { - try (PreparedStatement ps = c.prepareStatement(prefix.apply(GROUP_PERMISSIONS_INSERT))) { - for (NodeDataHolder nd : toAdd) { + try (PreparedStatement ps = c.prepareStatement(prefix.apply(GROUP_PERMISSIONS_DELETE_SPECIFIC))) { + for (NodeDataHolder nd : toRemove) { ps.setString(1, group.getName()); ps.setString(2, nd.getPermission()); ps.setBoolean(3, nd.isValue()); @@ -696,10 +696,10 @@ public class SQLBacking extends AbstractBacking { } } - if (!toRemove.isEmpty()) { + if (!toAdd.isEmpty()) { try (Connection c = provider.getConnection()) { - try (PreparedStatement ps = c.prepareStatement(prefix.apply(GROUP_PERMISSIONS_DELETE_SPECIFIC))) { - for (NodeDataHolder nd : toRemove) { + try (PreparedStatement ps = c.prepareStatement(prefix.apply(GROUP_PERMISSIONS_INSERT))) { + for (NodeDataHolder nd : toAdd) { ps.setString(1, group.getName()); ps.setString(2, nd.getPermission()); ps.setBoolean(3, nd.isValue());