Skip to content

Commit 4127454

Browse files
committed
Initial Commit
0 parents  commit 4127454

File tree

12 files changed

+682
-0
lines changed

12 files changed

+682
-0
lines changed

.gitignore

Lines changed: 113 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,113 @@
1+
# User-specific stuff
2+
.idea/
3+
4+
*.iml
5+
*.ipr
6+
*.iws
7+
8+
# IntelliJ
9+
out/
10+
11+
# Compiled class file
12+
*.class
13+
14+
# Log file
15+
*.log
16+
17+
# BlueJ files
18+
*.ctxt
19+
20+
# Package Files #
21+
*.jar
22+
*.war
23+
*.nar
24+
*.ear
25+
*.zip
26+
*.tar.gz
27+
*.rar
28+
29+
# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
30+
hs_err_pid*
31+
32+
*~
33+
34+
# temporary files which can be created if a process still has a handle open of a deleted file
35+
.fuse_hidden*
36+
37+
# KDE directory preferences
38+
.directory
39+
40+
# Linux trash folder which might appear on any partition or disk
41+
.Trash-*
42+
43+
# .nfs files are created when an open file is removed but is still being accessed
44+
.nfs*
45+
46+
# General
47+
.DS_Store
48+
.AppleDouble
49+
.LSOverride
50+
51+
# Icon must end with two \r
52+
Icon
53+
54+
# Thumbnails
55+
._*
56+
57+
# Files that might appear in the root of a volume
58+
.DocumentRevisions-V100
59+
.fseventsd
60+
.Spotlight-V100
61+
.TemporaryItems
62+
.Trashes
63+
.VolumeIcon.icns
64+
.com.apple.timemachine.donotpresent
65+
66+
# Directories potentially created on remote AFP share
67+
.AppleDB
68+
.AppleDesktop
69+
Network Trash Folder
70+
Temporary Items
71+
.apdisk
72+
73+
# Windows thumbnail cache files
74+
Thumbs.db
75+
Thumbs.db:encryptable
76+
ehthumbs.db
77+
ehthumbs_vista.db
78+
79+
# Dump file
80+
*.stackdump
81+
82+
# Folder config file
83+
[Dd]esktop.ini
84+
85+
# Recycle Bin used on file shares
86+
$RECYCLE.BIN/
87+
88+
# Windows Installer files
89+
*.cab
90+
*.msi
91+
*.msix
92+
*.msm
93+
*.msp
94+
95+
# Windows shortcuts
96+
*.lnk
97+
98+
target/
99+
100+
pom.xml.tag
101+
pom.xml.releaseBackup
102+
pom.xml.versionsBackup
103+
pom.xml.next
104+
105+
release.properties
106+
dependency-reduced-pom.xml
107+
buildNumber.properties
108+
.mvn/timing.properties
109+
.mvn/wrapper/maven-wrapper.jar
110+
.flattened-pom.xml
111+
112+
# Common working directory
113+
run/

pom.xml

Lines changed: 76 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,76 @@
1+
<?xml version="1.0" encoding="UTF-8"?>
2+
<project xmlns="http://maven.apache.org/POM/4.0.0"
3+
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
4+
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
5+
<modelVersion>4.0.0</modelVersion>
6+
7+
<groupId>simplexity</groupId>
8+
<artifactId>SimpleFly</artifactId>
9+
<version>0.0.0</version>
10+
<packaging>jar</packaging>
11+
12+
<name>SimpleFly</name>
13+
14+
<properties>
15+
<java.version>1.8</java.version>
16+
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
17+
</properties>
18+
19+
<build>
20+
<plugins>
21+
<plugin>
22+
<groupId>org.apache.maven.plugins</groupId>
23+
<artifactId>maven-compiler-plugin</artifactId>
24+
<version>3.8.1</version>
25+
<configuration>
26+
<source>16</source>
27+
<target>16</target>
28+
</configuration>
29+
</plugin>
30+
<plugin>
31+
<groupId>org.apache.maven.plugins</groupId>
32+
<artifactId>maven-shade-plugin</artifactId>
33+
<version>3.2.4</version>
34+
<executions>
35+
<execution>
36+
<phase>package</phase>
37+
<goals>
38+
<goal>shade</goal>
39+
</goals>
40+
</execution>
41+
</executions>
42+
</plugin>
43+
</plugins>
44+
<resources>
45+
<resource>
46+
<directory>src/main/resources</directory>
47+
<filtering>true</filtering>
48+
</resource>
49+
</resources>
50+
</build>
51+
52+
<repositories>
53+
<repository>
54+
<id>papermc-repo</id>
55+
<url>https://repo.papermc.io/repository/maven-public/</url>
56+
</repository>
57+
<repository>
58+
<id>sonatype</id>
59+
<url>https://oss.sonatype.org/content/groups/public/</url>
60+
</repository>
61+
</repositories>
62+
63+
<dependencies>
64+
<dependency>
65+
<groupId>io.papermc.paper</groupId>
66+
<artifactId>paper-api</artifactId>
67+
<version>1.20.2-R0.1-SNAPSHOT</version>
68+
<scope>provided</scope>
69+
</dependency>
70+
<dependency>
71+
<groupId>dev.jorel</groupId>
72+
<artifactId>commandapi-bukkit-shade</artifactId>
73+
<version>9.2.0</version>
74+
</dependency>
75+
</dependencies>
76+
</project>
Lines changed: 19 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
package simplexity.simplefly;
2+
3+
import org.bukkit.command.CommandSender;
4+
import org.bukkit.entity.Player;
5+
6+
public class CommandUtils {
7+
public static boolean checkIfPlayerAndPerms(CommandSender sender, String permission) {
8+
if (!(sender instanceof Player player)) {
9+
sender.sendRichMessage(ConfigValues.mustBePlayer);
10+
return false;
11+
}
12+
if (!player.hasPermission(permission)) {
13+
player.sendRichMessage(ConfigValues.noPermission);
14+
return false;
15+
}
16+
return true;
17+
}
18+
19+
}
Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
package simplexity.simplefly;
2+
3+
import org.bukkit.configuration.file.FileConfiguration;
4+
5+
public class ConfigValues {
6+
public static String papiFlightEnabled, papiFlightDisabled, prefix, enabled, disabled, flyOther,
7+
flyOwn, flySetByOther, flySpeedOther, flySpeedOwn, flySpeedSet, flySpeedReset,
8+
flySpeedSetOther, flySpeedResetOther, flySpeedSetByOther, flySpeedResetByOther,
9+
notAPlayer, noPermission, mustBePlayer, notEnoughArguments, notANumber;
10+
11+
public static float maxFlySpeed, minFlySpeed;
12+
public static boolean sessionPersistentFlight, worldChangePersistentFlight,
13+
respawnPersistentFlight, gamemodeChangePersistentFlight;
14+
15+
public static void reloadConfigValues(){
16+
FileConfiguration config = SimpleFly.getInstance().getConfig();
17+
maxFlySpeed = config.getInt("max-fly-speed");
18+
minFlySpeed = config.getInt("min-fly-speed");
19+
sessionPersistentFlight = config.getBoolean("session-persistent-flight");
20+
worldChangePersistentFlight = config.getBoolean("world-change-persistent-flight");
21+
respawnPersistentFlight = config.getBoolean("respawn-persistent-flight");
22+
gamemodeChangePersistentFlight = config.getBoolean("gamemode-change-persistent-flight");
23+
reloadLangValues();
24+
}
25+
public static void reloadLangValues(){
26+
FileConfiguration config = SimpleFly.getInstance().getConfig();
27+
papiFlightEnabled = config.getString("papi-flight-enabled");
28+
papiFlightDisabled = config.getString("papi-flight-disabled");
29+
prefix = config.getString("prefix");
30+
enabled = config.getString("enabled");
31+
disabled = config.getString("disabled");
32+
flyOther = config.getString("fly-other");
33+
flyOwn = config.getString("fly-own");
34+
flySetByOther = config.getString("fly-set-by-other");
35+
flySpeedOther = config.getString("fly-speed-other");
36+
flySpeedOwn = config.getString("fly-speed-own");
37+
flySpeedSet = config.getString("fly-speed-set");
38+
flySpeedReset = config.getString("fly-speed-reset");
39+
flySpeedSetOther = config.getString("fly-speed-set-other");
40+
flySpeedResetOther = config.getString("fly-speed-reset-other");
41+
flySpeedSetByOther = config.getString("fly-speed-set-by-other");
42+
flySpeedResetByOther = config.getString("fly-speed-reset-by-other");
43+
notAPlayer = config.getString("not-a-player");
44+
noPermission = config.getString("no-permission");
45+
mustBePlayer = config.getString("must-be-player");
46+
notEnoughArguments = config.getString("not-enough-arguments");
47+
notANumber = config.getString("not-a-number");
48+
}
49+
50+
}
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
package simplexity.simplefly;
2+
3+
import net.kyori.adventure.text.minimessage.MiniMessage;
4+
import org.bukkit.command.Command;
5+
import org.bukkit.command.CommandSender;
6+
import org.bukkit.command.TabExecutor;
7+
import org.bukkit.entity.Player;
8+
import org.jetbrains.annotations.NotNull;
9+
import org.jetbrains.annotations.Nullable;
10+
11+
import java.util.List;
12+
13+
public class Fly implements TabExecutor {
14+
@Override
15+
public boolean onCommand(@NotNull CommandSender sender, @NotNull Command command, @NotNull String s, @NotNull String[] args) {
16+
if (args.length == 0) {
17+
if (CommandUtils.checkIfPlayerAndPerms(sender, Util.flyPermission)) {
18+
FlyLogic.flyEnabled((Player) sender);
19+
return true;
20+
} else {
21+
return false;
22+
}
23+
}
24+
if (!sender.hasPermission(Util.flyOthersPermission)) return false;
25+
Player player = SimpleFly.getFlyServer().getPlayer(args[0]);
26+
if (player == null) {
27+
sender.sendRichMessage(ConfigValues.notAPlayer);
28+
return false;
29+
}
30+
FlyLogic.flyEnabled(player);
31+
return true;
32+
}
33+
34+
@Override
35+
public @Nullable List<String> onTabComplete(@NotNull CommandSender commandSender, @NotNull Command command, @NotNull String s, @NotNull String[] strings) {
36+
return null;
37+
}
38+
}
Lines changed: 90 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,90 @@
1+
package simplexity.simplefly;
2+
3+
import net.kyori.adventure.text.minimessage.MiniMessage;
4+
import net.kyori.adventure.text.minimessage.tag.resolver.Placeholder;
5+
import org.bukkit.Bukkit;
6+
import org.bukkit.NamespacedKey;
7+
import org.bukkit.entity.Player;
8+
import org.bukkit.event.EventHandler;
9+
import org.bukkit.event.Listener;
10+
import org.bukkit.event.player.PlayerChangedWorldEvent;
11+
import org.bukkit.event.player.PlayerGameModeChangeEvent;
12+
import org.bukkit.event.player.PlayerJoinEvent;
13+
import org.bukkit.event.player.PlayerRespawnEvent;
14+
import org.bukkit.persistence.PersistentDataContainer;
15+
import org.bukkit.persistence.PersistentDataType;
16+
17+
public class FlyListeners implements Listener {
18+
private static final NamespacedKey flyStatus = Util.flyStatus;
19+
private static final MiniMessage miniMessage = SimpleFly.getMiniMessage();
20+
@EventHandler
21+
public void onPlayerLogin(PlayerJoinEvent joinEvent) {
22+
if (!ConfigValues.sessionPersistentFlight) {
23+
return;
24+
}
25+
Player player = joinEvent.getPlayer();
26+
PersistentDataContainer playerPDC = player.getPersistentDataContainer();
27+
Bukkit.getScheduler().runTaskLater(SimpleFly.getInstance(), () -> {
28+
boolean flyEnabled = playerPDC.getOrDefault(flyStatus, PersistentDataType.BOOLEAN, false);
29+
if (flyEnabled && player.hasPermission(Util.flyPermission)) {
30+
System.out.println("Fly is enabled and person has perms");
31+
player.setAllowFlight(true);
32+
if (player.getFallDistance() > 0f) {
33+
player.setFlying(true);
34+
}
35+
player.sendMessage(miniMessage.deserialize(
36+
ConfigValues.prefix + ConfigValues.flyOwn
37+
));
38+
return;
39+
}
40+
if (flyEnabled && !player.hasPermission(Util.flyPermission)) {
41+
playerPDC.set(flyStatus, PersistentDataType.BOOLEAN, false);
42+
}
43+
}, 10);
44+
}
45+
46+
@EventHandler
47+
public void onWorldChange(PlayerChangedWorldEvent worldEvent) {
48+
if (!ConfigValues.worldChangePersistentFlight) return;
49+
Player player = worldEvent.getPlayer();
50+
PersistentDataContainer playerPDC = player.getPersistentDataContainer();
51+
Boolean flyEnabled = playerPDC.getOrDefault(flyStatus, PersistentDataType.BOOLEAN, false);
52+
if (flyEnabled) {
53+
System.out.println("Fly is enabled");
54+
player.setAllowFlight(true);
55+
if (player.getFallDistance() > 0f) {
56+
player.setFlying(true);
57+
}
58+
}
59+
}
60+
61+
@EventHandler
62+
public void onRespawn(PlayerRespawnEvent respawnEvent) {
63+
if (!ConfigValues.respawnPersistentFlight) return;
64+
Player player = respawnEvent.getPlayer();
65+
PersistentDataContainer playerPDC = player.getPersistentDataContainer();
66+
Boolean flyEnabled = playerPDC.getOrDefault(flyStatus, PersistentDataType.BOOLEAN, false);
67+
if (flyEnabled) {
68+
System.out.println("Fly is enabled");
69+
player.setAllowFlight(true);
70+
}
71+
}
72+
73+
@EventHandler
74+
public void onGamemodeChange(PlayerGameModeChangeEvent gameModeChangeEvent) {
75+
if (!ConfigValues.gamemodeChangePersistentFlight) return;
76+
Player player = gameModeChangeEvent.getPlayer();
77+
PersistentDataContainer playerPDC = player.getPersistentDataContainer();
78+
Bukkit.getScheduler().runTaskLater(SimpleFly.getInstance(), () -> {
79+
Boolean flyEnabled = playerPDC.getOrDefault(flyStatus, PersistentDataType.BOOLEAN, false);
80+
if (flyEnabled) {
81+
player.setAllowFlight(true);
82+
if (player.getFallDistance() > 0f) {
83+
player.setFlying(true);
84+
}
85+
}
86+
}, 10);
87+
}
88+
89+
90+
}

0 commit comments

Comments
 (0)