Cleanup handling of unknown/null usernames for users
This commit is contained in:
parent
43450f6cc7
commit
67b5c72520
@ -93,13 +93,23 @@ public interface Storage {
|
|||||||
* Loads a user's data from the main storage into the plugins local storage.
|
* Loads a user's data from the main storage into the plugins local storage.
|
||||||
*
|
*
|
||||||
* @param uuid the uuid of the user to load
|
* @param uuid the uuid of the user to load
|
||||||
* @param username the users username. (if you want to specify <code>null</code> here, just input "null" as a
|
* @param username the users username, or null if it is not known.
|
||||||
* string.)
|
|
||||||
* @return if the operation completed successfully
|
* @return if the operation completed successfully
|
||||||
* @throws NullPointerException if uuid or username is null
|
* @throws NullPointerException if uuid is null
|
||||||
*/
|
*/
|
||||||
CompletableFuture<Boolean> loadUser(UUID uuid, String username);
|
CompletableFuture<Boolean> loadUser(UUID uuid, String username);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads a user's data from the main storage into the plugins local storage.
|
||||||
|
*
|
||||||
|
* @param uuid the uuid of the user to load
|
||||||
|
* @return if the operation completed successfully
|
||||||
|
* @throws NullPointerException if uuid is null
|
||||||
|
*/
|
||||||
|
default CompletableFuture<Boolean> loadUser(UUID uuid) {
|
||||||
|
return loadUser(uuid, null);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Saves a user object back to storage. You should call this after you make any changes to a user.
|
* Saves a user object back to storage. You should call this after you make any changes to a user.
|
||||||
*
|
*
|
||||||
|
@ -43,7 +43,7 @@ public interface User extends PermissionHolder {
|
|||||||
UUID getUuid();
|
UUID getUuid();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the users username
|
* Gets the users username, or null if no username is associated with this user
|
||||||
*
|
*
|
||||||
* @return the Users Username
|
* @return the Users Username
|
||||||
*/
|
*/
|
||||||
|
@ -69,6 +69,6 @@ public class BukkitCalculatorFactory extends AbstractCalculatorFactory {
|
|||||||
}
|
}
|
||||||
processors.add(new DefaultsProcessor(contexts.isOp(), plugin.getDefaultsProvider()));
|
processors.add(new DefaultsProcessor(contexts.isOp(), plugin.getDefaultsProvider()));
|
||||||
|
|
||||||
return registerCalculator(new PermissionCalculator(plugin, user.getName(), processors.build()));
|
return registerCalculator(new PermissionCalculator(plugin, user.getFriendlyName(), processors.build()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -124,7 +124,7 @@ public class VaultChatHook extends Chat {
|
|||||||
world = perms.isIgnoreWorld() ? null : world;
|
world = perms.isIgnoreWorld() ? null : world;
|
||||||
node = escapeCharacters(node);
|
node = escapeCharacters(node);
|
||||||
|
|
||||||
perms.log("Getting meta: '" + node + "' for user " + user.getName() + " on world " + world + ", server " + perms.getServer());
|
perms.log("Getting meta: '" + node + "' for user " + user.getFriendlyName() + " on world " + world + ", server " + perms.getServer());
|
||||||
|
|
||||||
if (user.getUserData() == null) {
|
if (user.getUserData() == null) {
|
||||||
return defaultValue;
|
return defaultValue;
|
||||||
@ -142,7 +142,7 @@ public class VaultChatHook extends Chat {
|
|||||||
if (user == null) return "";
|
if (user == null) return "";
|
||||||
world = perms.isIgnoreWorld() ? null : world;
|
world = perms.isIgnoreWorld() ? null : world;
|
||||||
|
|
||||||
perms.log("Getting " + (prefix ? "prefix" : "suffix") + " for user " + user.getName() + " on world " + world + ", server " + perms.getServer());
|
perms.log("Getting " + (prefix ? "prefix" : "suffix") + " for user " + user.getFriendlyName() + " on world " + world + ", server " + perms.getServer());
|
||||||
|
|
||||||
if (user.getUserData() == null) {
|
if (user.getUserData() == null) {
|
||||||
return "";
|
return "";
|
||||||
|
@ -54,6 +54,6 @@ public class BungeeCalculatorFactory extends AbstractCalculatorFactory {
|
|||||||
processors.add(new WildcardProcessor());
|
processors.add(new WildcardProcessor());
|
||||||
}
|
}
|
||||||
|
|
||||||
return registerCalculator(new PermissionCalculator(plugin, user.getName(), processors.build()));
|
return registerCalculator(new PermissionCalculator(plugin, user.getFriendlyName(), processors.build()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -88,12 +88,12 @@ public class StorageDelegate implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> loadUser(UUID uuid, String username) {
|
public CompletableFuture<Boolean> loadUser(@NonNull UUID uuid, String username) {
|
||||||
return handle.force().loadUser(uuid, checkUsername(username));
|
return handle.force().loadUser(uuid, username == null ? null : checkUsername(username));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> saveUser(User user) {
|
public CompletableFuture<Boolean> saveUser(@NonNull User user) {
|
||||||
return handle.force().saveUser(UserDelegate.cast(user));
|
return handle.force().saveUser(UserDelegate.cast(user));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -113,12 +113,12 @@ public class StorageDelegate implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> createAndLoadGroup(String name) {
|
public CompletableFuture<Boolean> createAndLoadGroup(@NonNull String name) {
|
||||||
return handle.force().createAndLoadGroup(checkName(name), CreationCause.API);
|
return handle.force().createAndLoadGroup(checkName(name), CreationCause.API);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> loadGroup(String name) {
|
public CompletableFuture<Boolean> loadGroup(@NonNull String name) {
|
||||||
return handle.force().loadGroup(checkName(name));
|
return handle.force().loadGroup(checkName(name));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -128,12 +128,12 @@ public class StorageDelegate implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> saveGroup(Group group) {
|
public CompletableFuture<Boolean> saveGroup(@NonNull Group group) {
|
||||||
return handle.force().saveGroup(GroupDelegate.cast(group));
|
return handle.force().saveGroup(GroupDelegate.cast(group));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> deleteGroup(Group group) {
|
public CompletableFuture<Boolean> deleteGroup(@NonNull Group group) {
|
||||||
if (group.getName().equalsIgnoreCase(plugin.getConfiguration().get(ConfigKeys.DEFAULT_GROUP_NAME))) {
|
if (group.getName().equalsIgnoreCase(plugin.getConfiguration().get(ConfigKeys.DEFAULT_GROUP_NAME))) {
|
||||||
throw new IllegalArgumentException("Cannot delete the default group.");
|
throw new IllegalArgumentException("Cannot delete the default group.");
|
||||||
}
|
}
|
||||||
@ -146,12 +146,12 @@ public class StorageDelegate implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> createAndLoadTrack(String name) {
|
public CompletableFuture<Boolean> createAndLoadTrack(@NonNull String name) {
|
||||||
return handle.force().createAndLoadTrack(checkName(name), CreationCause.API);
|
return handle.force().createAndLoadTrack(checkName(name), CreationCause.API);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> loadTrack(String name) {
|
public CompletableFuture<Boolean> loadTrack(@NonNull String name) {
|
||||||
return handle.force().loadTrack(checkName(name));
|
return handle.force().loadTrack(checkName(name));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -161,22 +161,22 @@ public class StorageDelegate implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> saveTrack(Track track) {
|
public CompletableFuture<Boolean> saveTrack(@NonNull Track track) {
|
||||||
return handle.force().saveTrack(TrackDelegate.cast(track));
|
return handle.force().saveTrack(TrackDelegate.cast(track));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> deleteTrack(Track track) {
|
public CompletableFuture<Boolean> deleteTrack(@NonNull Track track) {
|
||||||
return handle.force().deleteTrack(TrackDelegate.cast(track), DeletionCause.API);
|
return handle.force().deleteTrack(TrackDelegate.cast(track), DeletionCause.API);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<Boolean> saveUUIDData(String username, UUID uuid) {
|
public CompletableFuture<Boolean> saveUUIDData(@NonNull String username, @NonNull UUID uuid) {
|
||||||
return handle.force().saveUUIDData(checkUsername(username), uuid);
|
return handle.force().saveUUIDData(checkUsername(username), uuid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CompletableFuture<UUID> getUUID(String username) {
|
public CompletableFuture<UUID> getUUID(@NonNull String username) {
|
||||||
return handle.force().getUUID(checkUsername(username));
|
return handle.force().getUUID(checkUsername(username));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,9 +49,9 @@ import static me.lucko.luckperms.common.api.ApiUtils.checkTime;
|
|||||||
* Provides a link between {@link User} and {@link me.lucko.luckperms.common.core.model.User}
|
* Provides a link between {@link User} and {@link me.lucko.luckperms.common.core.model.User}
|
||||||
*/
|
*/
|
||||||
public final class UserDelegate extends PermissionHolderDelegate implements User {
|
public final class UserDelegate extends PermissionHolderDelegate implements User {
|
||||||
public static me.lucko.luckperms.common.core.model.User cast(User g) {
|
public static me.lucko.luckperms.common.core.model.User cast(User u) {
|
||||||
Preconditions.checkState(g instanceof UserDelegate, "Illegal instance " + g.getClass() + " cannot be handled by this implementation.");
|
Preconditions.checkState(u instanceof UserDelegate, "Illegal instance " + u.getClass() + " cannot be handled by this implementation.");
|
||||||
return ((UserDelegate) g).getHandle();
|
return ((UserDelegate) u).getHandle();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Getter
|
@Getter
|
||||||
@ -69,7 +69,7 @@ public final class UserDelegate extends PermissionHolderDelegate implements User
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getName() {
|
public String getName() {
|
||||||
return handle.getName();
|
return handle.getName().orElse(null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -73,12 +73,12 @@ public class CheckCommand extends SingleCommand {
|
|||||||
|
|
||||||
UserCache data = user.getUserData();
|
UserCache data = user.getUserData();
|
||||||
if (data == null) {
|
if (data == null) {
|
||||||
Message.USER_NO_DATA.send(sender, user.getName());
|
Message.USER_NO_DATA.send(sender, user.getFriendlyName());
|
||||||
return CommandResult.STATE_ERROR;
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
Tristate tristate = data.getPermissionData(plugin.getContextForUser(user)).getPermissionValue(permission);
|
Tristate tristate = data.getPermissionData(plugin.getContextForUser(user)).getPermissionValue(permission);
|
||||||
Message.CHECK_RESULT.send(sender, user.getName(), permission, Util.formatTristate(tristate));
|
Message.CHECK_RESULT.send(sender, user.getFriendlyName(), permission, Util.formatTristate(tristate));
|
||||||
return CommandResult.SUCCESS;
|
return CommandResult.SUCCESS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -92,7 +92,7 @@ public class TreeCommand extends SingleCommand {
|
|||||||
|
|
||||||
UserCache data = user.getUserData();
|
UserCache data = user.getUserData();
|
||||||
if (data == null) {
|
if (data == null) {
|
||||||
Message.USER_NO_DATA.send(sender, user.getName());
|
Message.USER_NO_DATA.send(sender, user.getFriendlyName());
|
||||||
return CommandResult.STATE_ERROR;
|
return CommandResult.STATE_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -106,7 +106,7 @@ public class TreeCommand extends SingleCommand {
|
|||||||
|
|
||||||
Message.TREE_UPLOAD_START.send(sender);
|
Message.TREE_UPLOAD_START.send(sender);
|
||||||
|
|
||||||
String url = view.uploadPasteData(plugin.getVersion(), user.getName(), permissionData);
|
String url = view.uploadPasteData(plugin.getVersion(), user.getFriendlyName(), permissionData);
|
||||||
if (url == null) {
|
if (url == null) {
|
||||||
url = "null";
|
url = "null";
|
||||||
}
|
}
|
||||||
|
@ -125,7 +125,7 @@ public class UserDemote extends SubCommand<User> {
|
|||||||
|
|
||||||
user.unsetPermission(oldNode);
|
user.unsetPermission(oldNode);
|
||||||
|
|
||||||
Message.USER_DEMOTE_ENDOFTRACK.send(sender, track.getName(), user.getName(), old);
|
Message.USER_DEMOTE_ENDOFTRACK.send(sender, track.getName(), user.getFriendlyName(), old);
|
||||||
|
|
||||||
LogEntry.build().actor(sender).acted(user)
|
LogEntry.build().actor(sender).acted(user)
|
||||||
.action("demote " + args.stream().collect(Collectors.joining(" ")))
|
.action("demote " + args.stream().collect(Collectors.joining(" ")))
|
||||||
|
@ -54,7 +54,7 @@ public class UserInfo extends SubCommand<User> {
|
|||||||
@Override
|
@Override
|
||||||
public CommandResult execute(LuckPermsPlugin plugin, Sender sender, User user, List<String> args, String label) throws CommandException {
|
public CommandResult execute(LuckPermsPlugin plugin, Sender sender, User user, List<String> args, String label) throws CommandException {
|
||||||
Message.USER_INFO_GENERAL.send(sender,
|
Message.USER_INFO_GENERAL.send(sender,
|
||||||
user.getName(),
|
user.getName().orElse("Unknown"),
|
||||||
user.getUuid(),
|
user.getUuid(),
|
||||||
plugin.getPlayerStatus(user.getUuid()),
|
plugin.getPlayerStatus(user.getUuid()),
|
||||||
user.getPrimaryGroup().getValue(),
|
user.getPrimaryGroup().getValue(),
|
||||||
|
@ -106,13 +106,13 @@ public class UserPromote extends SubCommand<User> {
|
|||||||
|
|
||||||
Group nextGroup = plugin.getGroupManager().getIfLoaded(first);
|
Group nextGroup = plugin.getGroupManager().getIfLoaded(first);
|
||||||
if (nextGroup == null) {
|
if (nextGroup == null) {
|
||||||
Message.USER_PROMOTE_ERROR_MALFORMED.send(sender, false);
|
Message.USER_PROMOTE_ERROR_MALFORMED.send(sender, first);
|
||||||
return CommandResult.LOADING_ERROR;
|
return CommandResult.LOADING_ERROR;
|
||||||
}
|
}
|
||||||
|
|
||||||
user.setPermission(NodeFactory.newBuilder("group." + first).withExtraContext(context).build());
|
user.setPermission(NodeFactory.newBuilder("group." + first).withExtraContext(context).build());
|
||||||
|
|
||||||
Message.USER_TRACK_ADDED_TO_FIRST.send(sender, user.getName(), first, Util.contextSetToString(context));
|
Message.USER_TRACK_ADDED_TO_FIRST.send(sender, user.getFriendlyName(), first, Util.contextSetToString(context));
|
||||||
LogEntry.build().actor(sender).acted(user)
|
LogEntry.build().actor(sender).acted(user)
|
||||||
.action("promote " + args.stream().collect(Collectors.joining(" ")))
|
.action("promote " + args.stream().collect(Collectors.joining(" ")))
|
||||||
.build().submit(plugin, sender);
|
.build().submit(plugin, sender);
|
||||||
|
@ -68,12 +68,12 @@ public class UserSwitchPrimaryGroup extends SubCommand<User> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!user.inheritsGroup(group)) {
|
if (!user.inheritsGroup(group)) {
|
||||||
Message.USER_PRIMARYGROUP_ERROR_NOTMEMBER.send(sender, user.getName(), group.getName());
|
Message.USER_PRIMARYGROUP_ERROR_NOTMEMBER.send(sender, user.getFriendlyName(), group.getName());
|
||||||
user.setInheritGroup(group, ContextSet.empty());
|
user.setInheritGroup(group, ContextSet.empty());
|
||||||
}
|
}
|
||||||
|
|
||||||
user.getPrimaryGroup().setStoredValue(group.getName());
|
user.getPrimaryGroup().setStoredValue(group.getName());
|
||||||
Message.USER_PRIMARYGROUP_SUCCESS.send(sender, user.getName(), group.getDisplayName());
|
Message.USER_PRIMARYGROUP_SUCCESS.send(sender, user.getFriendlyName(), group.getDisplayName());
|
||||||
LogEntry.build().actor(sender).acted(user)
|
LogEntry.build().actor(sender).acted(user)
|
||||||
.action("setprimarygroup " + group.getName())
|
.action("setprimarygroup " + group.getName())
|
||||||
.build().submit(plugin, sender);
|
.build().submit(plugin, sender);
|
||||||
|
@ -33,20 +33,29 @@ import lombok.ToString;
|
|||||||
|
|
||||||
import me.lucko.luckperms.common.utils.Identifiable;
|
import me.lucko.luckperms.common.utils.Identifiable;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@Getter
|
|
||||||
@ToString
|
@ToString
|
||||||
@EqualsAndHashCode(of = "uuid")
|
@EqualsAndHashCode(of = "uuid")
|
||||||
@AllArgsConstructor(access = AccessLevel.PRIVATE)
|
@AllArgsConstructor(access = AccessLevel.PRIVATE)
|
||||||
public final class UserIdentifier implements Identifiable<UUID> {
|
public final class UserIdentifier implements Identifiable<UUID> {
|
||||||
public static UserIdentifier of(UUID uuid, String username) {
|
public static UserIdentifier of(UUID uuid, String username) {
|
||||||
|
if (username == null || username.equalsIgnoreCase("null") || username.isEmpty()) {
|
||||||
|
username = null;
|
||||||
|
}
|
||||||
|
|
||||||
return new UserIdentifier(uuid, username);
|
return new UserIdentifier(uuid, username);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Getter
|
||||||
private final UUID uuid;
|
private final UUID uuid;
|
||||||
private final String username;
|
private final String username;
|
||||||
|
|
||||||
|
public Optional<String> getUsername() {
|
||||||
|
return Optional.ofNullable(username);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UUID getId() {
|
public UUID getId() {
|
||||||
return getUuid();
|
return getUuid();
|
||||||
|
@ -27,7 +27,6 @@ package me.lucko.luckperms.common.core.model;
|
|||||||
|
|
||||||
import lombok.EqualsAndHashCode;
|
import lombok.EqualsAndHashCode;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import lombok.Setter;
|
|
||||||
import lombok.ToString;
|
import lombok.ToString;
|
||||||
|
|
||||||
import me.lucko.luckperms.api.caching.UserData;
|
import me.lucko.luckperms.api.caching.UserData;
|
||||||
@ -42,6 +41,7 @@ import me.lucko.luckperms.common.primarygroup.PrimaryGroupHolder;
|
|||||||
import me.lucko.luckperms.common.utils.BufferedRequest;
|
import me.lucko.luckperms.common.utils.BufferedRequest;
|
||||||
import me.lucko.luckperms.common.utils.Identifiable;
|
import me.lucko.luckperms.common.utils.Identifiable;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@ToString(of = {"uuid"})
|
@ToString(of = {"uuid"})
|
||||||
@ -57,9 +57,7 @@ public class User extends PermissionHolder implements Identifiable<UserIdentifie
|
|||||||
/**
|
/**
|
||||||
* The last known username of a player
|
* The last known username of a player
|
||||||
*/
|
*/
|
||||||
@Getter
|
private String name = null;
|
||||||
@Setter
|
|
||||||
private String name;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The users primary group
|
* The users primary group
|
||||||
@ -88,14 +86,14 @@ public class User extends PermissionHolder implements Identifiable<UserIdentifie
|
|||||||
public User(UUID uuid, LuckPermsPlugin plugin) {
|
public User(UUID uuid, LuckPermsPlugin plugin) {
|
||||||
super(uuid.toString(), plugin);
|
super(uuid.toString(), plugin);
|
||||||
this.uuid = uuid;
|
this.uuid = uuid;
|
||||||
this.name = null;
|
|
||||||
this.primaryGroup = plugin.getConfiguration().get(ConfigKeys.PRIMARY_GROUP_CALCULATION).apply(this);
|
this.primaryGroup = plugin.getConfiguration().get(ConfigKeys.PRIMARY_GROUP_CALCULATION).apply(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public User(UUID uuid, String name, LuckPermsPlugin plugin) {
|
public User(UUID uuid, String name, LuckPermsPlugin plugin) {
|
||||||
super(uuid.toString(), plugin);
|
super(uuid.toString(), plugin);
|
||||||
this.uuid = uuid;
|
this.uuid = uuid;
|
||||||
this.name = name;
|
setName(name, true);
|
||||||
|
|
||||||
this.primaryGroup = plugin.getConfiguration().get(ConfigKeys.PRIMARY_GROUP_CALCULATION).apply(this);
|
this.primaryGroup = plugin.getConfiguration().get(ConfigKeys.PRIMARY_GROUP_CALCULATION).apply(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,9 +102,49 @@ public class User extends PermissionHolder implements Identifiable<UserIdentifie
|
|||||||
return UserIdentifier.of(uuid, name);
|
return UserIdentifier.of(uuid, name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Optional<String> getName() {
|
||||||
|
return Optional.ofNullable(name);
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean setName(String name, boolean force) {
|
||||||
|
// if the value being set is null
|
||||||
|
if (name == null || name.equalsIgnoreCase("null") || name.isEmpty()) {
|
||||||
|
// only apply the change if it is being forced
|
||||||
|
if (force) {
|
||||||
|
// if the name is already null, return false
|
||||||
|
if (this.name == null) {
|
||||||
|
return false;
|
||||||
|
} else {
|
||||||
|
// set the new null value
|
||||||
|
this.name = null;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// we already have a non-null value, so return false
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// the name being set is not null
|
||||||
|
if (this.name == null) {
|
||||||
|
this.name = name;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// update the capitalisation, but still return false
|
||||||
|
if (this.name.equalsIgnoreCase(name)) {
|
||||||
|
this.name = name;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// completely new value, just set & return true
|
||||||
|
this.name = name;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getFriendlyName() {
|
public String getFriendlyName() {
|
||||||
return name;
|
return name != null ? name : uuid.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -217,7 +217,7 @@ public class Exporter implements Runnable {
|
|||||||
|
|
||||||
plugin.getStorage().loadUser(uuid, "null").join();
|
plugin.getStorage().loadUser(uuid, "null").join();
|
||||||
User user = plugin.getUserManager().get(uuid);
|
User user = plugin.getUserManager().get(uuid);
|
||||||
output.add("# Export user: " + user.getUuid().toString() + " - " + user.getName());
|
output.add("# Export user: " + user.getUuid().toString() + " - " + user.getName().orElse("unknown username"));
|
||||||
|
|
||||||
boolean inDefault = false;
|
boolean inDefault = false;
|
||||||
for (Node node : user.getNodes().values()) {
|
for (Node node : user.getNodes().values()) {
|
||||||
|
@ -116,7 +116,7 @@ public class LogEntry extends me.lucko.luckperms.api.LogEntry {
|
|||||||
|
|
||||||
public LogEntryBuilder acted(PermissionHolder acted) {
|
public LogEntryBuilder acted(PermissionHolder acted) {
|
||||||
if (acted instanceof User) {
|
if (acted instanceof User) {
|
||||||
super.actedName(((User) acted).getName());
|
super.actedName(((User) acted).getName().orElse("null"));
|
||||||
super.acted(((User) acted).getUuid());
|
super.acted(((User) acted).getUuid());
|
||||||
super.type('U');
|
super.type('U');
|
||||||
} else if (acted instanceof Group) {
|
} else if (acted instanceof Group) {
|
||||||
|
@ -35,6 +35,7 @@ import me.lucko.luckperms.common.managers.AbstractManager;
|
|||||||
import me.lucko.luckperms.common.managers.UserManager;
|
import me.lucko.luckperms.common.managers.UserManager;
|
||||||
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
import me.lucko.luckperms.common.plugin.LuckPermsPlugin;
|
||||||
|
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
@ -105,15 +106,16 @@ public class GenericUserManager extends AbstractManager<UserIdentifier, User> im
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public User apply(UserIdentifier id) {
|
public User apply(UserIdentifier id) {
|
||||||
return id.getUsername() == null ?
|
return !id.getUsername().isPresent() ?
|
||||||
new User(id.getUuid(), plugin) :
|
new User(id.getUuid(), plugin) :
|
||||||
new User(id.getUuid(), id.getUsername(), plugin);
|
new User(id.getUuid(), id.getUsername().get(), plugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public User getByUsername(String name) {
|
public User getByUsername(String name) {
|
||||||
for (User user : getAll().values()) {
|
for (User user : getAll().values()) {
|
||||||
if (user.getName().equalsIgnoreCase(name)) {
|
Optional<String> n = user.getName();
|
||||||
|
if (n.isPresent() && n.get().equalsIgnoreCase(name)) {
|
||||||
return user;
|
return user;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -180,7 +180,7 @@ public abstract class FlatfileBacking extends AbstractBacking {
|
|||||||
|
|
||||||
User u = plugin.getUserManager().get(uuid);
|
User u = plugin.getUserManager().get(uuid);
|
||||||
if (u != null) {
|
if (u != null) {
|
||||||
plugin.getLog().info("[FileWatcher] Refreshing user " + u.getName());
|
plugin.getLog().info("[FileWatcher] Refreshing user " + u.getFriendlyName());
|
||||||
plugin.getStorage().loadUser(uuid, "null");
|
plugin.getStorage().loadUser(uuid, "null");
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -176,12 +176,8 @@ public class JSONBacking extends FlatfileBacking {
|
|||||||
|
|
||||||
boolean save = plugin.getUserManager().giveDefaultIfNeeded(user, false);
|
boolean save = plugin.getUserManager().giveDefaultIfNeeded(user, false);
|
||||||
|
|
||||||
if (user.getName() == null || user.getName().equalsIgnoreCase("null")) {
|
if (user.setName(name, false)) {
|
||||||
user.setName(name);
|
save = true;
|
||||||
} else {
|
|
||||||
if (!name.equalsIgnoreCase(user.getName())) {
|
|
||||||
save = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (save) {
|
if (save) {
|
||||||
@ -230,7 +226,7 @@ public class JSONBacking extends FlatfileBacking {
|
|||||||
|
|
||||||
JsonObject data = new JsonObject();
|
JsonObject data = new JsonObject();
|
||||||
data.addProperty("uuid", user.getUuid().toString());
|
data.addProperty("uuid", user.getUuid().toString());
|
||||||
data.addProperty("name", user.getName());
|
data.addProperty("name", user.getName().orElse("null"));
|
||||||
data.addProperty("primaryGroup", user.getPrimaryGroup().getStoredValue());
|
data.addProperty("primaryGroup", user.getPrimaryGroup().getStoredValue());
|
||||||
|
|
||||||
Set<NodeModel> nodes = user.getNodes().values().stream().map(NodeModel::fromNode).collect(Collectors.toCollection(LinkedHashSet::new));
|
Set<NodeModel> nodes = user.getNodes().values().stream().map(NodeModel::fromNode).collect(Collectors.toCollection(LinkedHashSet::new));
|
||||||
|
@ -98,7 +98,7 @@ public class MongoDBBacking extends AbstractBacking {
|
|||||||
|
|
||||||
private static Document fromUser(User user) {
|
private static Document fromUser(User user) {
|
||||||
Document main = new Document("_id", user.getUuid())
|
Document main = new Document("_id", user.getUuid())
|
||||||
.append("name", user.getName())
|
.append("name", user.getName().orElse("null"))
|
||||||
.append("primaryGroup", user.getPrimaryGroup().getStoredValue());
|
.append("primaryGroup", user.getPrimaryGroup().getStoredValue());
|
||||||
|
|
||||||
Document perms = new Document();
|
Document perms = new Document();
|
||||||
@ -325,12 +325,8 @@ public class MongoDBBacking extends AbstractBacking {
|
|||||||
|
|
||||||
boolean save = plugin.getUserManager().giveDefaultIfNeeded(user, false);
|
boolean save = plugin.getUserManager().giveDefaultIfNeeded(user, false);
|
||||||
|
|
||||||
if (user.getName() == null || user.getName().equalsIgnoreCase("null")) {
|
if (user.setName(name, false)) {
|
||||||
user.setName(d.getString("name"));
|
save = true;
|
||||||
} else {
|
|
||||||
if (!d.getString("name").equalsIgnoreCase(user.getName())) {
|
|
||||||
save = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (save) {
|
if (save) {
|
||||||
|
@ -349,9 +349,7 @@ public class SQLBacking extends AbstractBacking {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Update their username to what was in the storage if the one in the local instance is null
|
// Update their username to what was in the storage if the one in the local instance is null
|
||||||
if (user.getName() == null || user.getName().equalsIgnoreCase("null")) {
|
user.setName(name, false);
|
||||||
user.setName(name);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If the user has any data in storage
|
// If the user has any data in storage
|
||||||
if (!data.isEmpty()) {
|
if (!data.isEmpty()) {
|
||||||
|
@ -179,12 +179,8 @@ public class YAMLBacking extends FlatfileBacking {
|
|||||||
|
|
||||||
boolean save = plugin.getUserManager().giveDefaultIfNeeded(user, false);
|
boolean save = plugin.getUserManager().giveDefaultIfNeeded(user, false);
|
||||||
|
|
||||||
if (user.getName() == null || user.getName().equalsIgnoreCase("null")) {
|
if (user.setName(name, false)) {
|
||||||
user.setName(name);
|
save = true;
|
||||||
} else {
|
|
||||||
if (!name.equalsIgnoreCase(user.getName())) {
|
|
||||||
save = true;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (save) {
|
if (save) {
|
||||||
@ -231,7 +227,7 @@ public class YAMLBacking extends FlatfileBacking {
|
|||||||
|
|
||||||
Map<String, Object> values = new LinkedHashMap<>();
|
Map<String, Object> values = new LinkedHashMap<>();
|
||||||
values.put("uuid", user.getUuid().toString());
|
values.put("uuid", user.getUuid().toString());
|
||||||
values.put("name", user.getName());
|
values.put("name", user.getName().orElse("null"));
|
||||||
values.put("primary-group", user.getPrimaryGroup().getStoredValue());
|
values.put("primary-group", user.getPrimaryGroup().getStoredValue());
|
||||||
|
|
||||||
Set<NodeModel> data = user.getNodes().values().stream().map(NodeModel::fromNode).collect(Collectors.toCollection(LinkedHashSet::new));
|
Set<NodeModel> data = user.getNodes().values().stream().map(NodeModel::fromNode).collect(Collectors.toCollection(LinkedHashSet::new));
|
||||||
|
@ -76,7 +76,7 @@ public class BufferedOutputStorage implements Storage, Runnable {
|
|||||||
private final Buffer<UserIdentifier, Boolean> uuidDataOutputBuffer = new Buffer<UserIdentifier, Boolean>() {
|
private final Buffer<UserIdentifier, Boolean> uuidDataOutputBuffer = new Buffer<UserIdentifier, Boolean>() {
|
||||||
@Override
|
@Override
|
||||||
protected Boolean dequeue(UserIdentifier userIdentifier) {
|
protected Boolean dequeue(UserIdentifier userIdentifier) {
|
||||||
return backing.saveUUIDData(userIdentifier.getUsername(), userIdentifier.getUuid()).join();
|
return backing.saveUUIDData(userIdentifier.getUsername().get(), userIdentifier.getUuid()).join();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -58,6 +58,6 @@ public class SpongeCalculatorFactory extends AbstractCalculatorFactory {
|
|||||||
}
|
}
|
||||||
processors.add(new DefaultsProcessor(plugin.getService(), contexts.getContexts()));
|
processors.add(new DefaultsProcessor(plugin.getService(), contexts.getContexts()));
|
||||||
|
|
||||||
return registerCalculator(new PermissionCalculator(plugin, user.getName(), processors.build()));
|
return registerCalculator(new PermissionCalculator(plugin, user.getFriendlyName(), processors.build()));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -56,6 +56,7 @@ import co.aikar.timings.Timing;
|
|||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Optional;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
@ -115,9 +116,9 @@ public class SpongeUserManager implements UserManager, LPSubjectCollection {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public SpongeUser apply(UserIdentifier id) {
|
public SpongeUser apply(UserIdentifier id) {
|
||||||
return id.getUsername() == null ?
|
return !id.getUsername().isPresent() ?
|
||||||
new SpongeUser(id.getUuid(), plugin) :
|
new SpongeUser(id.getUuid(), plugin) :
|
||||||
new SpongeUser(id.getUuid(), id.getUsername(), plugin);
|
new SpongeUser(id.getUuid(), id.getUsername().get(), plugin);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void performCleanup() {
|
public void performCleanup() {
|
||||||
@ -182,7 +183,8 @@ public class SpongeUserManager implements UserManager, LPSubjectCollection {
|
|||||||
@Override
|
@Override
|
||||||
public SpongeUser getByUsername(String name) {
|
public SpongeUser getByUsername(String name) {
|
||||||
for (SpongeUser user : getAll().values()) {
|
for (SpongeUser user : getAll().values()) {
|
||||||
if (user.getName().equalsIgnoreCase(name)) {
|
Optional<String> n = user.getName();
|
||||||
|
if (n.isPresent() && n.get().equalsIgnoreCase(name)) {
|
||||||
return user;
|
return user;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -98,7 +98,7 @@ public class SpongeUser extends User {
|
|||||||
|
|
||||||
private synchronized void checkData() {
|
private synchronized void checkData() {
|
||||||
if (parent.getUserData() == null) {
|
if (parent.getUserData() == null) {
|
||||||
plugin.getLog().warn("User " + parent.getName() + " - " + parent.getUuid() + " does not have any data loaded.");
|
plugin.getLog().warn("User " + parent.getName().orElse("unknown") + " - " + parent.getUuid() + " does not have any data loaded.");
|
||||||
parent.setupData(false);
|
parent.setupData(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user