/
PaperPlayerProperties.java
115 lines (101 loc) · 4.5 KB
/
PaperPlayerProperties.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
package com.denizenscript.denizen.paper.properties;
import com.denizenscript.denizen.objects.ItemTag;
import com.denizenscript.denizen.objects.PlayerTag;
import com.denizenscript.denizencore.objects.Mechanism;
import com.denizenscript.denizencore.objects.ObjectTag;
import com.denizenscript.denizencore.objects.core.ElementTag;
import com.denizenscript.denizencore.objects.properties.Property;
import com.denizenscript.denizencore.objects.properties.PropertyParser;
import org.bukkit.Material;
public class PaperPlayerProperties implements Property {
public static boolean describes(ObjectTag player) {
return player instanceof PlayerTag
&& ((PlayerTag) player).isOnline();
}
public static PaperPlayerProperties getFrom(ObjectTag player) {
if (!describes(player)) {
return null;
}
return new PaperPlayerProperties((PlayerTag) player);
}
public static final String[] handledMechs = new String[] {
"affects_monster_spawning", "firework_boost", "fake_op_level"
};
private PaperPlayerProperties(PlayerTag player) {
this.player = player;
}
PlayerTag player;
@Override
public String getPropertyString() {
return null;
}
@Override
public String getPropertyId() {
return "PaperPlayerProperties";
}
public static void registerTags() {
// <--[tag]
// @attribute <PlayerTag.affects_monster_spawning>
// @returns ElementTag(Boolean)
// @mechanism PlayerTag.affects_monster_spawning
// @group properties
// @Plugin Paper
// @description
// Returns whether the player affects monster spawning. When false, no monsters will spawn naturally because of this player.
// -->
PropertyParser.<PaperPlayerProperties, ElementTag>registerTag(ElementTag.class, "affects_monster_spawning", (attribute, player) -> {
return new ElementTag(player.player.getPlayerEntity().getAffectsSpawning());
});
}
@Override
public void adjust(Mechanism mechanism) {
// <--[mechanism]
// @object PlayerTag
// @name affects_monster_spawning
// @input ElementTag(Boolean)
// @Plugin Paper
// @description
// Sets whether this player affects monster spawning. When false, no monsters will spawn naturally because of this player.
// @tags
// <PlayerTag.affects_monster_spawning>
// -->
if (mechanism.matches("affects_monster_spawning") && mechanism.requireBoolean()) {
player.getPlayerEntity().setAffectsSpawning(mechanism.getValue().asBoolean());
}
// <--[mechanism]
// @object PlayerTag
// @name firework_boost
// @input ItemTag
// @Plugin Paper
// @description
// Firework boosts the player with the specified firework rocket.
// The player must be gliding.
// -->
if (mechanism.matches("firework_boost") && mechanism.requireObject(ItemTag.class)) {
if (!player.getPlayerEntity().isGliding()) {
mechanism.echoError("Player must be gliding to use firework_boost.");
return;
}
ItemTag item = mechanism.valueAsType(ItemTag.class);
if (item.getBukkitMaterial() != Material.FIREWORK_ROCKET) {
mechanism.echoError("Invalid input item: must be a firework rocket.");
return;
}
player.getPlayerEntity().boostElytra(item.getItemStack());
}
// <--[mechanism]
// @object PlayerTag
// @name fake_op_level
// @input ElementTag(Number)
// @Plugin Paper
// @description
// Sends a fake operator level to the client, enabling clientside op-required features like the debug gamemode hotkey (F3+F4).
// Input should be a number from 0 to 4, 0 indicating not op and 4 indicating maximum level op.
// The input number value corresponds to "op-permission-level" in the server.properties. See also <@link url https://minecraft.fandom.com/wiki/Permission_level>
// This will be reset when a player rejoins, changes world, has their real op status changed, ...
// -->
if (mechanism.matches("fake_op_level") && mechanism.requireInteger()) {
player.getPlayerEntity().sendOpLevel((byte) mechanism.getValue().asInt());
}
}
}