14 changed files with 276 additions and 311 deletions
@ -0,0 +1,151 @@ |
|||||||
|
package ru.simsonic.rscPermissions.Bukkit.Commands; |
||||||
|
|
||||||
|
import java.util.ArrayList; |
||||||
|
import java.util.Arrays; |
||||||
|
import java.util.Map; |
||||||
|
import org.bukkit.command.CommandSender; |
||||||
|
import org.bukkit.entity.Player; |
||||||
|
import ru.simsonic.rscMinecraftLibrary.Bukkit.CommandAnswerException; |
||||||
|
import ru.simsonic.rscPermissions.API.EntityType; |
||||||
|
import ru.simsonic.rscPermissions.API.RowEntity; |
||||||
|
import ru.simsonic.rscPermissions.Bukkit.BukkitUtilities; |
||||||
|
import ru.simsonic.rscPermissions.BukkitPluginMain; |
||||||
|
import ru.simsonic.rscPermissions.Engine.Backends.DatabaseEditor; |
||||||
|
import ru.simsonic.rscPermissions.Engine.Matchers; |
||||||
|
import ru.simsonic.rscPermissions.Engine.ResolutionResult; |
||||||
|
|
||||||
|
public class CommandEntity |
||||||
|
{ |
||||||
|
private final BukkitPluginMain rscp; |
||||||
|
CommandEntity(BukkitPluginMain plugin) |
||||||
|
{ |
||||||
|
this.rscp = plugin; |
||||||
|
} |
||||||
|
public void onEntityCommandHub(CommandSender sender, boolean type, String[] args) throws CommandAnswerException |
||||||
|
{ |
||||||
|
if(sender.hasPermission("rscp.admin")) |
||||||
|
throw new CommandAnswerException("Not enough permissions."); |
||||||
|
args = Arrays.copyOfRange(args, 1, args.length); |
||||||
|
if(args.length == 0) |
||||||
|
throw new CommandAnswerException("Read help."); |
||||||
|
RowEntity entity = null; |
||||||
|
Player player = null; |
||||||
|
if(type) |
||||||
|
{ |
||||||
|
player = BukkitUtilities.findOnlinePlayer(args[0]); |
||||||
|
if(player != null) |
||||||
|
args[1] = player.getName(); |
||||||
|
} else |
||||||
|
entity = rscp.internalCache.findGroupEntity(args[0]); |
||||||
|
final ResolutionResult result = (player != null) |
||||||
|
? rscp.permissionManager.getResult(player) |
||||||
|
: rscp.permissionManager.getResult(args[0]); |
||||||
|
if(player == null && entity == null) |
||||||
|
throw new CommandAnswerException("I don't know him."); |
||||||
|
switch(args[1].toLowerCase()) |
||||||
|
{ |
||||||
|
case "prefix": |
||||||
|
case "p": |
||||||
|
if(player != null) |
||||||
|
viewCalculatedPrefix(result, args[1]); |
||||||
|
else |
||||||
|
viewEntityPrefix(entity); |
||||||
|
break; |
||||||
|
case "suffix": |
||||||
|
case "s": |
||||||
|
if(player != null) |
||||||
|
viewCalculatedSuffix(result, args[1]); |
||||||
|
else |
||||||
|
viewEntitySuffix(entity); |
||||||
|
break; |
||||||
|
case "listpermissions": |
||||||
|
case "lp": |
||||||
|
listFinalPlayerPermissions(result, args[1]); |
||||||
|
break; |
||||||
|
case "listgroups": |
||||||
|
case "lg": |
||||||
|
listUserGroupsTree(result, args[1]); |
||||||
|
break; |
||||||
|
case "addparent": |
||||||
|
case "addgroup": |
||||||
|
case "ap": |
||||||
|
case "ag": |
||||||
|
// TO DO HERE
|
||||||
|
addGroup(result, args[1], null, null, null); |
||||||
|
break; |
||||||
|
case "removeparent": |
||||||
|
case "removegroup": |
||||||
|
case "rp": |
||||||
|
case "rg": |
||||||
|
// TO DO HERE
|
||||||
|
removeGroup(result, args[1], null); |
||||||
|
break; |
||||||
|
default: |
||||||
|
break; |
||||||
|
} |
||||||
|
} |
||||||
|
private void viewEntityPrefix(RowEntity entity) throws CommandAnswerException |
||||||
|
{ |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
answer.add("Own prefix for " + (entity.entityType == EntityType.GROUP ? "group" : "user") |
||||||
|
+ " {_YL}" + entity.entity + "{_LS} is:"); |
||||||
|
answer.add("{_R}\"" + (entity.prefix != null ? entity.prefix : "") + "{_R}\""); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void viewEntitySuffix(RowEntity entity) throws CommandAnswerException |
||||||
|
{ |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
answer.add("Own suffix for " + (entity.entityType == EntityType.GROUP ? "group" : "user") |
||||||
|
+ " {_YL}" + entity.entity + "{_LS} is:"); |
||||||
|
answer.add("{_R}\"" + (entity.suffix != null ? entity.suffix : "") + "{_R}\""); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void viewCalculatedPrefix(ResolutionResult result, String user) throws CommandAnswerException |
||||||
|
{ |
||||||
|
if(Matchers.isCorrectDashlessUUID(user)) |
||||||
|
user = Matchers.uuidAddDashes(user); |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
answer.add("Calculated prefix for user {_YL}" + user + "{_LS} is:"); |
||||||
|
answer.add("{_R}\"" + result.getPrefix() + "{_R}\""); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void viewCalculatedSuffix(ResolutionResult result, String user) throws CommandAnswerException |
||||||
|
{ |
||||||
|
if(Matchers.isCorrectDashlessUUID(user)) |
||||||
|
user = Matchers.uuidAddDashes(user); |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
answer.add("Calculated suffix for user {_YL}" + user + "{_LS} is:"); |
||||||
|
answer.add("{_R}\"" + result.getSuffix() + "{_R}\""); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void listFinalPlayerPermissions(ResolutionResult result, String user) throws CommandAnswerException |
||||||
|
{ |
||||||
|
if(Matchers.isCorrectDashlessUUID(user)) |
||||||
|
user = Matchers.uuidAddDashes(user); |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
answer.add("Permission list for user {_YL}" + user + "{_LS}:"); |
||||||
|
for(Map.Entry<String, Boolean> entry : result.getPermissions().entrySet()) |
||||||
|
answer.add((entry.getValue() ? "{_LG}" : "{_LR}") + entry.getKey()); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void listUserGroupsTree(ResolutionResult result, String user) throws CommandAnswerException |
||||||
|
{ |
||||||
|
if(Matchers.isCorrectDashlessUUID(user)) |
||||||
|
user = Matchers.uuidAddDashes(user); |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
answer.add("Group list for user {_YL}" + user + "{_LS}:"); |
||||||
|
for(String group : result.getOrderedGroups()) |
||||||
|
answer.add("{_LG}" + group); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void addGroup(ResolutionResult result, String user, String parent, String destination, Integer seconds) throws CommandAnswerException |
||||||
|
{ |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
private void removeGroup(ResolutionResult result, String user, String parent) throws CommandAnswerException |
||||||
|
{ |
||||||
|
final ArrayList<String> answer = new ArrayList<>(); |
||||||
|
throw new CommandAnswerException(answer); |
||||||
|
} |
||||||
|
} |
@ -1,124 +0,0 @@ |
|||||||
package ru.simsonic.rscPermissions.Bukkit.Commands; |
|
||||||
|
|
||||||
import java.util.ArrayList; |
|
||||||
import org.bukkit.command.CommandSender; |
|
||||||
import ru.simsonic.rscMinecraftLibrary.Bukkit.CommandAnswerException; |
|
||||||
import ru.simsonic.rscPermissions.BukkitPluginMain; |
|
||||||
import ru.simsonic.rscPermissions.Engine.Backends.DatabaseEditor; |
|
||||||
import ru.simsonic.rscPermissions.Engine.ResolutionResult; |
|
||||||
|
|
||||||
public class CommandGroup |
|
||||||
{ |
|
||||||
private final BukkitPluginMain rscp; |
|
||||||
CommandGroup(BukkitPluginMain plugin) |
|
||||||
{ |
|
||||||
this.rscp = plugin; |
|
||||||
} |
|
||||||
public void onGroupCommandHub(CommandSender sender, String[] args) throws CommandAnswerException |
|
||||||
{ |
|
||||||
/* |
|
||||||
/rscp - command |
|
||||||
group - 0 |
|
||||||
<entity> - 1 |
|
||||||
*/ |
|
||||||
if(sender.hasPermission("rscp.admin")) |
|
||||||
{ |
|
||||||
/* |
|
||||||
if(args.length < 3) |
|
||||||
return; |
|
||||||
final Player player = BukkitUtilities.findOnlinePlayer(args[1]); |
|
||||||
if(player != null) |
|
||||||
args[1] = player.getName(); |
|
||||||
final ResolutionResult result = (player != null) |
|
||||||
? rscp.permissionManager.getResult(player) |
|
||||||
: rscp.permissionManager.getResult(args[1]); |
|
||||||
switch(args[2].toLowerCase()) |
|
||||||
{ |
|
||||||
case "prefix": |
|
||||||
case "p": |
|
||||||
viewPrefix(result, args[1]); |
|
||||||
break; |
|
||||||
case "suffix": |
|
||||||
case "s": |
|
||||||
viewSuffix(result, args[1]); |
|
||||||
break; |
|
||||||
case "listpermissions": |
|
||||||
case "lp": |
|
||||||
listPermissions(result, args[1]); |
|
||||||
break; |
|
||||||
case "listgroups": |
|
||||||
case "lg": |
|
||||||
listGroups(result, args[1]); |
|
||||||
break; |
|
||||||
case "addgroup": |
|
||||||
case "ag": |
|
||||||
// TO DO HERE
|
|
||||||
addGroup(result, args[1], null, null, null); |
|
||||||
break; |
|
||||||
case "removegroup": |
|
||||||
case "rg": |
|
||||||
// TO DO HERE
|
|
||||||
removeGroup(result, args[1], null); |
|
||||||
break; |
|
||||||
default: |
|
||||||
break; |
|
||||||
} |
|
||||||
*/ |
|
||||||
} else |
|
||||||
throw new CommandAnswerException("Not enough permissions."); |
|
||||||
} |
|
||||||
/* |
|
||||||
private void viewPrefix(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Calculated prefix for user {_YL}" + user + "{_LS} is:"); |
|
||||||
answer.add("{_R}\"" + result.prefix + "{_R}\""); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void viewSuffix(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Calculated suffix for user {_YL}" + user + "{_LS} is:"); |
|
||||||
answer.add("{_R}\"" + result.suffix + "{_R}\""); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void listPermissions(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Permission list for user {_YL}" + user + "{_LS}:"); |
|
||||||
final ArrayList<String> sorted_keys = new ArrayList<>(result.permissions.keySet()); |
|
||||||
Collections.sort(sorted_keys); |
|
||||||
for(String perm : sorted_keys) |
|
||||||
answer.add((result.permissions.get(perm) ? "{_LG}" : "{_LR}") + perm); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void listGroups(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Group list for user {_YL}" + user + "{_LS}:"); |
|
||||||
for(String group : result.getOrderedGroups()) |
|
||||||
answer.add("{_LG}" + group); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
*/ |
|
||||||
private void addGroup(ResolutionResult result, String group, String parent, String destination, Integer seconds) throws CommandAnswerException |
|
||||||
{ |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
final DatabaseEditor databaseTransaction = new DatabaseEditor(rscp); |
|
||||||
databaseTransaction.apply(); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void removeGroup(ResolutionResult result, String group, String parent) throws CommandAnswerException |
|
||||||
{ |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
} |
|
@ -1,122 +0,0 @@ |
|||||||
package ru.simsonic.rscPermissions.Bukkit.Commands; |
|
||||||
|
|
||||||
import java.util.ArrayList; |
|
||||||
import java.util.Map; |
|
||||||
import org.bukkit.command.CommandSender; |
|
||||||
import org.bukkit.entity.Player; |
|
||||||
import ru.simsonic.rscMinecraftLibrary.Bukkit.CommandAnswerException; |
|
||||||
import ru.simsonic.rscPermissions.Bukkit.BukkitUtilities; |
|
||||||
import ru.simsonic.rscPermissions.BukkitPluginMain; |
|
||||||
import ru.simsonic.rscPermissions.Engine.Backends.DatabaseEditor; |
|
||||||
import ru.simsonic.rscPermissions.Engine.Matchers; |
|
||||||
import ru.simsonic.rscPermissions.Engine.ResolutionResult; |
|
||||||
|
|
||||||
public class CommandUser |
|
||||||
{ |
|
||||||
private final BukkitPluginMain rscp; |
|
||||||
CommandUser(BukkitPluginMain plugin) |
|
||||||
{ |
|
||||||
this.rscp = plugin; |
|
||||||
} |
|
||||||
public void onUserCommandHub(CommandSender sender, String[] args) throws CommandAnswerException |
|
||||||
{ |
|
||||||
/* |
|
||||||
/rscp - command |
|
||||||
user - 0 |
|
||||||
<entity> - 1 // -u; --by-uuid / -n (--by-name)
|
|
||||||
*/ |
|
||||||
if(sender.hasPermission("rscp.admin")) |
|
||||||
{ |
|
||||||
if(args.length < 3) |
|
||||||
return; |
|
||||||
final Player player = BukkitUtilities.findOnlinePlayer(args[1]); |
|
||||||
if(player != null) |
|
||||||
args[1] = player.getName(); |
|
||||||
final ResolutionResult result = (player != null) |
|
||||||
? rscp.permissionManager.getResult(player) |
|
||||||
: rscp.permissionManager.getResult(args[1]); |
|
||||||
switch(args[2].toLowerCase()) |
|
||||||
{ |
|
||||||
case "prefix": |
|
||||||
case "p": |
|
||||||
viewPrefix(result, args[1]); |
|
||||||
break; |
|
||||||
case "suffix": |
|
||||||
case "s": |
|
||||||
viewSuffix(result, args[1]); |
|
||||||
break; |
|
||||||
case "listpermissions": |
|
||||||
case "lp": |
|
||||||
listPermissions(result, args[1]); |
|
||||||
break; |
|
||||||
case "listgroups": |
|
||||||
case "lg": |
|
||||||
listGroups(result, args[1]); |
|
||||||
break; |
|
||||||
case "addgroup": |
|
||||||
case "ag": |
|
||||||
// TO DO HERE
|
|
||||||
addGroup(result, args[1], null, null, null); |
|
||||||
break; |
|
||||||
case "removegroup": |
|
||||||
case "rg": |
|
||||||
// TO DO HERE
|
|
||||||
removeGroup(result, args[1], null); |
|
||||||
break; |
|
||||||
default: |
|
||||||
break; |
|
||||||
} |
|
||||||
} else |
|
||||||
throw new CommandAnswerException("Not enough permissions."); |
|
||||||
} |
|
||||||
private void viewPrefix(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Calculated prefix for user {_YL}" + user + "{_LS} is:"); |
|
||||||
answer.add("{_R}\"" + result.getPrefix() + "{_R}\""); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void viewSuffix(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Calculated suffix for user {_YL}" + user + "{_LS} is:"); |
|
||||||
answer.add("{_R}\"" + result.getSuffix() + "{_R}\""); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void listPermissions(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Permission list for user {_YL}" + user + "{_LS}:"); |
|
||||||
for(Map.Entry<String, Boolean> entry : result.getPermissions().entrySet()) |
|
||||||
answer.add((entry.getValue() ? "{_LG}" : "{_LR}") + entry.getKey()); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void listGroups(ResolutionResult result, String user) throws CommandAnswerException |
|
||||||
{ |
|
||||||
if(Matchers.isCorrectDashlessUUID(user)) |
|
||||||
user = Matchers.uuidAddDashes(user); |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
answer.add("Group list for user {_YL}" + user + "{_LS}:"); |
|
||||||
for(String group : result.getOrderedGroups()) |
|
||||||
answer.add("{_LG}" + group); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void addGroup(ResolutionResult result, String user, String parent, String destination, Integer seconds) throws CommandAnswerException |
|
||||||
{ |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
final DatabaseEditor databaseTransaction = new DatabaseEditor(rscp); |
|
||||||
databaseTransaction.apply(); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
private void removeGroup(ResolutionResult result, String user, String parent) throws CommandAnswerException |
|
||||||
{ |
|
||||||
final ArrayList<String> answer = new ArrayList<>(); |
|
||||||
throw new CommandAnswerException(answer); |
|
||||||
} |
|
||||||
} |
|
Loading…
Reference in new issue