mcMMO/src/main/java/com/gmail/nossr50/commands/mc/McremoveCommand.java

137 lines
4.9 KiB
Java
Raw Normal View History

2012-02-28 20:19:12 +01:00
package com.gmail.nossr50.commands.mc;
import java.io.BufferedReader;
import java.io.FileReader;
import java.io.FileWriter;
import org.bukkit.Bukkit;
2012-02-28 20:19:12 +01:00
import org.bukkit.ChatColor;
import org.bukkit.command.Command;
import org.bukkit.command.CommandExecutor;
import org.bukkit.command.CommandSender;
import org.bukkit.entity.Player;
import com.gmail.nossr50.Users;
import com.gmail.nossr50.mcMMO;
2012-04-20 06:03:03 +02:00
import com.gmail.nossr50.commands.CommandHelper;
2012-02-28 20:19:12 +01:00
import com.gmail.nossr50.config.LoadProperties;
import com.gmail.nossr50.locale.mcLocale;
public class McremoveCommand implements CommandExecutor {
2012-04-20 06:03:03 +02:00
private final String LOCATION = "plugins/mcMMO/FlatFileStuff/mcmmo.users";
2012-02-28 20:19:12 +01:00
@Override
public boolean onCommand(CommandSender sender, Command command, String label, String[] args) {
2012-04-20 06:03:03 +02:00
String playerName;
String usage = ChatColor.RED + "Proper usage is /mcremove <playername>"; //TODO: Needs more locale.
2012-04-20 06:03:03 +02:00
String success;
2012-02-28 20:19:12 +01:00
2012-04-20 06:03:03 +02:00
if (CommandHelper.noCommandPermissions(sender, "mcmmo.tools.mcremove")) {
2012-02-28 20:19:12 +01:00
return true;
}
2012-04-20 06:03:03 +02:00
switch (args.length) {
case 1:
playerName = args[0];
success = ChatColor.GREEN + playerName + "was successfully removed from the database!"; //TODO: Locale
break;
default:
sender.sendMessage(usage);
return true;
2012-02-28 20:19:12 +01:00
}
2012-04-20 06:03:03 +02:00
/* MySQL */
if (LoadProperties.useMySQL) {
int userId = 0;
2012-04-20 06:03:03 +02:00
userId = mcMMO.database.getInt("SELECT id FROM " + LoadProperties.MySQLtablePrefix + "users WHERE user = '" + playerName + "'");
if (userId > 0) {
mcMMO.database.write("DELETE FROM "
+ LoadProperties.MySQLdbName + "."
+ LoadProperties.MySQLtablePrefix + "users WHERE "
+ LoadProperties.MySQLtablePrefix + "users.id=" + userId);
mcMMO.database.write("DELETE FROM "
+ LoadProperties.MySQLdbName + "."
+ LoadProperties.MySQLtablePrefix + "cooldowns WHERE "
+ LoadProperties.MySQLtablePrefix + "cooldowns.user_id=" + userId);
mcMMO.database.write("DELETE FROM "
+ LoadProperties.MySQLdbName + "."
+ LoadProperties.MySQLtablePrefix + "huds WHERE "
+ LoadProperties.MySQLtablePrefix + "huds.user_id=" + userId);
mcMMO.database.write("DELETE FROM "
+ LoadProperties.MySQLdbName + "."
+ LoadProperties.MySQLtablePrefix + "skills WHERE "
+ LoadProperties.MySQLtablePrefix + "skills.user_id=" + userId);
mcMMO.database.write("DELETE FROM "
+ LoadProperties.MySQLdbName + "."
+ LoadProperties.MySQLtablePrefix + "experience WHERE "
+ LoadProperties.MySQLtablePrefix + "experience.user_id=" + userId);
sender.sendMessage(success);
}
else {
sender.sendMessage(mcLocale.getString("Commands.DoesNotExist"));
}
2012-04-20 06:03:03 +02:00
}
else {
if (removeFlatFileUser(playerName)) {
sender.sendMessage(success);
}
else {
sender.sendMessage(mcLocale.getString("Commands.DoesNotExist"));
}
2012-02-28 20:19:12 +01:00
}
2012-04-20 06:03:03 +02:00
//Force PlayerProfile stuff to update
2012-04-20 06:03:03 +02:00
Player player = Bukkit.getServer().getPlayer(playerName);
if (player != null && Users.players.containsKey(playerName.toLowerCase())) {
Users.removeUser(player);
Users.addUser(player);
}
2012-04-20 06:03:03 +02:00
2012-02-28 20:19:12 +01:00
return true;
}
2012-04-20 06:03:03 +02:00
private boolean removeFlatFileUser(String playerName) {
boolean worked = false;
2012-04-20 06:03:03 +02:00
try {
2012-04-20 06:03:03 +02:00
FileReader file = new FileReader(LOCATION);
BufferedReader in = new BufferedReader(file);
StringBuilder writer = new StringBuilder();
String line = "";
2012-04-20 06:03:03 +02:00
while ((line = in.readLine()) != null) {
2012-04-20 06:03:03 +02:00
/* Write out the same file but when we get to the player we want to remove, we skip his line. */
if (!line.split(":")[0].equalsIgnoreCase(playerName)) {
writer.append(line).append("\r\n");
2012-04-20 06:03:03 +02:00
}
else {
System.out.println("User found, removing...");
worked = true;
continue; //Skip the player
}
}
2012-04-20 06:03:03 +02:00
in.close();
2012-04-20 06:03:03 +02:00
FileWriter out = new FileWriter(LOCATION); //Write out the new file
out.write(writer.toString());
out.close();
2012-04-20 06:03:03 +02:00
return worked;
2012-04-20 06:03:03 +02:00
}
catch (Exception e) {
Bukkit.getLogger().severe("Exception while reading " + LOCATION + " (Are you sure you formatted it correctly?)" + e.toString());
return worked;
}
}
2012-04-20 06:03:03 +02:00
}