fix abuse of static in SubjectReferenceFactory
This commit is contained in:
parent
764665cf15
commit
7bf666b062
@ -48,6 +48,8 @@ public interface LPPermissionService {
|
|||||||
|
|
||||||
LuckPermsPlugin getPlugin();
|
LuckPermsPlugin getPlugin();
|
||||||
|
|
||||||
|
SubjectReferenceFactory getReferenceFactory();
|
||||||
|
|
||||||
PermissionService sponge();
|
PermissionService sponge();
|
||||||
|
|
||||||
LPSubjectCollection getUserSubjects();
|
LPSubjectCollection getUserSubjects();
|
||||||
|
@ -27,7 +27,7 @@ package me.lucko.luckperms.sponge.service.model;
|
|||||||
|
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.NonNull;
|
import lombok.NonNull;
|
||||||
import lombok.experimental.UtilityClass;
|
import lombok.RequiredArgsConstructor;
|
||||||
|
|
||||||
import com.github.benmanes.caffeine.cache.Caffeine;
|
import com.github.benmanes.caffeine.cache.Caffeine;
|
||||||
import com.github.benmanes.caffeine.cache.LoadingCache;
|
import com.github.benmanes.caffeine.cache.LoadingCache;
|
||||||
@ -41,9 +41,37 @@ import java.util.concurrent.TimeUnit;
|
|||||||
/**
|
/**
|
||||||
* Caches the creation of {@link SubjectReference}s.
|
* Caches the creation of {@link SubjectReference}s.
|
||||||
*/
|
*/
|
||||||
@UtilityClass
|
@RequiredArgsConstructor
|
||||||
public final class SubjectReferenceFactory {
|
public final class SubjectReferenceFactory {
|
||||||
|
|
||||||
|
// static util access
|
||||||
|
|
||||||
|
@Deprecated
|
||||||
|
public static SubjectReference deserialize(@NonNull LPPermissionService service, String serialisedReference) {
|
||||||
|
return service.getReferenceFactory().deserialize(serialisedReference);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static SubjectReference obtain(@NonNull LPPermissionService service, LPSubject subject) {
|
||||||
|
return service.getReferenceFactory().obtain(subject);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static SubjectReference obtain(@NonNull LPPermissionService service, Subject subject) {
|
||||||
|
return service.getReferenceFactory().obtain(subject);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static SubjectReference obtain(@NonNull LPPermissionService service, org.spongepowered.api.service.permission.SubjectReference reference) {
|
||||||
|
return service.getReferenceFactory().obtain(reference);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static SubjectReference obtain(@NonNull LPPermissionService service, String collectionIdentifier, String subjectIdentifier) {
|
||||||
|
return service.getReferenceFactory().obtain(collectionIdentifier, subjectIdentifier);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The permission service to obtain real subject instances from
|
||||||
|
*/
|
||||||
|
private final LPPermissionService service;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Cache based factory for SubjectReferences.
|
* Cache based factory for SubjectReferences.
|
||||||
*
|
*
|
||||||
@ -53,40 +81,40 @@ public final class SubjectReferenceFactory {
|
|||||||
*
|
*
|
||||||
* It's perfectly ok if two instances of the same SubjectReference exist. (hence the 1 hour expiry)
|
* It's perfectly ok if two instances of the same SubjectReference exist. (hence the 1 hour expiry)
|
||||||
*/
|
*/
|
||||||
private static final LoadingCache<SubjectReferenceAttributes, SubjectReference> REFERENCE_CACHE = Caffeine.newBuilder()
|
private final LoadingCache<SubjectReferenceAttributes, SubjectReference> referenceCache = Caffeine.newBuilder()
|
||||||
.expireAfterAccess(1, TimeUnit.HOURS)
|
.expireAfterAccess(1, TimeUnit.HOURS)
|
||||||
.build(a -> new SubjectReference(a.permissionService, a.collectionId, a.id));
|
.build(a -> new SubjectReference(service, a.collectionId, a.id));
|
||||||
|
|
||||||
@Deprecated
|
@Deprecated
|
||||||
public static SubjectReference deserialize(@NonNull LPPermissionService service, @NonNull String serialisedReference) {
|
public SubjectReference deserialize(@NonNull String serialisedReference) {
|
||||||
List<String> parts = Splitter.on('/').limit(2).splitToList(serialisedReference);
|
List<String> parts = Splitter.on('/').limit(2).splitToList(serialisedReference);
|
||||||
return obtain(service, parts.get(0), parts.get(1));
|
return obtain(parts.get(0), parts.get(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SubjectReference obtain(@NonNull LPPermissionService service, @NonNull LPSubject subject) {
|
public SubjectReference obtain(@NonNull LPSubject subject) {
|
||||||
SubjectReference ret = obtain(service, subject.getParentCollection().getIdentifier(), subject.getIdentifier());
|
SubjectReference ret = obtain(subject.getParentCollection().getIdentifier(), subject.getIdentifier());
|
||||||
ret.fillCache(subject);
|
ret.fillCache(subject);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SubjectReference obtain(@NonNull LPPermissionService service, @NonNull Subject subject) {
|
public SubjectReference obtain(@NonNull Subject subject) {
|
||||||
if (subject instanceof ProxiedSubject) {
|
if (subject instanceof ProxiedSubject) {
|
||||||
return ((ProxiedSubject) subject).getReference();
|
return ((ProxiedSubject) subject).getReference();
|
||||||
}
|
}
|
||||||
|
|
||||||
return obtain(service, subject.getContainingCollection().getIdentifier(), subject.getIdentifier());
|
return obtain(subject.getContainingCollection().getIdentifier(), subject.getIdentifier());
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SubjectReference obtain(@NonNull LPPermissionService service, @NonNull org.spongepowered.api.service.permission.SubjectReference reference) {
|
public SubjectReference obtain(@NonNull org.spongepowered.api.service.permission.SubjectReference reference) {
|
||||||
if (reference instanceof SubjectReference) {
|
if (reference instanceof SubjectReference) {
|
||||||
return ((SubjectReference) reference);
|
return ((SubjectReference) reference);
|
||||||
} else {
|
} else {
|
||||||
return obtain(service, reference.getCollectionIdentifier(), reference.getSubjectIdentifier());
|
return obtain(reference.getCollectionIdentifier(), reference.getSubjectIdentifier());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SubjectReference obtain(@NonNull LPPermissionService service, @NonNull String collectionIdentifier, @NonNull String subjectIdentifier) {
|
public SubjectReference obtain(@NonNull String collectionIdentifier, @NonNull String subjectIdentifier) {
|
||||||
return REFERENCE_CACHE.get(new SubjectReferenceAttributes(service, collectionIdentifier, subjectIdentifier));
|
return referenceCache.get(new SubjectReferenceAttributes(collectionIdentifier, subjectIdentifier));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -94,8 +122,6 @@ public final class SubjectReferenceFactory {
|
|||||||
*/
|
*/
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
private static final class SubjectReferenceAttributes {
|
private static final class SubjectReferenceAttributes {
|
||||||
private final LPPermissionService permissionService;
|
|
||||||
|
|
||||||
private final String collectionId;
|
private final String collectionId;
|
||||||
private final String id;
|
private final String id;
|
||||||
|
|
||||||
|
@ -47,6 +47,7 @@ import me.lucko.luckperms.sponge.service.model.LPPermissionService;
|
|||||||
import me.lucko.luckperms.sponge.service.model.LPSubject;
|
import me.lucko.luckperms.sponge.service.model.LPSubject;
|
||||||
import me.lucko.luckperms.sponge.service.model.LPSubjectCollection;
|
import me.lucko.luckperms.sponge.service.model.LPSubjectCollection;
|
||||||
import me.lucko.luckperms.sponge.service.model.SubjectReference;
|
import me.lucko.luckperms.sponge.service.model.SubjectReference;
|
||||||
|
import me.lucko.luckperms.sponge.service.model.SubjectReferenceFactory;
|
||||||
import me.lucko.luckperms.sponge.service.persisted.PersistedCollection;
|
import me.lucko.luckperms.sponge.service.persisted.PersistedCollection;
|
||||||
import me.lucko.luckperms.sponge.service.storage.SubjectStorage;
|
import me.lucko.luckperms.sponge.service.storage.SubjectStorage;
|
||||||
|
|
||||||
@ -77,6 +78,7 @@ public class LuckPermsService implements LPPermissionService {
|
|||||||
@Getter(AccessLevel.NONE)
|
@Getter(AccessLevel.NONE)
|
||||||
private final PermissionService spongeProxy;
|
private final PermissionService spongeProxy;
|
||||||
|
|
||||||
|
private final SubjectReferenceFactory referenceFactory;
|
||||||
private final SubjectStorage storage;
|
private final SubjectStorage storage;
|
||||||
private final SpongeUserManager userSubjects;
|
private final SpongeUserManager userSubjects;
|
||||||
private final SpongeGroupManager groupSubjects;
|
private final SpongeGroupManager groupSubjects;
|
||||||
@ -89,6 +91,7 @@ public class LuckPermsService implements LPPermissionService {
|
|||||||
|
|
||||||
public LuckPermsService(LPSpongePlugin plugin) {
|
public LuckPermsService(LPSpongePlugin plugin) {
|
||||||
this.plugin = plugin;
|
this.plugin = plugin;
|
||||||
|
this.referenceFactory = new SubjectReferenceFactory(this);
|
||||||
this.spongeProxy = ProxyFactory.toSponge(this);
|
this.spongeProxy = ProxyFactory.toSponge(this);
|
||||||
|
|
||||||
storage = new SubjectStorage(this, new File(plugin.getDataDirectory(), "sponge-data"));
|
storage = new SubjectStorage(this, new File(plugin.getDataDirectory(), "sponge-data"));
|
||||||
|
Loading…
Reference in New Issue
Block a user