Skip to content

Commit 0c020c1

Browse files
committed
Initial Commit
0 parents  commit 0c020c1

File tree

10 files changed

+476
-0
lines changed

10 files changed

+476
-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: 71 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
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>SimplePlayerFreeze</artifactId>
9+
<version>0.0.0</version>
10+
<packaging>jar</packaging>
11+
12+
<name>SimplePlayerFreeze</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+
</dependencies>
71+
</project>
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
package simplexity.simpleplayerfreeze;
2+
3+
import org.bukkit.plugin.java.JavaPlugin;
4+
import simplexity.simpleplayerfreeze.commands.FreezePlayer;
5+
import simplexity.simpleplayerfreeze.commands.ReloadConfig;
6+
import simplexity.simpleplayerfreeze.commands.UnfreezePlayer;
7+
import simplexity.simpleplayerfreeze.listeners.EventListeners;
8+
9+
import java.util.List;
10+
11+
public final class SimplePlayerFreeze extends JavaPlugin {
12+
13+
14+
private static SimplePlayerFreeze instance;
15+
16+
@Override
17+
public void onEnable() {
18+
instance = this;
19+
this.getServer().getPluginManager().registerEvents(new EventListeners(), this);
20+
getServer().getCommandMap().register(Util.namespace, new FreezePlayer("freeze", "Freezes a player in place and prevents them from using normal things", "/freeze <player>", List.of("cease")));
21+
getServer().getCommandMap().register(Util.namespace, new UnfreezePlayer("unfreeze", "Unfreezes a player and allows them to use normal things", "/unfreeze <player>", List.of("resume")));
22+
getServer().getCommandMap().register(Util.namespace, new ReloadConfig("freezereload", " reloads the config", "/freezereload", List.of("simpleplayerfreezereload", "spfreload")));
23+
this.saveDefaultConfig();
24+
this.reloadConfig();
25+
Util.reloadMessages();
26+
// Plugin startup logic
27+
28+
}
29+
30+
public static SimplePlayerFreeze getInstance() {
31+
return instance;
32+
}
33+
34+
@Override
35+
public void onDisable() {
36+
// Plugin shutdown logic
37+
}
38+
}
Lines changed: 58 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,58 @@
1+
package simplexity.simpleplayerfreeze;
2+
3+
import net.kyori.adventure.text.minimessage.MiniMessage;
4+
import org.bukkit.NamespacedKey;
5+
import org.bukkit.entity.Player;
6+
import org.bukkit.permissions.Permission;
7+
import org.bukkit.persistence.PersistentDataType;
8+
9+
public class Util {
10+
11+
public static MiniMessage miniMessage = MiniMessage.miniMessage();
12+
public static String namespace = "simpleplayerfreeze";
13+
public static NamespacedKey isFrozenKey = new NamespacedKey(namespace, "isfrozen");
14+
public static Permission freezePermission = new Permission("spf.freeze");
15+
public static Permission unfreezePermission = new Permission("spf.unfreeze");
16+
public static Permission reloadPermission = new Permission("spf.reload");
17+
18+
public static String prefix = "";
19+
public static String commandErrorMessage = "";
20+
public static String cannotChat = "";
21+
public static String freezeMessage = "";
22+
public static String unfreezeMessage = "";
23+
public static String reloadMessage = "";
24+
public static String haveBeenFrozen = "";
25+
public static String haveBeenUnfrozen = "";
26+
public static String noPermission = "";
27+
public static String noPlayer = "";
28+
public static String loginMessage = "";
29+
public static String loginNotif = "";
30+
31+
public static void reloadMessages() {
32+
prefix = SimplePlayerFreeze.getInstance().getConfig().getString("prefix");
33+
commandErrorMessage = SimplePlayerFreeze.getInstance().getConfig().getString("command-error-message");
34+
cannotChat = SimplePlayerFreeze.getInstance().getConfig().getString("cannot-chat");
35+
freezeMessage = SimplePlayerFreeze.getInstance().getConfig().getString("freeze-message");
36+
unfreezeMessage = SimplePlayerFreeze.getInstance().getConfig().getString("unfreeze-message");
37+
reloadMessage = SimplePlayerFreeze.getInstance().getConfig().getString("reload-message");
38+
haveBeenFrozen = SimplePlayerFreeze.getInstance().getConfig().getString("have-been-frozen");
39+
haveBeenUnfrozen = SimplePlayerFreeze.getInstance().getConfig().getString("have-been-unfrozen");
40+
noPermission = SimplePlayerFreeze.getInstance().getConfig().getString("no-permission");
41+
noPlayer = SimplePlayerFreeze.getInstance().getConfig().getString("no-player");
42+
loginMessage = SimplePlayerFreeze.getInstance().getConfig().getString("login-message");
43+
loginNotif = SimplePlayerFreeze.getInstance().getConfig().getString("login-notif");
44+
}
45+
46+
public static void setFrozen(Player player) {
47+
player.getPersistentDataContainer().set(Util.isFrozenKey, PersistentDataType.BOOLEAN, true);
48+
player.setGlowing(true);
49+
player.setWalkSpeed(0f);
50+
}
51+
52+
public static void setUnfrozen(Player player) {
53+
player.getPersistentDataContainer().set(Util.isFrozenKey, PersistentDataType.BOOLEAN, false);
54+
player.setGlowing(false);
55+
player.setWalkSpeed(0.2f);
56+
}
57+
58+
}
Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
package simplexity.simpleplayerfreeze.commands;
2+
3+
import net.kyori.adventure.text.minimessage.tag.resolver.Placeholder;
4+
import org.bukkit.Bukkit;
5+
import org.bukkit.command.Command;
6+
import org.bukkit.command.CommandSender;
7+
import org.bukkit.entity.Player;
8+
import org.jetbrains.annotations.NotNull;
9+
import simplexity.simpleplayerfreeze.Util;
10+
11+
import java.util.List;
12+
13+
public class FreezePlayer extends Command {
14+
15+
public FreezePlayer(@NotNull String name, @NotNull String description, @NotNull String usageMessage, @NotNull List<String> aliases) {
16+
super(name, description, usageMessage, aliases);
17+
}
18+
19+
@Override
20+
public boolean execute(@NotNull CommandSender sender, @NotNull String s, @NotNull String[] strings) {
21+
if (!sender.hasPermission(Util.freezePermission)) return false;
22+
if (strings.length == 0) {
23+
sender.sendRichMessage(Util.noPlayer);
24+
return false;
25+
}
26+
Player player;
27+
player = Bukkit.getPlayer(strings[0]);
28+
if (player == null) {
29+
sender.sendRichMessage(Util.noPlayer);
30+
return false;
31+
} else {
32+
Util.setFrozen(player);
33+
sender.sendMessage(Util.miniMessage.deserialize(Util.freezeMessage,
34+
Placeholder.component("name", player.displayName())));
35+
player.sendRichMessage(Util.haveBeenFrozen);
36+
}
37+
return false;
38+
}
39+
}
Lines changed: 29 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
package simplexity.simpleplayerfreeze.commands;
2+
3+
import org.bukkit.command.Command;
4+
import org.bukkit.command.CommandSender;
5+
import org.jetbrains.annotations.NotNull;
6+
import simplexity.simpleplayerfreeze.SimplePlayerFreeze;
7+
import simplexity.simpleplayerfreeze.Util;
8+
9+
import java.util.List;
10+
11+
public class ReloadConfig extends Command {
12+
13+
14+
public ReloadConfig(@NotNull String name, @NotNull String description, @NotNull String usageMessage, @NotNull List<String> aliases) {
15+
super(name, description, usageMessage, aliases);
16+
}
17+
18+
@Override
19+
public boolean execute(@NotNull CommandSender sender, @NotNull String s, @NotNull String[] strings) {
20+
if (!sender.hasPermission(Util.reloadPermission)) {
21+
sender.sendRichMessage(Util.noPermission);
22+
return false;
23+
}
24+
SimplePlayerFreeze.getInstance().reloadConfig();
25+
Util.reloadMessages();
26+
sender.sendRichMessage(Util.reloadMessage);
27+
return true;
28+
}
29+
}
Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
package simplexity.simpleplayerfreeze.commands;
2+
3+
import net.kyori.adventure.text.minimessage.tag.resolver.Placeholder;
4+
import org.bukkit.Bukkit;
5+
import org.bukkit.command.Command;
6+
import org.bukkit.command.CommandSender;
7+
import org.bukkit.entity.Player;
8+
import org.jetbrains.annotations.NotNull;
9+
import simplexity.simpleplayerfreeze.Util;
10+
11+
import java.util.List;
12+
13+
public class UnfreezePlayer extends Command {
14+
15+
public UnfreezePlayer(@NotNull String name, @NotNull String description, @NotNull String usageMessage, @NotNull List<String> aliases) {
16+
super(name, description, usageMessage, aliases);
17+
}
18+
19+
@Override
20+
public boolean execute(@NotNull CommandSender sender, @NotNull String s, @NotNull String[] strings) {
21+
if (!sender.hasPermission(Util.unfreezePermission)) return false;
22+
if (strings.length == 0) {
23+
sender.sendRichMessage(Util.noPlayer);
24+
return false;
25+
}
26+
Player player;
27+
player = Bukkit.getPlayer(strings[0]);
28+
if (player == null) {
29+
sender.sendRichMessage(Util.noPlayer);
30+
return false;
31+
} else {
32+
Util.setUnfrozen(player);
33+
sender.sendMessage(Util.miniMessage.deserialize(Util.unfreezeMessage,
34+
Placeholder.component("name", player.displayName())));
35+
player.sendRichMessage(Util.haveBeenUnfrozen);
36+
}
37+
return false;
38+
}
39+
}

0 commit comments

Comments
 (0)