Compare commits

...

3 Commits

Author SHA1 Message Date
0d92921b45 Ignore SQLite database
All checks were successful
continuous-integration/drone/push Build is passing
2022-11-21 00:28:29 +01:00
a9ccfbe0bc Remove SQLite database 2022-11-21 00:28:10 +01:00
5ee7321978 Implement functional reply tracker
Now, with commands that support it, only the user who ran the command/triggered the interaction can use its buttons.
2022-11-21 00:27:57 +01:00
4 changed files with 68 additions and 3 deletions

1
.gitignore vendored
View File

@ -1,2 +1,3 @@
target/ target/
.idea/ .idea/
*.sqlite

BIN
db.sqlite

Binary file not shown.

View File

@ -145,7 +145,7 @@ public class ClearChatCommand
} }
Button deleteButton = Button.danger("clear_delete", "Delete").withEmoji(Emoji.fromUnicode("")); Button deleteButton = Button.danger("clear_delete", "Dismiss").withEmoji(Emoji.fromUnicode(""));
WebhookMessageEditAction<Message> webhookMessageEditAction; WebhookMessageEditAction<Message> webhookMessageEditAction;
@ -167,8 +167,10 @@ public class ClearChatCommand
String replyMessageId = message.getId(); String replyMessageId = message.getId();
String replyChannelId = message.getChannel().getId(); String replyChannelId = message.getChannel().getId();
String replyGuildId = message.getGuild().getId(); String replyGuildId = message.getGuild().getId();
String userId = event.getUser().getId();
Configuration.getDatabaseManager().queueDisabling(replyGuildId, replyChannelId, replyMessageId); Configuration.getDatabaseManager().queueDisabling(replyGuildId, replyChannelId, replyMessageId);
Configuration.getDatabaseManager().trackRanCommandReply(replyGuildId, replyChannelId, replyMessageId, userId);
} }
}).start(); }).start();
@ -177,6 +179,14 @@ public class ClearChatCommand
public void deleteButton(ButtonInteractionEvent event) public void deleteButton(ButtonInteractionEvent event)
{ {
event.getInteraction().getMessage().delete().queue();
if(!(Configuration.getDatabaseManager().isUserTrackedFor(event.getUser().getId(), event.getMessageId())))
{
event.reply("❌ You did not run this command!").setEphemeral(true).queue();
} else
{
event.getInteraction().getMessage().delete().queue();
}
} }
} }

View File

@ -95,6 +95,60 @@ public class DatabaseManager
return true; return true;
} }
public boolean trackRanCommandReply(String guildId, String channelId, String messageId, String userId)
{
String query = "INSERT INTO command_runners " +
"(guild_id, channel_id, message_id, user_id) VALUES " +
" (?, ?, ?, ?);";
try(PreparedStatement preparedStatement = dbConnection.prepareStatement(query))
{
preparedStatement.setString(1, guildId);
preparedStatement.setString(2, channelId);
preparedStatement.setString(3, messageId);
preparedStatement.setString(4, userId);
preparedStatement.executeUpdate();
return true;
} catch (SQLException e)
{
e.printStackTrace();
}
return false;
}
public boolean isUserTrackedFor(String userId, String messageId)
{
String trackedUserId = getTrackedReplyUserId(messageId);
if(trackedUserId == null) return false;
return userId.equals(trackedUserId);
}
public String getTrackedReplyUserId(String messageId)
{
String query = "SELECT user_id " +
"FROM command_runners " +
"WHERE message_id = ?;";
try(PreparedStatement preparedStatement = dbConnection.prepareStatement(query))
{
preparedStatement.setString(1, messageId);
ResultSet resultSet = preparedStatement.executeQuery();
if(resultSet.isClosed()) return null;
while(resultSet.next())
{
return resultSet.getString("user_id");
}
} catch (SQLException e) {
e.printStackTrace();
}
return null;
}
public boolean queueDisabling(String guildId, String channelId, String messageId) public boolean queueDisabling(String guildId, String channelId, String messageId)
{ {
LocalDateTime expiryTime = LocalDateTime.now().plusSeconds(Configuration.getExpiryTimeSeconds()); LocalDateTime expiryTime = LocalDateTime.now().plusSeconds(Configuration.getExpiryTimeSeconds());