12 changed files with 275 additions and 98 deletions
@ -0,0 +1,109 @@ |
|||||||
|
package ru.simsonic.rscPermissions.Bukkit.Commands; |
||||||
|
|
||||||
|
import java.util.ArrayList; |
||||||
|
import java.util.Collections; |
||||||
|
import org.bukkit.command.CommandSender; |
||||||
|
import org.bukkit.entity.Player; |
||||||
|
import ru.simsonic.rscMinecraftLibrary.Bukkit.CommandAnswerException; |
||||||
|
import ru.simsonic.rscPermissions.BukkitPluginMain; |
||||||
|
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 |
||||||
|
{ |
||||||
|
if(sender.hasPermission("rscp.admin")) |
||||||
|
{ |
||||||
|
if(args.length < 3) |
||||||
|
return; |
||||||
|
final Player player = rscp.bridgeForBukkit.findPlayer(args[1]); |
||||||
|
if(player != null) |
||||||
|
args[1] = player.getName(); |
||||||
|
final ResolutionResult result = (player != null) |
||||||
|
? rscp.permissionManager.getResult(player) |
||||||
|
: rscp.permissionManager.getResult(args[1]); |
||||||
|
if(Matchers.isCorrectDashlessUUID(args[1])) |
||||||
|
args[1] = Matchers.uuidAddDashes(args[1]); |
||||||
|
switch(args[2].toLowerCase()) |
||||||
|
{ |
||||||
|
case "p": |
||||||
|
case "prefix": |
||||||
|
viewPrefix(result, args[1]); |
||||||
|
break; |
||||||
|
case "s": |
||||||
|
case "suffix": |
||||||
|
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 |
||||||
|
{ |
||||||
|
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 |
||||||
|
{ |
||||||
|
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 |
||||||
|
{ |
||||||
|
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 |
||||||
|
{ |
||||||
|
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); |
||||||
|
} |
||||||
|
} |
@ -0,0 +1,11 @@ |
|||||||
|
package ru.simsonic.rscPermissions.Engine.Backends; |
||||||
|
|
||||||
|
import ru.simsonic.rscPermissions.API.RowInheritance; |
||||||
|
import ru.simsonic.rscPermissions.API.RowPermission; |
||||||
|
|
||||||
|
public class DatabaseAction |
||||||
|
{ |
||||||
|
public int id; |
||||||
|
public RowPermission permissions; |
||||||
|
public RowInheritance inheritance; |
||||||
|
} |
@ -0,0 +1,56 @@ |
|||||||
|
package ru.simsonic.rscPermissions.Engine.Backends; |
||||||
|
|
||||||
|
import java.util.LinkedList; |
||||||
|
import java.util.List; |
||||||
|
import ru.simsonic.rscMinecraftLibrary.Bukkit.CommandAnswerException; |
||||||
|
import ru.simsonic.rscPermissions.BukkitPluginMain; |
||||||
|
|
||||||
|
public class DatabaseTransaction |
||||||
|
{ |
||||||
|
private final BukkitPluginMain rscp; |
||||||
|
private final List<DatabaseAction> actions = new LinkedList<>(); |
||||||
|
public DatabaseTransaction(BukkitPluginMain rscp) |
||||||
|
{ |
||||||
|
this.rscp = rscp; |
||||||
|
} |
||||||
|
/* |
||||||
|
What can happen? |
||||||
|
<user> add permission [destination] [lifetime] |
||||||
|
<user> remove permission [destination] |
||||||
|
<user> add group [destination] [lifitime] |
||||||
|
<user> remove group [destination] |
||||||
|
*/ |
||||||
|
public void apply() throws CommandAnswerException |
||||||
|
{ |
||||||
|
// START TRANSACTION AND LOCK TABLE
|
||||||
|
rscp.connection.lockTableEntities(); |
||||||
|
rscp.connection.lockTablePermissions(); |
||||||
|
rscp.connection.lockTableInheritance(); |
||||||
|
rscp.connection.transactionStart(); |
||||||
|
|
||||||
|
// SELECT FROM DATABASE INTO LOCAL CACHE TO MAKE IT ACTUAL
|
||||||
|
final DatabaseContents contents = rscp.commandHelper.threadFetchDatabaseContents.remoteToLocal(); |
||||||
|
|
||||||
|
// UNDERSTAND WHAT TO DO
|
||||||
|
if(contents != null) |
||||||
|
{ |
||||||
|
// OPTIONAL: REMOVE OLD `id`'s WITH POTENTIALLY MULTIPLY DATA
|
||||||
|
if(false) |
||||||
|
{ |
||||||
|
// OPTIONAL: RESTORE DATA THAT SHOULDN'T BE REMOVED
|
||||||
|
} |
||||||
|
// OPTIONAL: INSERT NEW DATA THAT SHOULD BE ADDED
|
||||||
|
if(false) |
||||||
|
{ |
||||||
|
|
||||||
|
} |
||||||
|
} |
||||||
|
|
||||||
|
// COMMIT CHANGES AND UNLOCK TABLE
|
||||||
|
rscp.connection.transactionCommit(); |
||||||
|
rscp.connection.unlockAllTables(); |
||||||
|
|
||||||
|
// CALL PLUGIN TO APPLY ALL THIS CHANGES
|
||||||
|
rscp.commandHelper.threadFetchDatabaseContents.run(); |
||||||
|
} |
||||||
|
} |
Loading…
Reference in new issue