2024-07-11 13:43:54 -05:00
|
|
|
package one.oth3r.sit.utl;
|
|
|
|
|
2024-07-23 13:49:43 -05:00
|
|
|
import net.fabricmc.fabric.api.client.event.lifecycle.v1.ClientTickEvents;
|
|
|
|
import net.fabricmc.fabric.api.client.keybinding.v1.KeyBindingHelper;
|
|
|
|
import net.fabricmc.fabric.api.client.networking.v1.ClientPlayConnectionEvents;
|
|
|
|
import net.fabricmc.fabric.api.client.networking.v1.ClientPlayNetworking;
|
2024-07-11 13:43:54 -05:00
|
|
|
import net.fabricmc.fabric.api.command.v2.CommandRegistrationCallback;
|
|
|
|
import net.fabricmc.fabric.api.event.lifecycle.v1.ServerLifecycleEvents;
|
|
|
|
import net.fabricmc.fabric.api.event.lifecycle.v1.ServerTickEvents;
|
|
|
|
import net.fabricmc.fabric.api.event.player.UseBlockCallback;
|
2024-07-23 13:49:43 -05:00
|
|
|
import net.fabricmc.fabric.api.networking.v1.PayloadTypeRegistry;
|
2024-07-11 13:43:54 -05:00
|
|
|
import net.fabricmc.fabric.api.networking.v1.ServerPlayConnectionEvents;
|
2024-07-23 13:49:43 -05:00
|
|
|
import net.fabricmc.fabric.api.networking.v1.ServerPlayNetworking;
|
|
|
|
import net.minecraft.client.network.ClientPlayerEntity;
|
|
|
|
import net.minecraft.client.option.KeyBinding;
|
2024-07-11 13:43:54 -05:00
|
|
|
import net.minecraft.server.network.ServerPlayerEntity;
|
|
|
|
import net.minecraft.util.ActionResult;
|
2024-07-23 13:49:43 -05:00
|
|
|
import net.minecraft.util.Formatting;
|
2024-07-11 13:43:54 -05:00
|
|
|
import one.oth3r.sit.command.SitCommand;
|
2024-07-23 13:49:43 -05:00
|
|
|
import one.oth3r.sit.file.FileData;
|
|
|
|
import one.oth3r.sit.file.SittingConfig;
|
|
|
|
import one.oth3r.sit.packet.SitPayloads;
|
|
|
|
import org.lwjgl.glfw.GLFW;
|
2024-07-11 13:43:54 -05:00
|
|
|
|
|
|
|
public class Events {
|
|
|
|
|
2024-07-23 13:49:43 -05:00
|
|
|
private static class Keybindings {
|
|
|
|
private static KeyBinding toggle_key;
|
|
|
|
|
|
|
|
private static void register() {
|
|
|
|
toggle_key = KeyBindingHelper.registerKeyBinding(new KeyBinding(
|
|
|
|
"key.toggle",
|
|
|
|
GLFW.GLFW_KEY_UNKNOWN,
|
|
|
|
"category.sit"
|
|
|
|
));
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void loopLogic(ClientPlayerEntity player) {
|
|
|
|
while (toggle_key.isPressed()) {
|
|
|
|
toggle_key.setPressed(false);
|
|
|
|
if (Data.isInGame()) {
|
2024-07-26 09:42:05 -05:00
|
|
|
// todo move to logic.java
|
2024-07-23 13:49:43 -05:00
|
|
|
if (Data.isSupportedServer()) {
|
|
|
|
// get the sitting config
|
|
|
|
SittingConfig config = FileData.getSittingConfig();
|
|
|
|
// toggle the setting
|
|
|
|
config.setEnabled(!config.getEnabled());
|
|
|
|
|
|
|
|
// set the sitting config to the new value
|
|
|
|
FileData.setSittingConfig(config);
|
|
|
|
// save the changes to the file
|
|
|
|
SittingConfig.save();
|
|
|
|
// send the changes to the server
|
|
|
|
Utl.sendSettingsPackets();
|
|
|
|
|
|
|
|
|
|
|
|
// get the message settings
|
|
|
|
String messageKey = "msg.sit_toggle."+(config.getEnabled()?"on":"off");
|
|
|
|
Formatting messageColor = config.getEnabled()?Formatting.GREEN:Formatting.RED;
|
|
|
|
|
|
|
|
// send the player the actionbar message
|
|
|
|
player.sendMessage(Utl.lang("msg.sit_toggle",
|
|
|
|
Utl.lang(messageKey).formatted(messageColor)), true);
|
|
|
|
} else {
|
2024-07-26 09:42:05 -05:00
|
|
|
// unsupported server message if not in a Sit! server
|
2024-07-23 13:49:43 -05:00
|
|
|
player.sendMessage(Utl.lang("msg.sit_toggle.unsupported")
|
|
|
|
.formatted(Formatting.RED), true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static class Packet {
|
|
|
|
private static void common() {
|
|
|
|
// register the data
|
|
|
|
PayloadTypeRegistry.playC2S().register(SitPayloads.SettingsPayload.ID, SitPayloads.SettingsPayload.CODEC);
|
|
|
|
|
|
|
|
PayloadTypeRegistry.playS2C().register(SitPayloads.ResponsePayload.ID, SitPayloads.ResponsePayload.CODEC);
|
|
|
|
|
|
|
|
// server receiver is common
|
|
|
|
ServerPlayNetworking.registerGlobalReceiver(SitPayloads.SettingsPayload.ID,((payload, context) -> Data.getServer().execute(() -> {
|
|
|
|
FileData.setPlayerSetting(context.player(),Utl.getGson().fromJson(payload.value(), SittingConfig.class));
|
|
|
|
// send the player back a packet for conformation
|
|
|
|
ServerPlayNetworking.send(context.player(),new SitPayloads.ResponsePayload(SitPayloads.ResponsePayload.VERSION));
|
|
|
|
})));
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void client() {
|
|
|
|
ClientPlayNetworking.registerGlobalReceiver(SitPayloads.ResponsePayload.ID, ((payload, context) -> {
|
|
|
|
// only update when needed
|
|
|
|
if (!Data.isSupportedServer()) {
|
|
|
|
Data.setSupportedServer(true);
|
|
|
|
Data.LOGGER.info("Connected to Sit! server! packet: {}", payload.value());
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void clientMisc() {
|
|
|
|
// client tick loop
|
|
|
|
ClientTickEvents.END_CLIENT_TICK.register(client -> {
|
|
|
|
assert client.player != null;
|
|
|
|
Keybindings.loopLogic(client.player);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* registers all client connection code
|
|
|
|
*/
|
|
|
|
private static void clientConnections() {
|
|
|
|
ClientPlayConnectionEvents.JOIN.register((handler, sender, client) -> {
|
|
|
|
Data.setInGame(true);
|
|
|
|
if (client.isInSingleplayer()) Data.setSingleplayer(true);
|
|
|
|
// send a data packet whenever joining a server
|
|
|
|
Utl.sendSettingsPackets();
|
|
|
|
});
|
|
|
|
|
|
|
|
// reset cashed things on disconnect
|
|
|
|
ClientPlayConnectionEvents.DISCONNECT.register((handler, client) -> {
|
|
|
|
Data.setInGame(false);
|
|
|
|
Data.setSingleplayer(false);
|
|
|
|
Data.setSupportedServer(false);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* registers all common server player connection code
|
|
|
|
*/
|
|
|
|
private static void playerConnections() {
|
2024-07-11 13:43:54 -05:00
|
|
|
// PLAYER JOIN
|
|
|
|
ServerPlayConnectionEvents.JOIN.register((handler, sender, server) -> {
|
2024-07-23 13:49:43 -05:00
|
|
|
FileData.setPlayerSetting(handler.player, FileData.getSittingConfig());
|
|
|
|
FileData.setCheckPlayer(handler.player, 5);
|
2024-07-11 13:43:54 -05:00
|
|
|
});
|
|
|
|
|
|
|
|
ServerPlayConnectionEvents.DISCONNECT.register((handler, server) -> {
|
|
|
|
// if keep is off, remove the entity
|
2024-07-23 13:49:43 -05:00
|
|
|
if (!FileData.getServerConfig().isKeepActive()) {
|
2024-07-11 13:43:54 -05:00
|
|
|
Logic.removeEntity(handler.player);
|
|
|
|
}
|
2024-07-23 13:49:43 -05:00
|
|
|
FileData.removePlayerSetting(handler.player);
|
2024-07-11 13:43:54 -05:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2024-07-23 13:49:43 -05:00
|
|
|
/**
|
|
|
|
* registers all server lifecycle events
|
|
|
|
*/
|
|
|
|
private static void serverLifecycle() {
|
2024-07-11 13:43:54 -05:00
|
|
|
ServerLifecycleEvents.SERVER_STARTED.register(s -> {
|
2024-07-23 13:49:43 -05:00
|
|
|
Data.setServer(s);
|
2024-07-11 13:43:54 -05:00
|
|
|
|
|
|
|
// right click on block event
|
|
|
|
UseBlockCallback.EVENT.register((pl, world, hand, hitResult) -> {
|
|
|
|
// get the server player
|
2024-07-23 13:49:43 -05:00
|
|
|
ServerPlayerEntity player = Data.getServer().getPlayerManager().getPlayer(pl.getUuid());
|
2024-07-11 13:43:54 -05:00
|
|
|
|
|
|
|
// make sure the player isn't null, and make sure they aren't in spectator
|
|
|
|
if (player == null || player.isSpectator()) return ActionResult.PASS;
|
|
|
|
|
|
|
|
// consume if sitting, if not pass
|
|
|
|
return Logic.sit(player,hitResult.getBlockPos(),hitResult)? ActionResult.CONSUME : ActionResult.PASS;
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
ServerLifecycleEvents.SERVER_STOPPED.register(s -> {
|
2024-07-23 13:49:43 -05:00
|
|
|
// clear the server
|
|
|
|
Data.setServer(null);
|
2024-07-11 13:43:54 -05:00
|
|
|
// clear all player settings (singleplayer and such)
|
2024-07-23 13:49:43 -05:00
|
|
|
FileData.clearPlayerSettings();
|
2024-07-11 13:43:54 -05:00
|
|
|
});
|
|
|
|
|
2024-07-23 13:49:43 -05:00
|
|
|
// server loop setup
|
2024-07-11 13:43:54 -05:00
|
|
|
ServerTickEvents.END_SERVER_TICK.register(minecraftServer -> minecraftServer.execute(LoopManager::tick));
|
|
|
|
|
2024-07-23 13:49:43 -05:00
|
|
|
// server command setup
|
2024-07-11 13:43:54 -05:00
|
|
|
CommandRegistrationCallback.EVENT.register((dispatcher, registryAccess, environment) -> SitCommand.register(dispatcher));
|
|
|
|
}
|
|
|
|
|
2024-07-23 13:49:43 -05:00
|
|
|
// a one call method for the common and client
|
|
|
|
|
2024-07-11 13:43:54 -05:00
|
|
|
public static void registerCommon() {
|
|
|
|
playerConnections();
|
2024-07-23 13:49:43 -05:00
|
|
|
serverLifecycle();
|
|
|
|
Packet.common();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static void registerClient() {
|
|
|
|
Keybindings.register();
|
|
|
|
clientConnections();
|
|
|
|
clientMisc();
|
|
|
|
Packet.client();
|
2024-07-11 13:43:54 -05:00
|
|
|
}
|
|
|
|
}
|