parent
e3e5f58f32
commit
7598aded28
12 changed files with 283 additions and 82 deletions
18
.forgejo/workflows/build.yml
Normal file
18
.forgejo/workflows/build.yml
Normal file
|
@ -0,0 +1,18 @@
|
|||
on: [push]
|
||||
jobs:
|
||||
deploy:
|
||||
runs-on: docker
|
||||
container: debian:sid
|
||||
steps:
|
||||
- name: Prepare for installation
|
||||
run: apt update
|
||||
- name: Install JDK
|
||||
run: apt install --no-install-recommends -y openjdk-21-jdk-headless maven git nodejs
|
||||
- name: Clone repository
|
||||
run: git clone https://git.m724.eu/Minecon724/mutils.git .
|
||||
- name: Build
|
||||
run: mvn clean package
|
||||
- name: Upload artifacts
|
||||
uses: https://github.com/actions/upload-artifact@v3
|
||||
with:
|
||||
path: target/mutils-*.jar
|
22
src/main/java/eu/m724/tweaks/TweaksPlugin.java
Normal file
22
src/main/java/eu/m724/tweaks/TweaksPlugin.java
Normal file
|
@ -0,0 +1,22 @@
|
|||
package eu.m724.tweaks;
|
||||
|
||||
import eu.m724.tweaks.chat.ChatCommands;
|
||||
import eu.m724.tweaks.chat.ChatManager;
|
||||
import eu.m724.tweaks.door.DoorListener;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
|
||||
import java.util.Objects;
|
||||
|
||||
public class TweaksPlugin extends JavaPlugin {
|
||||
@Override
|
||||
public void onEnable() {
|
||||
ChatManager chatManager = new ChatManager(this);
|
||||
chatManager.init();
|
||||
|
||||
ChatCommands chatCommands = new ChatCommands(chatManager);
|
||||
Objects.requireNonNull(getCommand("chat")).setExecutor(chatCommands);
|
||||
Objects.requireNonNull(getCommand("chatmanage")).setExecutor(chatCommands);
|
||||
|
||||
getServer().getPluginManager().registerEvents(new DoorListener(), this);
|
||||
}
|
||||
}
|
20
src/main/java/eu/m724/tweaks/auth/AuthListener.java
Normal file
20
src/main/java/eu/m724/tweaks/auth/AuthListener.java
Normal file
|
@ -0,0 +1,20 @@
|
|||
package eu.m724.tweaks.auth;
|
||||
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.player.PlayerLoginEvent;
|
||||
|
||||
public class AuthListener implements Listener {
|
||||
private final AuthManager authManager;
|
||||
|
||||
public AuthListener(AuthManager authManager) {
|
||||
this.authManager = authManager;
|
||||
}
|
||||
|
||||
@EventHandler
|
||||
public void onPlayerLogin(PlayerLoginEvent event) {
|
||||
Player player = event.getPlayer();
|
||||
String hostname = event.getHostname();
|
||||
}
|
||||
}
|
11
src/main/java/eu/m724/tweaks/auth/AuthManager.java
Normal file
11
src/main/java/eu/m724/tweaks/auth/AuthManager.java
Normal file
|
@ -0,0 +1,11 @@
|
|||
package eu.m724.tweaks.auth;
|
||||
|
||||
import org.bukkit.plugin.Plugin;
|
||||
|
||||
public class AuthManager {
|
||||
private final Plugin plugin;
|
||||
|
||||
public AuthManager(Plugin plugin) {
|
||||
this.plugin = plugin;
|
||||
}
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
package eu.m724.utils.chat;
|
||||
package eu.m724.tweaks.chat;
|
||||
|
||||
import net.md_5.bungee.api.ChatColor;
|
||||
import net.md_5.bungee.api.chat.BaseComponent;
|
||||
|
@ -57,6 +57,8 @@ public class ChatCommands implements CommandExecutor {
|
|||
component = new ComponentBuilder("Invalid password").color(ChatColor.RED)
|
||||
.create();
|
||||
}
|
||||
} else {
|
||||
authenticated = true;
|
||||
}
|
||||
} else {
|
||||
component = new ComponentBuilder("No room named ").color(ChatColor.RED)
|
||||
|
@ -79,16 +81,14 @@ public class ChatCommands implements CommandExecutor {
|
|||
} else if (command.getName().equals("chatmanage")) {
|
||||
Player player = (Player) sender;
|
||||
ChatRoom chatRoom = manager.getPlayerChatRoom(player);
|
||||
|
||||
if (!chatRoom.owner.equals(player)) {
|
||||
sender.sendMessage("You're not the owner of %s, please enter the room you want to make changes in".formatted(chatRoom.id));
|
||||
return true;
|
||||
}
|
||||
boolean isOwner = player.equals(chatRoom.owner);
|
||||
|
||||
if (args.length > 1) {
|
||||
String action = args[0];
|
||||
String argument = args[1];
|
||||
if (action.equals("create")) {
|
||||
|
||||
switch (action) {
|
||||
case "create" -> {
|
||||
try {
|
||||
ChatRoom newRoom = manager.createChatRoom(argument, null, player);
|
||||
sender.sendMessage("Created a chat room. Join it: /c " + newRoom.id);
|
||||
|
@ -101,9 +101,20 @@ public class ChatCommands implements CommandExecutor {
|
|||
sender.sendMessage("Failed to create room");
|
||||
e.printStackTrace();
|
||||
}
|
||||
} else if (action.equals("delete")) {
|
||||
}
|
||||
case "delete" -> {
|
||||
if (argument.equals(chatRoom.id)) {
|
||||
if (isOwner) {
|
||||
// TODO
|
||||
} else if (action.equals("setowner")) {
|
||||
} else {
|
||||
sender.sendMessage("You're not the owner of %s, please enter the room you want to make changes in".formatted(chatRoom.id));
|
||||
}
|
||||
} else {
|
||||
sender.sendMessage("Pass %s as an argument to confirm".formatted(chatRoom.id));
|
||||
}
|
||||
}
|
||||
case "setowner" -> {
|
||||
if (isOwner) {
|
||||
Player newOwner = Bukkit.getPlayer(argument);
|
||||
if (newOwner != null && newOwner.isOnline()) {
|
||||
chatRoom.owner = newOwner;
|
||||
|
@ -117,7 +128,12 @@ public class ChatCommands implements CommandExecutor {
|
|||
} else {
|
||||
sender.sendMessage("Player must be online");
|
||||
}
|
||||
} else if (action.equals("setpassword")) {
|
||||
} else {
|
||||
sender.sendMessage("You're not the owner of %s, please enter the room you want to make changes in".formatted(chatRoom.id));
|
||||
}
|
||||
}
|
||||
case "setpassword" -> {
|
||||
if (isOwner) {
|
||||
chatRoom.password = Arrays.stream(args).skip(1).collect(Collectors.joining(" ")).strip();
|
||||
try {
|
||||
manager.saveChatRoom(chatRoom);
|
||||
|
@ -126,7 +142,12 @@ public class ChatCommands implements CommandExecutor {
|
|||
sender.sendMessage("Failed to change password");
|
||||
e.printStackTrace();
|
||||
}
|
||||
} else if (action.equals("setcolor")) {
|
||||
} else {
|
||||
sender.sendMessage("You're not the owner of %s, please enter the room you want to make changes in".formatted(chatRoom.id));
|
||||
}
|
||||
}
|
||||
case "setcolor" -> {
|
||||
if (isOwner) {
|
||||
ChatColor newColor = ChatColor.of(argument);
|
||||
if (newColor != null) {
|
||||
chatRoom.color = newColor;
|
||||
|
@ -140,6 +161,13 @@ public class ChatCommands implements CommandExecutor {
|
|||
} else {
|
||||
sender.sendMessage("Invalid color");
|
||||
}
|
||||
} else {
|
||||
sender.sendMessage("You're not the owner of %s, please enter the room you want to make changes in".formatted(chatRoom.id));
|
||||
}
|
||||
}
|
||||
default -> {
|
||||
sender.sendMessage("Actions: create, delete, setowner, setpassword, setcolor");
|
||||
}
|
||||
}
|
||||
} else if (args.length > 0) {
|
||||
switch (args[0]) {
|
||||
|
@ -153,10 +181,11 @@ public class ChatCommands implements CommandExecutor {
|
|||
sender.sendMessage("To change the password of room %s, pass the new password as an argument for this action.".formatted(chatRoom));
|
||||
case "setcolor" ->
|
||||
sender.sendMessage("To change the message color of room %s, pass the new color as an argument for this action. #hex or color name.".formatted(chatRoom));
|
||||
default -> sender.sendMessage("create, delete, setowner, setpassword");
|
||||
default ->
|
||||
sender.sendMessage("Actions: create, delete, setowner, setpassword, setcolor");
|
||||
}
|
||||
} else {
|
||||
sender.sendMessage("create, delete, setowner, setpassword, setcolor");
|
||||
sender.sendMessage("Actions: create, delete, setowner, setpassword, setcolor");
|
||||
}
|
||||
}
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package eu.m724.utils.chat;
|
||||
package eu.m724.tweaks.chat;
|
||||
|
||||
import net.md_5.bungee.api.ChatColor;
|
||||
import net.md_5.bungee.api.chat.BaseComponent;
|
|
@ -1,4 +1,4 @@
|
|||
package eu.m724.utils.chat;
|
||||
package eu.m724.tweaks.chat;
|
||||
|
||||
import org.bukkit.NamespacedKey;
|
||||
import org.bukkit.OfflinePlayer;
|
|
@ -1,4 +1,4 @@
|
|||
package eu.m724.utils.chat;
|
||||
package eu.m724.tweaks.chat;
|
||||
|
||||
import net.md_5.bungee.api.ChatColor;
|
||||
import net.md_5.bungee.api.chat.BaseComponent;
|
||||
|
@ -6,6 +6,7 @@ import net.md_5.bungee.api.chat.ComponentBuilder;
|
|||
import org.bukkit.OfflinePlayer;
|
||||
import org.bukkit.entity.Player;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
@ -37,15 +38,18 @@ public class ChatRoom {
|
|||
if (owner != null)
|
||||
builder = builder.append("\nOwner: ").color(ChatColor.GOLD)
|
||||
.append(owner.getName()).color(ChatColor.AQUA);
|
||||
|
||||
if (!players.isEmpty()) {
|
||||
builder = builder.append("\nOnline (%d): ".formatted(players.size())).color(ChatColor.GOLD);
|
||||
|
||||
List<Player> playersList = players.stream().sorted().toList();
|
||||
List<Player> playersList = new ArrayList<>(players);
|
||||
builder = builder.append(playersList.removeFirst().getName()).color(ChatColor.GRAY);
|
||||
|
||||
for (Player player : playersList) {
|
||||
builder = builder.append(", ").color(ChatColor.GRAY)
|
||||
.append(player.getName()).color(ChatColor.AQUA);
|
||||
}
|
||||
}
|
||||
|
||||
return builder.create();
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
package eu.m724.utils.chat;
|
||||
package eu.m724.tweaks.chat;
|
||||
|
||||
import net.md_5.bungee.api.ChatColor;
|
||||
import org.bukkit.Bukkit;
|
||||
|
@ -37,7 +37,7 @@ public class ChatRoomLoader {
|
|||
return 2;
|
||||
} else if (!id.equals(id.toLowerCase())) {
|
||||
return 3;
|
||||
} else if (id.chars().allMatch(Character::isLetterOrDigit)) {
|
||||
} else if (!id.chars().allMatch(Character::isLetterOrDigit)) {
|
||||
return 4;
|
||||
}
|
||||
|
113
src/main/java/eu/m724/tweaks/door/DoorListener.java
Normal file
113
src/main/java/eu/m724/tweaks/door/DoorListener.java
Normal file
|
@ -0,0 +1,113 @@
|
|||
package eu.m724.tweaks.door;
|
||||
|
||||
import org.bukkit.*;
|
||||
import org.bukkit.block.Block;
|
||||
import org.bukkit.block.BlockFace;
|
||||
import org.bukkit.block.data.type.Door;
|
||||
import org.bukkit.entity.Player;
|
||||
import org.bukkit.event.EventHandler;
|
||||
import org.bukkit.event.Listener;
|
||||
import org.bukkit.event.block.Action;
|
||||
import org.bukkit.event.block.BlockDamageEvent;
|
||||
import org.bukkit.event.player.PlayerInteractEvent;
|
||||
import org.bukkit.potion.PotionEffect;
|
||||
import org.bukkit.potion.PotionEffectType;
|
||||
import org.bukkit.util.RayTraceResult;
|
||||
|
||||
import java.util.concurrent.ThreadLocalRandom;
|
||||
|
||||
public class DoorListener implements Listener {
|
||||
@EventHandler
|
||||
public void onBlockDamage(BlockDamageEvent event) {
|
||||
Block block = event.getBlock();
|
||||
if (!(block.getBlockData() instanceof Door door)) return;
|
||||
|
||||
World world = block.getLocation().getWorld();
|
||||
Player player = event.getPlayer();
|
||||
|
||||
// TODO maybe it would be faster to check just player and the door
|
||||
RayTraceResult result = player.rayTraceBlocks(5);
|
||||
if (result == null) return;
|
||||
|
||||
Location hitLocation = result.getHitPosition().toLocation(world);
|
||||
double distance = player.getEyeLocation().distanceSquared(hitLocation);
|
||||
if (distance > 12) return;
|
||||
|
||||
Sound sound = block.getType() == Material.IRON_DOOR ? Sound.ENTITY_ZOMBIE_ATTACK_IRON_DOOR : Sound.ENTITY_ZOMBIE_ATTACK_WOODEN_DOOR;
|
||||
float volume = player.isSneaking() ? 0.4f : 1f;
|
||||
float pitch = player.getFallDistance() > 0 ? 1f : 1.5f;
|
||||
|
||||
if (player.hasPotionEffect(PotionEffectType.NAUSEA)) {
|
||||
pitch = ThreadLocalRandom.current().nextFloat(0.5f, 0.7f);
|
||||
}
|
||||
|
||||
PotionEffect weakness = player.getPotionEffect(PotionEffectType.WEAKNESS);
|
||||
PotionEffect fatigue = player.getPotionEffect(PotionEffectType.MINING_FATIGUE);
|
||||
int level = (weakness != null ? weakness.getAmplifier() : 0) + (fatigue != null ? fatigue.getAmplifier() : 0);
|
||||
|
||||
if (weakness != null || fatigue != null) {
|
||||
volume /= level / 3f;
|
||||
pitch /= level;
|
||||
}
|
||||
|
||||
volume *= (float) ((10.0 - Math.min(distance - 2, 10.0)) / 10.0);
|
||||
|
||||
world.playSound(hitLocation, sound, volume, pitch);
|
||||
world.spawnParticle(Particle.BLOCK, hitLocation, (int) (10 * volume), door);
|
||||
}
|
||||
|
||||
@EventHandler
|
||||
public void onPlayerInteract(PlayerInteractEvent event) {
|
||||
// make sure the player is opening a door
|
||||
if (!event.hasBlock()) return;
|
||||
if (event.getAction() != Action.RIGHT_CLICK_BLOCK) return;
|
||||
Block block = event.getClickedBlock();
|
||||
if (!(block.getBlockData() instanceof Door door)) return;
|
||||
|
||||
// check if the doors are in like one line
|
||||
boolean right = door.getHinge() == Door.Hinge.RIGHT;
|
||||
Location location = block.getLocation();
|
||||
BlockFace expectedFacing = door.getFacing();
|
||||
|
||||
switch (door.getFacing()) {
|
||||
case NORTH -> location.add(right ? -1 : 1, 0, 0);
|
||||
case SOUTH -> location.add(right ? 1 : -1, 0, 0);
|
||||
case EAST -> location.add(0, 0, right ? -1 : 1);
|
||||
case WEST -> location.add(0, 0, right ? 1 : -1);
|
||||
}
|
||||
|
||||
// if not, check if the doors are a corner
|
||||
if (location.getBlock().isEmpty()) {
|
||||
location = block.getLocation();
|
||||
|
||||
switch (door.getFacing()) {
|
||||
case NORTH -> {
|
||||
location.add(right ? -1 : 1, 0, 1);
|
||||
expectedFacing = right ? BlockFace.WEST : BlockFace.EAST;
|
||||
}
|
||||
case SOUTH -> {
|
||||
location.add(right ? 1 : -1, 0, -1);
|
||||
expectedFacing = right ? BlockFace.EAST : BlockFace.WEST;
|
||||
}
|
||||
case EAST -> {
|
||||
location.add(-1, 0, right ? -1 : 1);
|
||||
expectedFacing = right ? BlockFace.NORTH : BlockFace.SOUTH;
|
||||
}
|
||||
case WEST -> {
|
||||
location.add(1, 0, right ? 1 : -1);
|
||||
expectedFacing = right ? BlockFace.SOUTH : BlockFace.NORTH;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// if there's a second door placed correctly
|
||||
if (location.getBlock().getType() == block.getType()) {
|
||||
Door nextDoor = (Door) location.getBlock().getBlockData();
|
||||
if (nextDoor.getHinge() == door.getHinge()) return;
|
||||
if (nextDoor.getFacing() != expectedFacing) return;
|
||||
// ! because it seems door is actually opening after this event
|
||||
nextDoor.setOpen(!door.isOpen());
|
||||
location.getBlock().setBlockData(nextDoor);
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,16 +0,0 @@
|
|||
package eu.m724.utils;
|
||||
|
||||
import eu.m724.utils.chat.ChatCommands;
|
||||
import eu.m724.utils.chat.ChatManager;
|
||||
import org.bukkit.plugin.java.JavaPlugin;
|
||||
|
||||
public class UtilsPlugin extends JavaPlugin {
|
||||
@Override
|
||||
public void onEnable() {
|
||||
ChatManager chatManager = new ChatManager(this);
|
||||
chatManager.init();
|
||||
|
||||
ChatCommands chatCommands = new ChatCommands(chatManager);
|
||||
getCommand("chat").setExecutor(chatCommands);
|
||||
}
|
||||
}
|
|
@ -1,7 +1,7 @@
|
|||
name: mUtils724
|
||||
name: Tweaks724
|
||||
version: ${project.version}
|
||||
|
||||
main: eu.m724.utils.UtilsPlugin
|
||||
main: eu.m724.tweaks.TweaksPlugin
|
||||
api-version: 1.21.1
|
||||
|
||||
commands:
|
||||
|
|
Loading…
Reference in a new issue