You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
383 lines
13 KiB
383 lines
13 KiB
10 years ago
|
package ru.simsonic.rscPermissions.Bukkit.Commands;
|
||
10 years ago
|
import java.io.File;
|
||
11 years ago
|
import java.util.ArrayList;
|
||
|
import java.util.Collections;
|
||
|
import java.util.Map;
|
||
10 years ago
|
import java.util.logging.Level;
|
||
11 years ago
|
import org.bukkit.command.Command;
|
||
|
import org.bukkit.command.CommandSender;
|
||
|
import org.bukkit.entity.Player;
|
||
10 years ago
|
import ru.simsonic.rscPermissions.Backends.DatabaseContents;
|
||
10 years ago
|
import ru.simsonic.rscPermissions.Bukkit.PermissionsEx_YAML;
|
||
10 years ago
|
import ru.simsonic.rscPermissions.BukkitPluginMain;
|
||
11 years ago
|
import ru.simsonic.rscUtilityLibrary.CommandProcessing.CommandAnswerException;
|
||
10 years ago
|
import ru.simsonic.rscUtilityLibrary.RestartableThread;
|
||
11 years ago
|
|
||
10 years ago
|
public class BukkitCommands
|
||
11 years ago
|
{
|
||
10 years ago
|
private final BukkitPluginMain rscp;
|
||
10 years ago
|
public BukkitCommands(final BukkitPluginMain rscp)
|
||
11 years ago
|
{
|
||
10 years ago
|
this.rscp = rscp;
|
||
|
}
|
||
10 years ago
|
public final RestartableThread threadFetchDatabaseContents = new RestartableThread()
|
||
10 years ago
|
{
|
||
|
@Override
|
||
|
public void run()
|
||
|
{
|
||
10 years ago
|
if(rscp.connection.isConnected() == false)
|
||
|
if(rscp.connection.connect() == false)
|
||
|
{
|
||
10 years ago
|
BukkitPluginMain.consoleLog.warning("[rscp] Cannot connect to database! Using local cache only.");
|
||
10 years ago
|
return;
|
||
|
}
|
||
10 years ago
|
final DatabaseContents contents = rscp.connection.retrieveContents();
|
||
10 years ago
|
if(contents != null)
|
||
|
{
|
||
|
contents.normalize();
|
||
|
rscp.fileCache.cleanup();
|
||
|
rscp.fileCache.saveContents(contents);
|
||
10 years ago
|
contents.filterServerId(rscp.getServer().getServerId());
|
||
10 years ago
|
rscp.internalCache.fill(contents);
|
||
10 years ago
|
final Runnable syncTask = new Runnable()
|
||
|
{
|
||
|
@Override
|
||
|
public synchronized void run()
|
||
|
{
|
||
|
rscp.permissionManager.recalculateOnlinePlayers();
|
||
|
notify();
|
||
|
}
|
||
|
};
|
||
|
try
|
||
|
{
|
||
|
synchronized(syncTask)
|
||
|
{
|
||
|
rscp.getServer().getScheduler().runTask(rscp, syncTask);
|
||
|
syncTask.wait();
|
||
|
}
|
||
|
} catch(InterruptedException ex) {
|
||
|
}
|
||
10 years ago
|
} else
|
||
|
BukkitPluginMain.consoleLog.warning("[rscp] Cannot load data from database.");
|
||
10 years ago
|
}
|
||
|
};
|
||
|
public Thread threadMigrateFromPExSQL(final CommandSender sender)
|
||
|
{
|
||
|
final Thread result = new Thread()
|
||
|
{
|
||
|
@Override
|
||
|
public void run()
|
||
|
{
|
||
|
try
|
||
|
{
|
||
|
setName("rscp:MigrateFromPExSQL");
|
||
|
rscp.connection.executeUpdateT("Migrate_from_PermissionsEx");
|
||
10 years ago
|
threadFetchDatabaseContents.join();
|
||
10 years ago
|
rscp.getServer().getScheduler().runTask(rscp, new Runnable()
|
||
|
{
|
||
|
@Override
|
||
|
public void run()
|
||
|
{
|
||
|
rscp.formattedMessage(sender, "Migration from PermissionsEx (MySQL backend) done!");
|
||
|
rscp.formattedMessage(sender, "Check the latest database row for new data.");
|
||
|
}
|
||
|
});
|
||
10 years ago
|
} catch(InterruptedException ex) {
|
||
10 years ago
|
BukkitPluginMain.consoleLog.log(Level.SEVERE, "[rscp] Exception in MigrateFromPExSQL(): {0}", ex);
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
result.start();
|
||
|
return result;
|
||
|
}
|
||
|
public RestartableThread threadInsertExampleRows(final CommandSender sender)
|
||
|
{
|
||
|
final RestartableThread threadInsertExampleRows = new RestartableThread()
|
||
|
{
|
||
|
@Override
|
||
|
public void run()
|
||
|
{
|
||
|
Thread.currentThread().setName("rscp:InsertExampleRows");
|
||
|
rscp.connection.insertExampleRows();
|
||
|
rscp.getServer().getScheduler().runTask(rscp, new Runnable()
|
||
|
{
|
||
|
@Override
|
||
|
public void run()
|
||
|
{
|
||
|
sender.sendMessage("Database tables were filled with example rows.");
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
};
|
||
10 years ago
|
threadInsertExampleRows.startDeamon();
|
||
10 years ago
|
return threadInsertExampleRows;
|
||
|
}
|
||
11 years ago
|
public void onCommand(CommandSender sender, Command cmd, String label, String[] args) throws CommandAnswerException
|
||
11 years ago
|
{
|
||
|
switch(cmd.getName().toLowerCase())
|
||
|
{
|
||
|
case "rscp":
|
||
|
onCommandHub(sender, args);
|
||
11 years ago
|
break;
|
||
11 years ago
|
}
|
||
|
}
|
||
11 years ago
|
private void onCommandHub(CommandSender sender, String[] args) throws CommandAnswerException
|
||
11 years ago
|
{
|
||
|
final ArrayList<String> help = new ArrayList<>();
|
||
|
if(sender.hasPermission("rscp.admin"))
|
||
11 years ago
|
help.add("/rscp (user|group) {_LS}-- PermissionsEx-like admin commands");
|
||
11 years ago
|
if(sender.hasPermission("rscp.admin.lock"))
|
||
11 years ago
|
help.add("/rscp (lock|unlock) {_LS}-- maintenance mode control");
|
||
11 years ago
|
if(sender.hasPermission("rscp.admin"))
|
||
|
{
|
||
11 years ago
|
help.add("/rscp (examplerows|import) {_LS}-- possible useful things");
|
||
|
help.add("/rscp (debug|fetch|reload) {_LS}-- admin stuff");
|
||
11 years ago
|
}
|
||
11 years ago
|
help.add("/rscp (help) {_LS}-- show these notes");
|
||
11 years ago
|
if(help.size() > 0)
|
||
|
help.add(0, "{MAGENTA}Usage:");
|
||
10 years ago
|
help.add(0, rscp.getDescription().getName() + " v" + rscp.getDescription().getVersion());
|
||
11 years ago
|
help.add(1, "Perfect Superperms manager for multiserver environments");
|
||
|
if(sender.hasPermission("rscp.admin"))
|
||
10 years ago
|
help.add(2, "{_DS}Current serverId is \'{_LS}" + rscp.getServer().getServerId() + "{_DS}\' (server.properties)");
|
||
|
help.add("{_LG}" + rscp.getDescription().getWebsite());
|
||
11 years ago
|
if(args.length == 0)
|
||
11 years ago
|
throw new CommandAnswerException(help);
|
||
11 years ago
|
switch(args[0].toLowerCase())
|
||
|
{
|
||
|
case "user":
|
||
|
onCommandHubUser(sender, args);
|
||
|
return;
|
||
|
case "group":
|
||
|
onCommandHubGroup(sender, args);
|
||
|
return;
|
||
|
case "lock":
|
||
|
/* rscp lock [mMode] */
|
||
|
if(sender.hasPermission("rscp.lock"))
|
||
|
{
|
||
|
final String mMode = (args.length >= 2) ? args[1] : "default";
|
||
|
String mmon = "Maintenance mode enabled";
|
||
10 years ago
|
mmon = rscp.getConfig().getString("language.maintenance.locked.default.mmon", mmon);
|
||
|
mmon = rscp.getConfig().getString("language.maintenance.locked." + mMode + ".mmon", mmon);
|
||
10 years ago
|
rscp.bukkitListener.setMaintenanceMode(mMode);
|
||
11 years ago
|
throw new CommandAnswerException(mmon);
|
||
11 years ago
|
}
|
||
|
return;
|
||
|
case "unlock":
|
||
|
/* rscp unlock */
|
||
|
if(sender.hasPermission("rscp.lock"))
|
||
|
{
|
||
|
String mmoff = "Maintenance mode disabled";
|
||
10 years ago
|
mmoff = rscp.getConfig().getString("language.maintenance.unlocked", mmoff);
|
||
10 years ago
|
rscp.bukkitListener.setMaintenanceMode(null);
|
||
11 years ago
|
throw new CommandAnswerException(mmoff);
|
||
11 years ago
|
}
|
||
|
break;
|
||
|
case "examplerows":
|
||
|
/* rscp examplerows */
|
||
|
if(sender.hasPermission("rscp.admin"))
|
||
|
{
|
||
10 years ago
|
threadInsertExampleRows(sender);
|
||
11 years ago
|
throw new CommandAnswerException("Example rows have been added into database.");
|
||
11 years ago
|
}
|
||
|
return;
|
||
|
case "import":
|
||
|
/* rscp import pex <filename.yml> */
|
||
|
if(sender.hasPermission("rscp.admin"))
|
||
|
{
|
||
|
if(args.length > 1)
|
||
|
switch(args[1].toLowerCase())
|
||
|
{
|
||
|
case "pex-yaml":
|
||
|
if(args.length == 2)
|
||
|
break;
|
||
|
// TO DO HERE
|
||
10 years ago
|
PermissionsEx_YAML importer_pex = new PermissionsEx_YAML(
|
||
|
new File(rscp.getDataFolder(), args[2]));
|
||
10 years ago
|
threadFetchDatabaseContents.startDeamon();
|
||
11 years ago
|
throw new CommandAnswerException(new String[]
|
||
11 years ago
|
{
|
||
|
"Data has been imported successfully!",
|
||
10 years ago
|
/*
|
||
|
"Entities: {MAGENTA}" + Integer.toString(importer_pex.getEntities().length),
|
||
11 years ago
|
"Permissions: {MAGENTA}" + Integer.toString(importer_pex.getPermissions().length),
|
||
|
"Inheritance: {MAGENTA}" + Integer.toString(importer_pex.getInheritance().length),
|
||
10 years ago
|
*/
|
||
|
"{_DR}{_B}IT IS FAKE :p - all this is undone yet!",
|
||
11 years ago
|
});
|
||
|
case "pex-sql":
|
||
10 years ago
|
threadMigrateFromPExSQL(sender);
|
||
11 years ago
|
throw new CommandAnswerException("Trying to import PEX database into rscPermissions...");
|
||
11 years ago
|
}
|
||
11 years ago
|
throw new CommandAnswerException(new String[]
|
||
11 years ago
|
{
|
||
|
"Usage: {GOLD}/rscp import <importer> [options]",
|
||
|
"Available importers:",
|
||
|
"{_LR}pex-yaml{_LS} (PermissionsEx)",
|
||
|
"{_LG}pex-sql{_LS} (PermissionsEx)",
|
||
|
});
|
||
|
}
|
||
|
return;
|
||
|
case "fetch":
|
||
|
/* rscp fetch */
|
||
|
if(sender.hasPermission("rscp.admin.reload"))
|
||
|
{
|
||
10 years ago
|
threadFetchDatabaseContents.startDeamon();
|
||
11 years ago
|
throw new CommandAnswerException("Tables have been fetched.");
|
||
11 years ago
|
}
|
||
|
return;
|
||
|
case "reload":
|
||
|
/* rscp reload */
|
||
|
if(sender.hasPermission("rscp.admin.reload"))
|
||
|
{
|
||
10 years ago
|
rscp.getServer().getPluginManager().disablePlugin(rscp);
|
||
|
rscp.getServer().getPluginManager().enablePlugin(rscp);
|
||
11 years ago
|
throw new CommandAnswerException("Plugin has been reloaded.");
|
||
11 years ago
|
}
|
||
|
return;
|
||
|
case "debug":
|
||
|
/* rscp debug [yes|on|no|off|toggle] */
|
||
|
if(sender.hasPermission("rscp.admin"))
|
||
11 years ago
|
throw new CommandAnswerException("Not implemented yet.");
|
||
11 years ago
|
return;
|
||
|
case "help":
|
||
|
default:
|
||
11 years ago
|
throw new CommandAnswerException(help);
|
||
11 years ago
|
}
|
||
|
}
|
||
11 years ago
|
private void onCommandHubUser(CommandSender sender, String[] args) throws CommandAnswerException
|
||
11 years ago
|
{
|
||
|
if(sender.hasPermission("rscp.admin") == false)
|
||
11 years ago
|
throw new CommandAnswerException("Not enough permissions.");
|
||
11 years ago
|
final String[] help = new String[]
|
||
|
{
|
||
|
"rscPermissions command hub (user section).",
|
||
|
"{MAGENTA}Usage:",
|
||
|
"/rscp user <user> list permissions",
|
||
|
"/rscp user <user> list groups",
|
||
|
// "/rscp user <user> list ranks",
|
||
|
"/rscp user <user> prefix [prefix]",
|
||
|
"/rscp user <user> suffix [suffix]",
|
||
|
};
|
||
|
if(args.length < 3)
|
||
11 years ago
|
throw new CommandAnswerException(help);
|
||
10 years ago
|
final Player player = rscp.getServer().getPlayerExact(args[1]);
|
||
11 years ago
|
if(player == null)
|
||
11 years ago
|
throw new CommandAnswerException("Player should be online");
|
||
11 years ago
|
final ArrayList<String> list = new ArrayList<>();
|
||
|
switch(args[2].toLowerCase())
|
||
|
{
|
||
|
case "list":
|
||
|
if(args.length < 4)
|
||
11 years ago
|
throw new CommandAnswerException(help);
|
||
11 years ago
|
switch(args[3].toLowerCase())
|
||
|
{
|
||
|
case "permissions":
|
||
|
list.add("{MAGENTA}Permission list for {_YL}" + player.getName());
|
||
10 years ago
|
final Map<String, Boolean> pv = rscp.permissionManager.listPlayerPermissions(player);
|
||
11 years ago
|
final ArrayList<String> sorted_keys = new ArrayList<>(pv.keySet());
|
||
|
Collections.sort(sorted_keys);
|
||
|
for(String perm : sorted_keys)
|
||
|
if(pv.containsKey(perm))
|
||
|
list.add((pv.get(perm) ? "{_LG}" : "{_LR}") + perm);
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
case "groups":
|
||
|
list.add("{MAGENTA}Group list for {_YL}" + player.getName() + "{MAGENTA}:");
|
||
11 years ago
|
/*
|
||
11 years ago
|
ArrayList<String> groups = plugin.cache.getUserGroups(player.getName());
|
||
|
for(String group : groups)
|
||
|
list.add("{_LG}" + group);
|
||
11 years ago
|
*/
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
/*
|
||
|
case "ranks":
|
||
|
list.add("{MAGENTA}Ranks of player {_YL}" + player.getName() + "{MAGENTA}:");
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
*/
|
||
|
}
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
case "prefix":
|
||
|
if(args.length > 3)
|
||
|
{
|
||
11 years ago
|
/*
|
||
11 years ago
|
plugin.API.setPlayerPrefix(null, player.getName(), args[3]);
|
||
|
list.add("{MAGENTA}Prefix for user {_YL}" + player.getName() +
|
||
|
" {MAGENTA}has been set to \"{_R}" + plugin.cache.userGetPrefix(player.getName()) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
} else {
|
||
|
/*
|
||
11 years ago
|
list.add("{MAGENTA}Prefix for user {_YL}" + player.getName() +
|
||
|
" {MAGENTA}is \"{_R}" + plugin.cache.userGetPrefix(player.getName()) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
}
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
case "suffix":
|
||
|
if(args.length > 3)
|
||
|
{
|
||
11 years ago
|
/*
|
||
11 years ago
|
plugin.API.setPlayerSuffix(null, player.getName(), args[3]);
|
||
|
list.add("{MAGENTA}Suffix for user {_YL}" + player.getName() +
|
||
|
" {MAGENTA}has been set to \"{_R}" + plugin.cache.userGetSuffix(player.getName()) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
} else {
|
||
|
/*
|
||
11 years ago
|
list.add("{MAGENTA}Suffix for user {_YL}" + player.getName() +
|
||
|
" {MAGENTA}is \"{_R}" + plugin.cache.userGetSuffix(player.getName()) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
}
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
}
|
||
|
}
|
||
11 years ago
|
private void onCommandHubGroup(CommandSender sender, String[] args) throws CommandAnswerException
|
||
11 years ago
|
{
|
||
|
if(sender.hasPermission("rscp.admin") == false)
|
||
11 years ago
|
throw new CommandAnswerException("Not enough permissions.");
|
||
11 years ago
|
final String[] help = new String[]
|
||
|
{
|
||
|
"rscPermissions command hub (group section).",
|
||
|
"{MAGENTA}Usage:",
|
||
|
// "/rscp group <group> list permissions",
|
||
|
// "/rscp group <group> list ranks",
|
||
|
"/rscp group <group> prefix [prefix]",
|
||
|
"/rscp group <group> suffix [suffix]",
|
||
|
};
|
||
|
if(args.length < 3)
|
||
11 years ago
|
throw new CommandAnswerException(help);
|
||
11 years ago
|
final String group = args[1];
|
||
|
final ArrayList<String> list = new ArrayList<>();
|
||
|
switch(args[2].toLowerCase())
|
||
|
{
|
||
|
case "prefix":
|
||
|
if(args.length > 3)
|
||
|
{
|
||
11 years ago
|
/*
|
||
11 years ago
|
plugin.API.setGroupPrefix(null, group, args[3]);
|
||
|
list.add("{MAGENTA}Prefix for group {_YL}" + group +
|
||
|
" {MAGENTA}has been set to \"{_R}" + plugin.cache.groupGetPrefix(group) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
} else {
|
||
|
/*
|
||
11 years ago
|
list.add("{MAGENTA}Prefix for group {_YL}" + group +
|
||
|
" {MAGENTA}is \"{_R}" + plugin.cache.groupGetPrefix(group) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
}
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
case "suffix":
|
||
|
if(args.length > 3)
|
||
|
{
|
||
11 years ago
|
/*
|
||
11 years ago
|
plugin.API.setGroupSuffix(null, group, args[3]);
|
||
|
list.add("{MAGENTA}Suffix for group {_YL}" + group +
|
||
|
" {MAGENTA}has been set to \"{_R}" + plugin.cache.groupGetSuffix(group) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
} else {
|
||
|
/*
|
||
11 years ago
|
list.add("{MAGENTA}Suffix for group {_YL}" + group +
|
||
|
" {MAGENTA}is \"{_R}" + plugin.cache.groupGetSuffix(group) + "{MAGENTA}\".");
|
||
11 years ago
|
*/
|
||
|
}
|
||
11 years ago
|
throw new CommandAnswerException(list);
|
||
11 years ago
|
}
|
||
|
}
|
||
11 years ago
|
}
|