Don't store API delegate instances for all users
This commit is contained in:
parent
e28d15456c
commit
2bc56de1c3
@ -131,7 +131,7 @@ public class LuckPermsApiProvider implements LuckPermsApi {
|
|||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public Storage getStorage() {
|
public Storage getStorage() {
|
||||||
return this.plugin.getStorage().getDelegate();
|
return this.plugin.getStorage().getApiDelegate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
|
@ -45,13 +45,13 @@ public class ApiGroupManager implements GroupManager {
|
|||||||
public Group getGroup(@Nonnull String name) {
|
public Group getGroup(@Nonnull String name) {
|
||||||
Objects.requireNonNull(name, "name");
|
Objects.requireNonNull(name, "name");
|
||||||
me.lucko.luckperms.common.model.Group group = this.handle.getIfLoaded(name);
|
me.lucko.luckperms.common.model.Group group = this.handle.getIfLoaded(name);
|
||||||
return group == null ? null : group.getDelegate();
|
return group == null ? null : group.getApiDelegate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public Set<Group> getLoadedGroups() {
|
public Set<Group> getLoadedGroups() {
|
||||||
return this.handle.getAll().values().stream().map(me.lucko.luckperms.common.model.Group::getDelegate).collect(Collectors.toSet());
|
return this.handle.getAll().values().stream().map(me.lucko.luckperms.common.model.Group::getApiDelegate).collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -45,13 +45,13 @@ public class ApiTrackManager implements TrackManager {
|
|||||||
public Track getTrack(@Nonnull String name) {
|
public Track getTrack(@Nonnull String name) {
|
||||||
Objects.requireNonNull(name, "name");
|
Objects.requireNonNull(name, "name");
|
||||||
me.lucko.luckperms.common.model.Track track = this.handle.getIfLoaded(name);
|
me.lucko.luckperms.common.model.Track track = this.handle.getIfLoaded(name);
|
||||||
return track == null ? null : track.getDelegate();
|
return track == null ? null : track.getApiDelegate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public Set<Track> getLoadedTracks() {
|
public Set<Track> getLoadedTracks() {
|
||||||
return this.handle.getAll().values().stream().map(me.lucko.luckperms.common.model.Track::getDelegate).collect(Collectors.toSet());
|
return this.handle.getAll().values().stream().map(me.lucko.luckperms.common.model.Track::getApiDelegate).collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -48,20 +48,20 @@ public class ApiUserManager implements UserManager {
|
|||||||
public User getUser(@Nonnull UUID uuid) {
|
public User getUser(@Nonnull UUID uuid) {
|
||||||
Objects.requireNonNull(uuid, "uuid");
|
Objects.requireNonNull(uuid, "uuid");
|
||||||
me.lucko.luckperms.common.model.User user = this.handle.getIfLoaded(uuid);
|
me.lucko.luckperms.common.model.User user = this.handle.getIfLoaded(uuid);
|
||||||
return user == null ? null : user.getDelegate();
|
return user == null ? null : new ApiUser(user);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public User getUser(@Nonnull String name) {
|
public User getUser(@Nonnull String name) {
|
||||||
Objects.requireNonNull(name, "name");
|
Objects.requireNonNull(name, "name");
|
||||||
me.lucko.luckperms.common.model.User user = this.handle.getByUsername(name);
|
me.lucko.luckperms.common.model.User user = this.handle.getByUsername(name);
|
||||||
return user == null ? null : user.getDelegate();
|
return user == null ? null : new ApiUser(user);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public Set<User> getLoadedUsers() {
|
public Set<User> getLoadedUsers() {
|
||||||
return this.handle.getAll().values().stream().map(me.lucko.luckperms.common.model.User::getDelegate).collect(Collectors.toSet());
|
return this.handle.getAll().values().stream().map(ApiUser::new).collect(Collectors.toSet());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -59,7 +59,7 @@ import javax.annotation.Nonnull;
|
|||||||
public class ApiPermissionHolder implements PermissionHolder {
|
public class ApiPermissionHolder implements PermissionHolder {
|
||||||
private final me.lucko.luckperms.common.model.PermissionHolder handle;
|
private final me.lucko.luckperms.common.model.PermissionHolder handle;
|
||||||
|
|
||||||
public ApiPermissionHolder(me.lucko.luckperms.common.model.PermissionHolder handle) {
|
ApiPermissionHolder(me.lucko.luckperms.common.model.PermissionHolder handle) {
|
||||||
this.handle = Objects.requireNonNull(handle, "handle");
|
this.handle = Objects.requireNonNull(handle, "handle");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -45,16 +45,16 @@ public final class ApiUser extends ApiPermissionHolder implements User {
|
|||||||
|
|
||||||
private final me.lucko.luckperms.common.model.User handle;
|
private final me.lucko.luckperms.common.model.User handle;
|
||||||
|
|
||||||
@Override
|
|
||||||
me.lucko.luckperms.common.model.User getHandle() {
|
|
||||||
return this.handle;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ApiUser(me.lucko.luckperms.common.model.User handle) {
|
public ApiUser(me.lucko.luckperms.common.model.User handle) {
|
||||||
super(handle);
|
super(handle);
|
||||||
this.handle = handle;
|
this.handle = handle;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
me.lucko.luckperms.common.model.User getHandle() {
|
||||||
|
return this.handle;
|
||||||
|
}
|
||||||
|
|
||||||
@Nonnull
|
@Nonnull
|
||||||
@Override
|
@Override
|
||||||
public UUID getUuid() {
|
public UUID getUuid() {
|
||||||
|
@ -101,17 +101,17 @@ public final class EventFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void handleGroupCacheLoad(Group group, GroupData data) {
|
public void handleGroupCacheLoad(Group group, GroupData data) {
|
||||||
EventGroupCacheLoad event = new EventGroupCacheLoad(group.getDelegate(), data);
|
EventGroupCacheLoad event = new EventGroupCacheLoad(group.getApiDelegate(), data);
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleGroupCreate(Group group, CreationCause cause) {
|
public void handleGroupCreate(Group group, CreationCause cause) {
|
||||||
EventGroupCreate event = new EventGroupCreate(group.getDelegate(), cause);
|
EventGroupCreate event = new EventGroupCreate(group.getApiDelegate(), cause);
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleGroupDataRecalculate(Group group, GroupData data) {
|
public void handleGroupDataRecalculate(Group group, GroupData data) {
|
||||||
EventGroupDataRecalculate event = new EventGroupDataRecalculate(group.getDelegate(), data);
|
EventGroupDataRecalculate event = new EventGroupDataRecalculate(group.getApiDelegate(), data);
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -126,7 +126,7 @@ public final class EventFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void handleGroupLoad(Group group) {
|
public void handleGroupLoad(Group group) {
|
||||||
EventGroupLoad event = new EventGroupLoad(group.getDelegate());
|
EventGroupLoad event = new EventGroupLoad(group.getApiDelegate());
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -203,7 +203,7 @@ public final class EventFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void handleTrackCreate(Track track, CreationCause cause) {
|
public void handleTrackCreate(Track track, CreationCause cause) {
|
||||||
EventTrackCreate event = new EventTrackCreate(track.getDelegate(), cause);
|
EventTrackCreate event = new EventTrackCreate(track.getApiDelegate(), cause);
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -218,22 +218,22 @@ public final class EventFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void handleTrackLoad(Track track) {
|
public void handleTrackLoad(Track track) {
|
||||||
EventTrackLoad event = new EventTrackLoad(track.getDelegate());
|
EventTrackLoad event = new EventTrackLoad(track.getApiDelegate());
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleTrackAddGroup(Track track, String group, List<String> before, List<String> after) {
|
public void handleTrackAddGroup(Track track, String group, List<String> before, List<String> after) {
|
||||||
EventTrackAddGroup event = new EventTrackAddGroup(group, track.getDelegate(), ImmutableList.copyOf(before), ImmutableList.copyOf(after));
|
EventTrackAddGroup event = new EventTrackAddGroup(group, track.getApiDelegate(), ImmutableList.copyOf(before), ImmutableList.copyOf(after));
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleTrackClear(Track track, List<String> before) {
|
public void handleTrackClear(Track track, List<String> before) {
|
||||||
EventTrackClear event = new EventTrackClear(track.getDelegate(), ImmutableList.copyOf(before), ImmutableList.of());
|
EventTrackClear event = new EventTrackClear(track.getApiDelegate(), ImmutableList.copyOf(before), ImmutableList.of());
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleTrackRemoveGroup(Track track, String group, List<String> before, List<String> after) {
|
public void handleTrackRemoveGroup(Track track, String group, List<String> before, List<String> after) {
|
||||||
EventTrackRemoveGroup event = new EventTrackRemoveGroup(group, track.getDelegate(), ImmutableList.copyOf(before), ImmutableList.copyOf(after));
|
EventTrackRemoveGroup event = new EventTrackRemoveGroup(group, track.getApiDelegate(), ImmutableList.copyOf(before), ImmutableList.copyOf(after));
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -263,12 +263,12 @@ public final class EventFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void handleUserDemote(User user, Track track, String from, String to) {
|
public void handleUserDemote(User user, Track track, String from, String to) {
|
||||||
EventUserDemote event = new EventUserDemote(track.getDelegate(), user.getDelegate(), from, to);
|
EventUserDemote event = new EventUserDemote(track.getApiDelegate(), user.getDelegate(), from, to);
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleUserPromote(User user, Track track, String from, String to) {
|
public void handleUserPromote(User user, Track track, String from, String to) {
|
||||||
EventUserPromote event = new EventUserPromote(track.getDelegate(), user.getDelegate(), from, to);
|
EventUserPromote event = new EventUserPromote(track.getApiDelegate(), user.getDelegate(), from, to);
|
||||||
fireEventAsync(event);
|
fireEventAsync(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -46,7 +46,7 @@ public class Group extends PermissionHolder implements Identifiable<String> {
|
|||||||
*/
|
*/
|
||||||
private final String name;
|
private final String name;
|
||||||
|
|
||||||
private final ApiGroup delegate = new ApiGroup(this);
|
private final ApiGroup apiDelegate = new ApiGroup(this);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The groups data cache instance
|
* The groups data cache instance
|
||||||
@ -71,9 +71,8 @@ public class Group extends PermissionHolder implements Identifiable<String> {
|
|||||||
return this.name;
|
return this.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
public ApiGroup getApiDelegate() {
|
||||||
public ApiGroup getDelegate() {
|
return this.apiDelegate;
|
||||||
return this.delegate;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -38,7 +38,6 @@ import me.lucko.luckperms.api.Node;
|
|||||||
import me.lucko.luckperms.api.Tristate;
|
import me.lucko.luckperms.api.Tristate;
|
||||||
import me.lucko.luckperms.api.context.ContextSet;
|
import me.lucko.luckperms.api.context.ContextSet;
|
||||||
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
import me.lucko.luckperms.api.context.ImmutableContextSet;
|
||||||
import me.lucko.luckperms.common.api.delegates.model.ApiPermissionHolder;
|
|
||||||
import me.lucko.luckperms.common.buffers.BufferedRequest;
|
import me.lucko.luckperms.common.buffers.BufferedRequest;
|
||||||
import me.lucko.luckperms.common.buffers.Cache;
|
import me.lucko.luckperms.common.buffers.Cache;
|
||||||
import me.lucko.luckperms.common.caching.HolderCachedData;
|
import me.lucko.luckperms.common.caching.HolderCachedData;
|
||||||
@ -227,13 +226,6 @@ public abstract class PermissionHolder {
|
|||||||
*/
|
*/
|
||||||
public abstract HolderType getType();
|
public abstract HolderType getType();
|
||||||
|
|
||||||
/**
|
|
||||||
* Gets the API delegate for this instance
|
|
||||||
*
|
|
||||||
* @return the api delegate
|
|
||||||
*/
|
|
||||||
public abstract ApiPermissionHolder getDelegate();
|
|
||||||
|
|
||||||
public NodeMap getData(NodeMapType type) {
|
public NodeMap getData(NodeMapType type) {
|
||||||
switch (type) {
|
switch (type) {
|
||||||
case ENDURING:
|
case ENDURING:
|
||||||
|
@ -54,7 +54,7 @@ public final class Track implements Identifiable<String> {
|
|||||||
*/
|
*/
|
||||||
private final List<String> groups = Collections.synchronizedList(new ArrayList<>());
|
private final List<String> groups = Collections.synchronizedList(new ArrayList<>());
|
||||||
|
|
||||||
private final ApiTrack delegate = new ApiTrack(this);
|
private final ApiTrack apiDelegate = new ApiTrack(this);
|
||||||
|
|
||||||
public Track(String name, LuckPermsPlugin plugin) {
|
public Track(String name, LuckPermsPlugin plugin) {
|
||||||
this.name = name;
|
this.name = name;
|
||||||
@ -69,8 +69,8 @@ public final class Track implements Identifiable<String> {
|
|||||||
return this.ioLock;
|
return this.ioLock;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ApiTrack getDelegate() {
|
public ApiTrack getApiDelegate() {
|
||||||
return this.delegate;
|
return this.apiDelegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -26,7 +26,6 @@
|
|||||||
package me.lucko.luckperms.common.model;
|
package me.lucko.luckperms.common.model;
|
||||||
|
|
||||||
import me.lucko.luckperms.api.Contexts;
|
import me.lucko.luckperms.api.Contexts;
|
||||||
import me.lucko.luckperms.common.api.delegates.model.ApiUser;
|
|
||||||
import me.lucko.luckperms.common.buffers.BufferedRequest;
|
import me.lucko.luckperms.common.buffers.BufferedRequest;
|
||||||
import me.lucko.luckperms.common.caching.UserCachedData;
|
import me.lucko.luckperms.common.caching.UserCachedData;
|
||||||
import me.lucko.luckperms.common.config.ConfigKeys;
|
import me.lucko.luckperms.common.config.ConfigKeys;
|
||||||
@ -65,8 +64,6 @@ public class User extends PermissionHolder implements Identifiable<UserIdentifie
|
|||||||
|
|
||||||
private final BufferedRequest<Void> refreshBuffer;
|
private final BufferedRequest<Void> refreshBuffer;
|
||||||
|
|
||||||
private final ApiUser delegate = new ApiUser(this);
|
|
||||||
|
|
||||||
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;
|
||||||
@ -108,11 +105,6 @@ public class User extends PermissionHolder implements Identifiable<UserIdentifie
|
|||||||
return this.refreshBuffer;
|
return this.refreshBuffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public ApiUser getDelegate() {
|
|
||||||
return this.delegate;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public UserIdentifier getId() {
|
public UserIdentifier getId() {
|
||||||
return UserIdentifier.of(this.uuid, this.name);
|
return UserIdentifier.of(this.uuid, this.name);
|
||||||
|
@ -64,12 +64,12 @@ public class AbstractStorage implements Storage {
|
|||||||
private final LuckPermsPlugin plugin;
|
private final LuckPermsPlugin plugin;
|
||||||
private final AbstractDao dao;
|
private final AbstractDao dao;
|
||||||
|
|
||||||
private final ApiStorage delegate;
|
private final ApiStorage apiDelegate;
|
||||||
|
|
||||||
private AbstractStorage(LuckPermsPlugin plugin, AbstractDao dao) {
|
private AbstractStorage(LuckPermsPlugin plugin, AbstractDao dao) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
this.dao = dao;
|
this.dao = dao;
|
||||||
this.delegate = new ApiStorage(plugin, this);
|
this.apiDelegate = new ApiStorage(plugin, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@ -100,8 +100,8 @@ public class AbstractStorage implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ApiStorage getDelegate() {
|
public ApiStorage getApiDelegate() {
|
||||||
return this.delegate;
|
return this.apiDelegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
private interface ThrowingRunnable {
|
private interface ThrowingRunnable {
|
||||||
|
@ -49,7 +49,7 @@ import java.util.concurrent.CompletableFuture;
|
|||||||
*/
|
*/
|
||||||
public interface Storage {
|
public interface Storage {
|
||||||
|
|
||||||
ApiStorage getDelegate();
|
ApiStorage getApiDelegate();
|
||||||
|
|
||||||
AbstractDao getDao();
|
AbstractDao getDao();
|
||||||
|
|
||||||
|
@ -178,8 +178,8 @@ public class BufferedOutputStorage implements Storage, Runnable {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ApiStorage getDelegate() {
|
public ApiStorage getApiDelegate() {
|
||||||
return this.delegate.getDelegate();
|
return this.delegate.getApiDelegate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -69,8 +69,8 @@ public class PhasedStorage implements Storage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ApiStorage getDelegate() {
|
public ApiStorage getApiDelegate() {
|
||||||
return this.delegate.getDelegate();
|
return this.delegate.getApiDelegate();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user