Fail silently when plugins use reflection to add to dummy permissibles (#1117)
This commit is contained in:
parent
c3cdf387c2
commit
ae3adf23c8
@ -32,8 +32,14 @@ import org.bukkit.permissions.PermissionAttachmentInfo;
|
||||
import org.bukkit.plugin.Plugin;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.function.BiFunction;
|
||||
import java.util.function.Function;
|
||||
|
||||
public class DummyPermissibleBase extends PermissibleBase {
|
||||
private static final Field ATTACHMENTS_FIELD;
|
||||
@ -51,19 +57,6 @@ public class DummyPermissibleBase extends PermissibleBase {
|
||||
}
|
||||
}
|
||||
|
||||
public static void nullFields(PermissibleBase permissibleBase) {
|
||||
try {
|
||||
ATTACHMENTS_FIELD.set(permissibleBase, Collections.emptyList());
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
try {
|
||||
PERMISSIONS_FIELD.set(permissibleBase, Collections.emptyMap());
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
}
|
||||
|
||||
public static void copyFields(PermissibleBase from, PermissibleBase to) {
|
||||
try {
|
||||
ATTACHMENTS_FIELD.set(to, ATTACHMENTS_FIELD.get(from));
|
||||
@ -81,7 +74,31 @@ public class DummyPermissibleBase extends PermissibleBase {
|
||||
|
||||
private DummyPermissibleBase() {
|
||||
super(null);
|
||||
nullFields(this);
|
||||
|
||||
// we want the singleton dummy attachment to be stateless
|
||||
// the behaviour of this class is to fail silently, so we can't use Collections.emptyX
|
||||
try {
|
||||
ATTACHMENTS_FIELD.set(this, new ArrayList<PermissionAttachment>(){
|
||||
@Override public boolean add(PermissionAttachment permissionAttachment) { return true; }
|
||||
@Override public void add(int index, PermissionAttachment element) { }
|
||||
@Override public boolean addAll(Collection<? extends PermissionAttachment> c) { return true; }
|
||||
@Override public boolean addAll(int index, Collection<? extends PermissionAttachment> c) { return true; }
|
||||
});
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
try {
|
||||
PERMISSIONS_FIELD.set(this, new HashMap<String, PermissionAttachmentInfo>() {
|
||||
@Override public PermissionAttachmentInfo put(String key, PermissionAttachmentInfo value) { return null; }
|
||||
@Override public void putAll(Map<? extends String, ? extends PermissionAttachmentInfo> m) { }
|
||||
@Override public PermissionAttachmentInfo putIfAbsent(String key, PermissionAttachmentInfo value) { return null; }
|
||||
@Override public PermissionAttachmentInfo compute(String key, BiFunction<? super String, ? super PermissionAttachmentInfo, ? extends PermissionAttachmentInfo> remappingFunction) { return null; }
|
||||
@Override public PermissionAttachmentInfo computeIfPresent(String key, BiFunction<? super String, ? super PermissionAttachmentInfo, ? extends PermissionAttachmentInfo> remappingFunction) { return null; }
|
||||
@Override public PermissionAttachmentInfo computeIfAbsent(String key, Function<? super String, ? extends PermissionAttachmentInfo> mappingFunction) { return null; }
|
||||
});
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
}
|
||||
|
||||
@Override public boolean isOp() { return false; }
|
||||
|
@ -33,11 +33,15 @@ import cn.nukkit.plugin.Plugin;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.util.AbstractList;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collection;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.RandomAccess;
|
||||
import java.util.function.BiFunction;
|
||||
import java.util.function.Function;
|
||||
|
||||
public class DummyPermissibleBase extends PermissibleBase {
|
||||
private static final Field ATTACHMENTS_FIELD;
|
||||
@ -55,19 +59,6 @@ public class DummyPermissibleBase extends PermissibleBase {
|
||||
}
|
||||
}
|
||||
|
||||
public static void nullFields(PermissibleBase permissibleBase) {
|
||||
try {
|
||||
ATTACHMENTS_FIELD.set(permissibleBase, EMPTY_LIST);
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
try {
|
||||
PERMISSIONS_FIELD.set(permissibleBase, Collections.emptyMap());
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
}
|
||||
|
||||
public static void copyFields(PermissibleBase from, PermissibleBase to) {
|
||||
try {
|
||||
ATTACHMENTS_FIELD.set(to, ATTACHMENTS_FIELD.get(from));
|
||||
@ -85,7 +76,31 @@ public class DummyPermissibleBase extends PermissibleBase {
|
||||
|
||||
private DummyPermissibleBase() {
|
||||
super(null);
|
||||
nullFields(this);
|
||||
|
||||
// we want the singleton dummy attachment to be stateless
|
||||
// the behaviour of this class is to fail silently, so we can't use Collections.emptyX
|
||||
try {
|
||||
ATTACHMENTS_FIELD.set(this, new ArrayList<PermissionAttachment>(){
|
||||
@Override public boolean add(PermissionAttachment permissionAttachment) { return true; }
|
||||
@Override public void add(int index, PermissionAttachment element) { }
|
||||
@Override public boolean addAll(Collection<? extends PermissionAttachment> c) { return true; }
|
||||
@Override public boolean addAll(int index, Collection<? extends PermissionAttachment> c) { return true; }
|
||||
});
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
try {
|
||||
PERMISSIONS_FIELD.set(this, new HashMap<String, PermissionAttachmentInfo>() {
|
||||
@Override public PermissionAttachmentInfo put(String key, PermissionAttachmentInfo value) { return null; }
|
||||
@Override public void putAll(Map<? extends String, ? extends PermissionAttachmentInfo> m) { }
|
||||
@Override public PermissionAttachmentInfo putIfAbsent(String key, PermissionAttachmentInfo value) { return null; }
|
||||
@Override public PermissionAttachmentInfo compute(String key, BiFunction<? super String, ? super PermissionAttachmentInfo, ? extends PermissionAttachmentInfo> remappingFunction) { return null; }
|
||||
@Override public PermissionAttachmentInfo computeIfPresent(String key, BiFunction<? super String, ? super PermissionAttachmentInfo, ? extends PermissionAttachmentInfo> remappingFunction) { return null; }
|
||||
@Override public PermissionAttachmentInfo computeIfAbsent(String key, Function<? super String, ? extends PermissionAttachmentInfo> mappingFunction) { return null; }
|
||||
});
|
||||
} catch (Exception e) {
|
||||
// ignore
|
||||
}
|
||||
}
|
||||
|
||||
@Override public boolean isOp() { return false; }
|
||||
|
Loading…
Reference in New Issue
Block a user