feat: 新版 API
This commit is contained in:
@@ -3,8 +3,6 @@ package cn.hamster3.mc.plugin.ball.bukkit;
|
|||||||
import cn.hamster3.mc.plugin.ball.bukkit.api.BallBukkitAPI;
|
import cn.hamster3.mc.plugin.ball.bukkit.api.BallBukkitAPI;
|
||||||
import cn.hamster3.mc.plugin.ball.bukkit.hook.PlaceholderHook;
|
import cn.hamster3.mc.plugin.ball.bukkit.hook.PlaceholderHook;
|
||||||
import cn.hamster3.mc.plugin.ball.bukkit.listener.BallBukkitListener;
|
import cn.hamster3.mc.plugin.ball.bukkit.listener.BallBukkitListener;
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOnlineEvent;
|
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
import org.bukkit.plugin.java.JavaPlugin;
|
import org.bukkit.plugin.java.JavaPlugin;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@@ -55,20 +53,8 @@ public class HamsterBallPlugin extends JavaPlugin {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
if (!BallAPI.getInstance().isEnabled()) {
|
|
||||||
sync(() -> {
|
|
||||||
logger.info("由于 HamsterBall 未能成功连接, 服务器将立即关闭");
|
|
||||||
Bukkit.shutdown();
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Bukkit.getPluginManager().registerEvents(BallBukkitListener.INSTANCE, this);
|
Bukkit.getPluginManager().registerEvents(BallBukkitListener.INSTANCE, this);
|
||||||
logger.info("已注册 BallBukkitListener");
|
logger.info("已注册 BallBukkitListener");
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
ServerOnlineEvent.ACTION,
|
|
||||||
new ServerOnlineEvent(BallAPI.getInstance().getLocalServerInfo())
|
|
||||||
);
|
|
||||||
sync(() -> {
|
sync(() -> {
|
||||||
if (Bukkit.getPluginManager().isPluginEnabled("PlaceholderAPI")) {
|
if (Bukkit.getPluginManager().isPluginEnabled("PlaceholderAPI")) {
|
||||||
PlaceholderHook.INSTANCE.register();
|
PlaceholderHook.INSTANCE.register();
|
||||||
|
@@ -1,10 +1,18 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.bukkit.api;
|
package cn.hamster3.mc.plugin.ball.bukkit.api;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.bukkit.HamsterBallPlugin;
|
import cn.hamster3.mc.plugin.ball.bukkit.HamsterBallPlugin;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bukkit.event.MessageSendEvent;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bukkit.event.operate.*;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bukkit.event.player.*;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bukkit.event.server.ServerOfflineEvent;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bukkit.event.server.ServerOnlineEvent;
|
||||||
import cn.hamster3.mc.plugin.ball.bukkit.util.BallBukkitUtils;
|
import cn.hamster3.mc.plugin.ball.bukkit.util.BallBukkitUtils;
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.event.BallActions;
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
||||||
import io.lettuce.core.RedisClient;
|
import io.lettuce.core.RedisClient;
|
||||||
import org.bukkit.Bukkit;
|
import org.bukkit.Bukkit;
|
||||||
@@ -71,9 +79,167 @@ public class BallBukkitAPI extends BallAPI {
|
|||||||
super.disable();
|
super.disable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sendBallMessage(@NotNull String channel, @NotNull BallMessage message, boolean block) {
|
||||||
|
Bukkit.getPluginManager().callEvent(new MessageSendEvent(Bukkit.isPrimaryThread(), channel, message));
|
||||||
|
super.sendBallMessage(channel, message, block);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onMessage(String channel, BallMessage message) {
|
||||||
|
if (!BallAPI.BALL_CHANNEL.equals(channel)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (BallActions.valueOf(message.getAction())) {
|
||||||
|
case BroadcastPlayerMessage: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BroadcastPlayerMessageEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DispatchConsoleCommand: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(DispatchConsoleCommandEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DispatchPlayerCommand: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(DispatchPlayerCommandEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case KickPlayer: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(KickPlayerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SendMessageToPlayer: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(SendMessageToPlayerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SendPlayerToLocation: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(SendPlayerToLocationEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SendPlayerToPlayer: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(SendPlayerToPlayerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerInfoUpdate: {
|
||||||
|
BallPlayerInfoUpdateEvent event = message.getContentAs(BallPlayerInfoUpdateEvent.class);
|
||||||
|
Bukkit.getPluginManager().callEvent(event);
|
||||||
|
BallPlayerInfo info = event.getPlayerInfo();
|
||||||
|
playerInfo.put(info.getUuid(), info);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPreLogin: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPreLoginEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerLogin: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerLoginEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPostLogin: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPostLoginEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPreConnectServer: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPreConnectServerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerConnectServer: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerConnectServerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPostConnectServer: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPostConnectServerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerLogout: {
|
||||||
|
Bukkit.getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerLogoutEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case ServerOnline: {
|
||||||
|
ServerOnlineEvent event = message.getContentAs(ServerOnlineEvent.class);
|
||||||
|
Bukkit.getPluginManager().callEvent(event);
|
||||||
|
BallServerInfo info = event.getServerInfo();
|
||||||
|
serverInfo.put(info.getId(), info);
|
||||||
|
switch (info.getType()) {
|
||||||
|
case GAME: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getGameServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PROXY: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getProxyServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case ServerOffline: {
|
||||||
|
ServerOfflineEvent event = message.getContentAs(ServerOfflineEvent.class);
|
||||||
|
Bukkit.getPluginManager().callEvent(event);
|
||||||
|
String serverID = event.getServerInfo().getId();
|
||||||
|
BallServerInfo info = serverInfo.remove(serverID);
|
||||||
|
if (info == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (info.getType()) {
|
||||||
|
case GAME: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getGameServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PROXY: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getProxyServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull Logger getLogger() {
|
public @NotNull Logger getLogger() {
|
||||||
return HamsterBallPlugin.getInstance().getLogger();
|
return HamsterBallPlugin.getInstance().getLogger();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class MessageReceiveEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final String channel;
|
||||||
|
@NotNull
|
||||||
|
private final BallMessage message;
|
||||||
|
|
||||||
|
public MessageReceiveEvent(@NotNull String channel, @NotNull BallMessage message) {
|
||||||
|
super(true);
|
||||||
|
this.channel = channel;
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class MessageSendEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final String channel;
|
||||||
|
@NotNull
|
||||||
|
private final BallMessage message;
|
||||||
|
|
||||||
|
public MessageSendEvent(boolean isAsync, @NotNull String channel, @NotNull BallMessage message) {
|
||||||
|
super(isAsync);
|
||||||
|
this.channel = channel;
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,28 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class BroadcastPlayerMessageEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final DisplayMessage message;
|
||||||
|
|
||||||
|
public BroadcastPlayerMessageEvent(@NotNull DisplayMessage message) {
|
||||||
|
super(true);
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,34 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class DispatchConsoleCommandEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
private final BallServerType serverType;
|
||||||
|
@Nullable
|
||||||
|
private final String serverID;
|
||||||
|
@NotNull
|
||||||
|
private final String command;
|
||||||
|
|
||||||
|
public DispatchConsoleCommandEvent(@Nullable BallServerType serverType, @Nullable String serverID, @NotNull String command) {
|
||||||
|
super(true);
|
||||||
|
this.serverType = serverType;
|
||||||
|
this.serverID = serverID;
|
||||||
|
this.command = command;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,36 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class DispatchPlayerCommandEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@Nullable
|
||||||
|
private final BallServerType serverType;
|
||||||
|
@Nullable
|
||||||
|
private final UUID uuid;
|
||||||
|
@NotNull
|
||||||
|
private final String command;
|
||||||
|
|
||||||
|
public DispatchPlayerCommandEvent(@Nullable BallServerType serverType, @Nullable UUID uuid, @NotNull String command) {
|
||||||
|
super(true);
|
||||||
|
this.serverType = serverType;
|
||||||
|
this.uuid = uuid;
|
||||||
|
this.command = command;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,32 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.text.Component;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class KickPlayerEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final UUID uuid;
|
||||||
|
@NotNull
|
||||||
|
private final Component reason;
|
||||||
|
|
||||||
|
public KickPlayerEvent(@NotNull UUID uuid, @NotNull Component reason) {
|
||||||
|
super(true);
|
||||||
|
this.uuid = uuid;
|
||||||
|
this.reason = reason;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,33 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class SendMessageToPlayerEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final Set<UUID> receivers;
|
||||||
|
@NotNull
|
||||||
|
private final DisplayMessage message;
|
||||||
|
|
||||||
|
public SendMessageToPlayerEvent(@NotNull Set<UUID> receivers, @NotNull DisplayMessage message) {
|
||||||
|
super(true);
|
||||||
|
this.receivers = receivers;
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,38 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallLocation;
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class SendPlayerToLocationEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final Set<UUID> sendPlayer;
|
||||||
|
@NotNull
|
||||||
|
private final BallLocation location;
|
||||||
|
@Nullable
|
||||||
|
private final DisplayMessage doneMessage;
|
||||||
|
|
||||||
|
public SendPlayerToLocationEvent(@NotNull Set<UUID> sendPlayer, @NotNull BallLocation location, @Nullable DisplayMessage doneMessage) {
|
||||||
|
super(true);
|
||||||
|
this.sendPlayer = sendPlayer;
|
||||||
|
this.location = location;
|
||||||
|
this.doneMessage = doneMessage;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,41 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class SendPlayerToPlayerEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final Set<UUID> sendPlayer;
|
||||||
|
@NotNull
|
||||||
|
private final UUID toPlayer;
|
||||||
|
@Nullable
|
||||||
|
private final DisplayMessage doneMessage;
|
||||||
|
@Nullable
|
||||||
|
private final DisplayMessage doneTargetMessage;
|
||||||
|
|
||||||
|
public SendPlayerToPlayerEvent(@NotNull Set<UUID> sendPlayer, @NotNull UUID toPlayer, @Nullable DisplayMessage doneMessage, @Nullable DisplayMessage doneTargetMessage) {
|
||||||
|
super(true);
|
||||||
|
this.sendPlayer = sendPlayer;
|
||||||
|
this.toPlayer = toPlayer;
|
||||||
|
this.doneMessage = doneMessage;
|
||||||
|
this.doneTargetMessage = doneTargetMessage;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,43 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家进入子服
|
||||||
|
* <p>
|
||||||
|
* 仅在使用 velocity 代理端时才会触发这个事件
|
||||||
|
*
|
||||||
|
* @see BallPlayerPreConnectServerEvent 玩家准备进入子服
|
||||||
|
* @see BallPlayerConnectServerEvent 玩家进入子服
|
||||||
|
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerConnectServerEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@Nullable
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
|
|
||||||
|
public BallPlayerConnectServerEvent(@NotNull BallPlayerInfo playerInfo, @Nullable String from, @NotNull String to) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
this.from = from;
|
||||||
|
this.to = to;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家已进入子服
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerInfoUpdateEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
|
||||||
|
public BallPlayerInfoUpdateEvent(@NotNull BallPlayerInfo playerInfo) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,31 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家连接到代理服务器
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerLoginEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
|
||||||
|
public BallPlayerLoginEvent(@NotNull BallPlayerInfo playerInfo) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家与代理服务器断开连接
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerLogoutEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
|
||||||
|
public BallPlayerLogoutEvent(@NotNull BallPlayerInfo playerInfo) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,40 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家已经进入子服
|
||||||
|
*
|
||||||
|
* @see BallPlayerPreConnectServerEvent 玩家准备进入子服
|
||||||
|
* @see BallPlayerConnectServerEvent 玩家进入子服
|
||||||
|
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerPostConnectServerEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@NotNull
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
|
|
||||||
|
public BallPlayerPostConnectServerEvent(@NotNull BallPlayerInfo playerInfo, @NotNull String from, @NotNull String to) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
this.from = from;
|
||||||
|
this.to = to;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家已连接到代理服务器
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerPostLoginEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
|
||||||
|
public BallPlayerPostLoginEvent(@NotNull BallPlayerInfo playerInfo) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,41 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家准备进入子服
|
||||||
|
*
|
||||||
|
* @see BallPlayerPreConnectServerEvent 玩家准备进入子服
|
||||||
|
* @see BallPlayerConnectServerEvent 玩家进入子服
|
||||||
|
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerPreConnectServerEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@Nullable
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
|
|
||||||
|
public BallPlayerPreConnectServerEvent(@NotNull BallPlayerInfo playerInfo, @Nullable String from, @NotNull String to) {
|
||||||
|
super(true);
|
||||||
|
this.playerInfo = playerInfo;
|
||||||
|
this.from = from;
|
||||||
|
this.to = to;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,29 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.player;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家准备连接到代理服务器
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class BallPlayerPreLoginEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final String playerName;
|
||||||
|
|
||||||
|
public BallPlayerPreLoginEvent(@NotNull String playerName) {
|
||||||
|
super(true);
|
||||||
|
this.playerName = playerName;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.server;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 服务器离线
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class ServerOfflineEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallServerInfo serverInfo;
|
||||||
|
|
||||||
|
public ServerOfflineEvent(@NotNull BallServerInfo serverInfo) {
|
||||||
|
super(true);
|
||||||
|
this.serverInfo = serverInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,30 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bukkit.event.server;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
|
import lombok.Getter;
|
||||||
|
import org.bukkit.event.Event;
|
||||||
|
import org.bukkit.event.HandlerList;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 服务器上线
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
public class ServerOnlineEvent extends Event {
|
||||||
|
@Getter
|
||||||
|
private static final HandlerList handlerList = new HandlerList();
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final BallServerInfo serverInfo;
|
||||||
|
|
||||||
|
public ServerOnlineEvent(@NotNull BallServerInfo serverInfo) {
|
||||||
|
super(true);
|
||||||
|
this.serverInfo = serverInfo;
|
||||||
|
}
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
@Override
|
||||||
|
public HandlerList getHandlers() {
|
||||||
|
return handlerList;
|
||||||
|
}
|
||||||
|
}
|
@@ -2,11 +2,9 @@ package cn.hamster3.mc.plugin.ball.bukkit.listener;
|
|||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.bukkit.HamsterBallPlugin;
|
import cn.hamster3.mc.plugin.ball.bukkit.HamsterBallPlugin;
|
||||||
import cn.hamster3.mc.plugin.ball.bukkit.data.BukkitLocation;
|
import cn.hamster3.mc.plugin.ball.bukkit.data.BukkitLocation;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bukkit.event.operate.*;
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.operate.*;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.listener.BallListener;
|
|
||||||
import cn.hamster3.mc.plugin.core.bukkit.api.CoreBukkitAPI;
|
import cn.hamster3.mc.plugin.core.bukkit.api.CoreBukkitAPI;
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
||||||
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
@@ -33,7 +31,7 @@ import java.util.HashMap;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
|
||||||
public class BallBukkitListener implements Listener, BallListener {
|
public class BallBukkitListener implements Listener {
|
||||||
public static final BallBukkitListener INSTANCE = new BallBukkitListener();
|
public static final BallBukkitListener INSTANCE = new BallBukkitListener();
|
||||||
|
|
||||||
private final HashMap<UUID, ToLocation> playerToLocation = new HashMap<>();
|
private final HashMap<UUID, ToLocation> playerToLocation = new HashMap<>();
|
||||||
@@ -42,108 +40,6 @@ public class BallBukkitListener implements Listener, BallListener {
|
|||||||
private BallBukkitListener() {
|
private BallBukkitListener() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onMessageReceived(@NotNull BallMessageInfo info) {
|
|
||||||
switch (info.getAction()) {
|
|
||||||
case BroadcastPlayerMessageEvent.ACTION: {
|
|
||||||
BroadcastPlayerMessageEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BroadcastPlayerMessageEvent.class);
|
|
||||||
DisplayMessage message = event.getMessage();
|
|
||||||
Audience audience = CoreAPI.getInstance().getAudienceProvider().all();
|
|
||||||
message.show(audience);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case DispatchConsoleCommandEvent.ACTION: {
|
|
||||||
DispatchConsoleCommandEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), DispatchConsoleCommandEvent.class);
|
|
||||||
if (event.getType() != null && event.getType() != BallServerType.GAME) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (event.getServerID() != null && !BallAPI.getInstance().isLocalServer(event.getServerID())) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Bukkit.dispatchCommand(Bukkit.getConsoleSender(), event.getCommand());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case DispatchPlayerCommandEvent.ACTION: {
|
|
||||||
DispatchPlayerCommandEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), DispatchPlayerCommandEvent.class);
|
|
||||||
if (event.getType() != null && event.getType() != BallServerType.GAME) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (event.getUuid() != null) {
|
|
||||||
Player player = Bukkit.getPlayer(event.getUuid());
|
|
||||||
if (player == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
Bukkit.dispatchCommand(player, event.getCommand());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (Player player : Bukkit.getOnlinePlayers()) {
|
|
||||||
Bukkit.dispatchCommand(player, event.getCommand());
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case SendPlayerToLocationEvent.ACTION: {
|
|
||||||
SendPlayerToLocationEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), SendPlayerToLocationEvent.class);
|
|
||||||
BukkitLocation location = new BukkitLocation(event.getLocation());
|
|
||||||
if (BallAPI.getInstance().isLocalServer(location.getServerID())) {
|
|
||||||
for (UUID uuid : event.getSendPlayerUUID()) {
|
|
||||||
Player player = Bukkit.getPlayer(uuid);
|
|
||||||
if (player != null) {
|
|
||||||
HamsterBallPlugin.sync(() -> {
|
|
||||||
player.teleport(location.toBukkitLocation());
|
|
||||||
if (event.getDoneMessage() != null) {
|
|
||||||
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(player);
|
|
||||||
event.getDoneMessage().show(audience);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
playerToLocation.put(uuid, new ToLocation(location.toBukkitLocation(), event.getDoneMessage()));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case SendPlayerToPlayerEvent.ACTION: {
|
|
||||||
SendPlayerToPlayerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), SendPlayerToPlayerEvent.class);
|
|
||||||
Player toPlayer = Bukkit.getPlayer(event.getToPlayerUUID());
|
|
||||||
if (toPlayer == null) {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
Location location = toPlayer.getLocation();
|
|
||||||
for (UUID uuid : event.getSendPlayerUUID()) {
|
|
||||||
Player sendPlayer = Bukkit.getPlayer(uuid);
|
|
||||||
if (sendPlayer != null) {
|
|
||||||
HamsterBallPlugin.sync(() -> {
|
|
||||||
sendPlayer.teleport(location);
|
|
||||||
if (event.getDoneMessage() != null) {
|
|
||||||
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(sendPlayer);
|
|
||||||
event.getDoneMessage().show(audience, TextReplacementConfig.builder()
|
|
||||||
.matchLiteral("%player_name%")
|
|
||||||
.replacement(toPlayer.getName())
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
if (event.getDoneTargetMessage() != null) {
|
|
||||||
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(toPlayer);
|
|
||||||
event.getDoneTargetMessage().show(audience, TextReplacementConfig.builder()
|
|
||||||
.matchLiteral("%player_name%")
|
|
||||||
.replacement(sendPlayer.getName())
|
|
||||||
.build());
|
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
ToPlayer data = new ToPlayer(
|
|
||||||
toPlayer.getUniqueId(),
|
|
||||||
toPlayer.getLocation(),
|
|
||||||
event.getDoneMessage(),
|
|
||||||
event.getDoneTargetMessage()
|
|
||||||
);
|
|
||||||
playerToPlayer.put(uuid, data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
||||||
public void onPlayerJoin(PlayerJoinEvent event) {
|
public void onPlayerJoin(PlayerJoinEvent event) {
|
||||||
Player player = event.getPlayer();
|
Player player = event.getPlayer();
|
||||||
@@ -189,6 +85,102 @@ public class BallBukkitListener implements Listener, BallListener {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
||||||
|
public void onBroadcastPlayerMessage(BroadcastPlayerMessageEvent event) {
|
||||||
|
DisplayMessage message = event.getMessage();
|
||||||
|
Audience audience = CoreAPI.getInstance().getAudienceProvider().all();
|
||||||
|
message.show(audience);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
||||||
|
public void onDispatchConsoleCommand(DispatchConsoleCommandEvent event) {
|
||||||
|
if (event.getServerType() != null && event.getServerType() != BallServerType.GAME) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (event.getServerID() != null && !BallAPI.getInstance().isLocalServer(event.getServerID())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Bukkit.dispatchCommand(Bukkit.getConsoleSender(), event.getCommand());
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
||||||
|
public void onDispatchPlayerCommand(DispatchPlayerCommandEvent event) {
|
||||||
|
if (event.getServerType() != null && event.getServerType() != BallServerType.GAME) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (event.getUuid() != null) {
|
||||||
|
Player player = Bukkit.getPlayer(event.getUuid());
|
||||||
|
if (player == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Bukkit.dispatchCommand(player, event.getCommand());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (Player player : Bukkit.getOnlinePlayers()) {
|
||||||
|
Bukkit.dispatchCommand(player, event.getCommand());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
||||||
|
public void onSendPlayerToLocation(SendPlayerToLocationEvent event) {
|
||||||
|
BukkitLocation location = new BukkitLocation(event.getLocation());
|
||||||
|
if (BallAPI.getInstance().isLocalServer(location.getServerID())) {
|
||||||
|
for (UUID uuid : event.getSendPlayer()) {
|
||||||
|
Player player = Bukkit.getPlayer(uuid);
|
||||||
|
if (player != null) {
|
||||||
|
HamsterBallPlugin.sync(() -> {
|
||||||
|
player.teleport(location.toBukkitLocation());
|
||||||
|
if (event.getDoneMessage() != null) {
|
||||||
|
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(player);
|
||||||
|
event.getDoneMessage().show(audience);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
playerToLocation.put(uuid, new ToLocation(location.toBukkitLocation(), event.getDoneMessage()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(ignoreCancelled = true, priority = EventPriority.HIGH)
|
||||||
|
public void onSendPlayerToPlayer(SendPlayerToPlayerEvent event) {
|
||||||
|
Player toPlayer = Bukkit.getPlayer(event.getToPlayer());
|
||||||
|
if (toPlayer == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
Location location = toPlayer.getLocation();
|
||||||
|
for (UUID uuid : event.getSendPlayer()) {
|
||||||
|
Player sendPlayer = Bukkit.getPlayer(uuid);
|
||||||
|
if (sendPlayer != null) {
|
||||||
|
HamsterBallPlugin.sync(() -> {
|
||||||
|
sendPlayer.teleport(location);
|
||||||
|
if (event.getDoneMessage() != null) {
|
||||||
|
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(sendPlayer);
|
||||||
|
event.getDoneMessage().show(audience, TextReplacementConfig.builder()
|
||||||
|
.matchLiteral("%player_name%")
|
||||||
|
.replacement(toPlayer.getName())
|
||||||
|
.build());
|
||||||
|
}
|
||||||
|
if (event.getDoneTargetMessage() != null) {
|
||||||
|
Audience audience = CoreBukkitAPI.getInstance().getAudienceProvider().player(toPlayer);
|
||||||
|
event.getDoneTargetMessage().show(audience, TextReplacementConfig.builder()
|
||||||
|
.matchLiteral("%player_name%")
|
||||||
|
.replacement(sendPlayer.getName())
|
||||||
|
.build());
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
ToPlayer data = new ToPlayer(
|
||||||
|
toPlayer.getUniqueId(),
|
||||||
|
toPlayer.getLocation(),
|
||||||
|
event.getDoneMessage(),
|
||||||
|
event.getDoneTargetMessage()
|
||||||
|
);
|
||||||
|
playerToPlayer.put(uuid, data);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private List<DisplayMessage> getCachedPlayerMessage(@NotNull UUID uuid) throws SQLException {
|
private List<DisplayMessage> getCachedPlayerMessage(@NotNull UUID uuid) throws SQLException {
|
||||||
ArrayList<DisplayMessage> list = new ArrayList<>();
|
ArrayList<DisplayMessage> list = new ArrayList<>();
|
||||||
|
@@ -1,11 +1,10 @@
|
|||||||
package cn.hamster3.mc.plugin.core.bungee;
|
package cn.hamster3.mc.plugin.ball.bungee;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.api.BallBungeeCordAPI;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.listener.BallBungeeCordListener;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.util.BallBungeeCordUtils;
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOnlineEvent;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.api.BallBungeeCordAPI;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.listener.BallBungeeCordListener;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.util.BallBungeeCordUtils;
|
|
||||||
import net.md_5.bungee.api.ProxyServer;
|
import net.md_5.bungee.api.ProxyServer;
|
||||||
import net.md_5.bungee.api.plugin.Plugin;
|
import net.md_5.bungee.api.plugin.Plugin;
|
||||||
|
|
||||||
@@ -45,17 +44,8 @@ public class HamsterBallPlugin extends Plugin {
|
|||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
e.printStackTrace();
|
e.printStackTrace();
|
||||||
}
|
}
|
||||||
if (!BallAPI.getInstance().isEnabled()) {
|
|
||||||
ProxyServer.getInstance().stop("由于 HamsterBall 未能成功连接, 服务器将立即关闭");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
ProxyServer.getInstance().getPluginManager().registerListener(this, BallBungeeCordListener.INSTANCE);
|
ProxyServer.getInstance().getPluginManager().registerListener(this, BallBungeeCordListener.INSTANCE);
|
||||||
logger.info("已注册 BallBungeeCordListener");
|
logger.info("已注册 BallBungeeCordListener");
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
ServerOnlineEvent.ACTION,
|
|
||||||
new ServerOnlineEvent(BallAPI.getInstance().getLocalServerInfo())
|
|
||||||
);
|
|
||||||
BallAPI.getInstance().getAllPlayerInfo().values()
|
BallAPI.getInstance().getAllPlayerInfo().values()
|
||||||
.stream()
|
.stream()
|
||||||
.filter(BallPlayerInfo::isOnline)
|
.filter(BallPlayerInfo::isOnline)
|
@@ -0,0 +1,245 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.api;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.HamsterBallPlugin;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.MessageReceiveEvent;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.MessageSendEvent;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.operate.*;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.player.*;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.server.ServerOfflineEvent;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.server.ServerOnlineEvent;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.util.BallBungeeCordUtils;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.event.BallActions;
|
||||||
|
import cn.hamster3.mc.plugin.core.bungee.util.CoreBungeeCordUtils;
|
||||||
|
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
||||||
|
import io.lettuce.core.RedisClient;
|
||||||
|
import net.md_5.bungee.api.ProxyServer;
|
||||||
|
import net.md_5.bungee.config.Configuration;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import javax.sql.DataSource;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.logging.Logger;
|
||||||
|
|
||||||
|
public class BallBungeeCordAPI extends BallAPI {
|
||||||
|
public BallBungeeCordAPI(@NotNull BallServerInfo localServerInfo, @Nullable DataSource datasource, @NotNull RedisClient redisClient, boolean debug) {
|
||||||
|
super(localServerInfo, datasource, redisClient, debug);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static BallBungeeCordAPI getInstance() {
|
||||||
|
return (BallBungeeCordAPI) instance;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void init() {
|
||||||
|
if (instance != null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
HamsterBallPlugin plugin = HamsterBallPlugin.getInstance();
|
||||||
|
Configuration config = CoreBungeeCordUtils.getPluginConfig(plugin);
|
||||||
|
Map<String, String> env = System.getenv();
|
||||||
|
|
||||||
|
BallServerInfo serverInfo = new BallServerInfo(
|
||||||
|
env.getOrDefault("BALL_LOCAL_SERVER_INFO_ID", config.getString("server-info.id")),
|
||||||
|
env.getOrDefault("BALL_LOCAL_SERVER_INFO_NAME", config.getString("server-info.name")),
|
||||||
|
BallServerType.PROXY,
|
||||||
|
env.getOrDefault("BALL_LOCAL_SERVER_IP", config.getString("server-info.host", "0.0.0.0")),
|
||||||
|
Integer.parseInt(
|
||||||
|
env.getOrDefault("BALL_LOCAL_SERVER_PORT", config.getString("server-info.port", "25577"))
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
DataSource datasource;
|
||||||
|
if (config.contains("datasource")) {
|
||||||
|
plugin.getLogger().info("检测到配置文件中包含 datasource 节点,启用自定义数据库连接");
|
||||||
|
datasource = BallBungeeCordUtils.getDataSource(config.getSection("datasource"));
|
||||||
|
} else {
|
||||||
|
plugin.getLogger().info("未检测到配置文件中的 datasource 节点,复用 HamsterCore 数据库连接");
|
||||||
|
datasource = CoreAPI.getInstance().getDataSource();
|
||||||
|
}
|
||||||
|
|
||||||
|
RedisClient redisClient = RedisClient.create(config.getString("redis-url", "redis://localhost:6379?clientName=HamsterBall"));
|
||||||
|
|
||||||
|
instance = new BallBungeeCordAPI(serverInfo, datasource, redisClient, config.getBoolean("debug", false));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void enable() throws SQLException, InterruptedException {
|
||||||
|
super.enable();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void disable() throws SQLException, InterruptedException {
|
||||||
|
super.disable();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void sendBallMessage(@NotNull String channel, @NotNull BallMessage message, boolean block) {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(new MessageSendEvent(channel, message));
|
||||||
|
super.sendBallMessage(channel, message, block);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onMessage(String channel, BallMessage message) {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(new MessageReceiveEvent(channel, message));
|
||||||
|
if (!BallAPI.BALL_CHANNEL.equals(channel)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (BallActions.valueOf(message.getAction())) {
|
||||||
|
case BroadcastPlayerMessage: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BroadcastPlayerMessageEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DispatchConsoleCommand: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(DispatchConsoleCommandEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case DispatchPlayerCommand: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(DispatchPlayerCommandEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case KickPlayer: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(KickPlayerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SendMessageToPlayer: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(SendMessageToPlayerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SendPlayerToLocation: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(SendPlayerToLocationEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case SendPlayerToPlayer: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(SendPlayerToPlayerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerInfoUpdate: {
|
||||||
|
BallPlayerInfoUpdateEvent event = message.getContentAs(BallPlayerInfoUpdateEvent.class);
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(event);
|
||||||
|
BallPlayerInfo info = event.getPlayerInfo();
|
||||||
|
playerInfo.put(info.getUuid(), info);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPreLogin: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPreLoginEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerLogin: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerLoginEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPostLogin: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPostLoginEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPreConnectServer: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPreConnectServerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerConnectServer: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerConnectServerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerPostConnectServer: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerPostConnectServerEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PlayerLogout: {
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(
|
||||||
|
message.getContentAs(BallPlayerLogoutEvent.class)
|
||||||
|
);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case ServerOnline: {
|
||||||
|
ServerOnlineEvent event = message.getContentAs(ServerOnlineEvent.class);
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(event);
|
||||||
|
BallServerInfo info = event.getServerInfo();
|
||||||
|
serverInfo.put(info.getId(), info);
|
||||||
|
switch (info.getType()) {
|
||||||
|
case GAME: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getGameServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PROXY: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getProxyServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case ServerOffline: {
|
||||||
|
ServerOfflineEvent event = message.getContentAs(ServerOfflineEvent.class);
|
||||||
|
ProxyServer.getInstance().getPluginManager().callEvent(event);
|
||||||
|
String serverID = event.getServerInfo().getId();
|
||||||
|
BallServerInfo info = serverInfo.remove(serverID);
|
||||||
|
if (info == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (info.getType()) {
|
||||||
|
case GAME: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getGameServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case PROXY: {
|
||||||
|
playerInfo.forEach((uuid, playerInfo) -> {
|
||||||
|
if (playerInfo.getProxyServer().equals(info.getId())) {
|
||||||
|
playerInfo.setOnline(false);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public @NotNull Logger getLogger() {
|
||||||
|
return HamsterBallPlugin.getInstance().getLogger();
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,19 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class MessageReceiveEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final String channel;
|
||||||
|
@NotNull
|
||||||
|
private final BallMessage message;
|
||||||
|
|
||||||
|
public MessageReceiveEvent(@NotNull String channel, @NotNull BallMessage message) {
|
||||||
|
this.channel = channel;
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,19 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
public class MessageSendEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final String channel;
|
||||||
|
@NotNull
|
||||||
|
private final BallMessage message;
|
||||||
|
|
||||||
|
public MessageSendEvent(@NotNull String channel, @NotNull BallMessage message) {
|
||||||
|
this.channel = channel;
|
||||||
|
this.message = message;
|
||||||
|
}
|
||||||
|
}
|
@@ -0,0 +1,14 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BroadcastPlayerMessageEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final DisplayMessage message;
|
||||||
|
}
|
@@ -0,0 +1,19 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class DispatchConsoleCommandEvent extends Event {
|
||||||
|
@Nullable
|
||||||
|
private final BallServerType serverType;
|
||||||
|
@Nullable
|
||||||
|
private final String serverID;
|
||||||
|
@NotNull
|
||||||
|
private final String command;
|
||||||
|
}
|
@@ -0,0 +1,21 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class DispatchPlayerCommandEvent extends Event {
|
||||||
|
@Nullable
|
||||||
|
private final BallServerType serverType;
|
||||||
|
@Nullable
|
||||||
|
private final UUID uuid;
|
||||||
|
@NotNull
|
||||||
|
private final String command;
|
||||||
|
}
|
@@ -0,0 +1,18 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.text.Component;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class KickPlayerEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final UUID uuid;
|
||||||
|
@NotNull
|
||||||
|
private final Component reason;
|
||||||
|
}
|
@@ -0,0 +1,19 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class SendMessageToPlayerEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final Set<UUID> receivers;
|
||||||
|
@NotNull
|
||||||
|
private final DisplayMessage message;
|
||||||
|
}
|
@@ -0,0 +1,23 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.data.BallLocation;
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class SendPlayerToLocationEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final Set<UUID> sendPlayer;
|
||||||
|
@NotNull
|
||||||
|
private final BallLocation location;
|
||||||
|
@Nullable
|
||||||
|
private final DisplayMessage doneMessage;
|
||||||
|
}
|
@@ -0,0 +1,24 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.operate;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.Set;
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class SendPlayerToPlayerEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final Set<UUID> sendPlayer;
|
||||||
|
@NotNull
|
||||||
|
private final UUID toPlayer;
|
||||||
|
@Nullable
|
||||||
|
private final DisplayMessage doneMessage;
|
||||||
|
@Nullable
|
||||||
|
private final DisplayMessage doneTargetMessage;
|
||||||
|
}
|
@@ -1,8 +1,9 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.event.player;
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
@@ -15,11 +16,9 @@ import org.jetbrains.annotations.Nullable;
|
|||||||
* @see BallPlayerConnectServerEvent 玩家进入子服
|
* @see BallPlayerConnectServerEvent 玩家进入子服
|
||||||
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
||||||
*/
|
*/
|
||||||
@Data
|
@Getter
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerConnectServerEvent {
|
public class BallPlayerConnectServerEvent extends Event {
|
||||||
public static final String ACTION = "PlayerConnectServer";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallPlayerInfo playerInfo;
|
private final BallPlayerInfo playerInfo;
|
||||||
@Nullable
|
@Nullable
|
@@ -0,0 +1,17 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家已进入子服
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerInfoUpdateEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
}
|
@@ -0,0 +1,17 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家连接到代理服务器
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerLoginEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
}
|
@@ -0,0 +1,17 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家与代理服务器断开连接
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerLogoutEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private BallPlayerInfo playerInfo;
|
||||||
|
}
|
@@ -1,8 +1,9 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.event.player;
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -12,11 +13,13 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
* @see BallPlayerConnectServerEvent 玩家进入子服
|
* @see BallPlayerConnectServerEvent 玩家进入子服
|
||||||
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
||||||
*/
|
*/
|
||||||
@Data
|
@Getter
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerPostConnectServerEvent {
|
public class BallPlayerPostConnectServerEvent extends Event {
|
||||||
public static final String ACTION = "PlayerPostConnectServer";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallPlayerInfo playerInfo;
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@NotNull
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
}
|
}
|
@@ -0,0 +1,17 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家已连接到代理服务器
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerPostLoginEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
}
|
@@ -1,8 +1,9 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.event.player;
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
import org.jetbrains.annotations.Nullable;
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
@@ -13,16 +14,13 @@ import org.jetbrains.annotations.Nullable;
|
|||||||
* @see BallPlayerConnectServerEvent 玩家进入子服
|
* @see BallPlayerConnectServerEvent 玩家进入子服
|
||||||
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
* @see BallPlayerPostConnectServerEvent 玩家已经进入子服
|
||||||
*/
|
*/
|
||||||
@Data
|
@Getter
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerPreConnectServerEvent {
|
public class BallPlayerPreConnectServerEvent extends Event {
|
||||||
public static final String ACTION = "PlayerPreConnectServer";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallPlayerInfo playerInfo;
|
private final BallPlayerInfo playerInfo;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final String from;
|
private final String from;
|
||||||
@NotNull
|
@NotNull
|
||||||
private final String to;
|
private final String to;
|
||||||
|
|
||||||
}
|
}
|
@@ -0,0 +1,16 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.player;
|
||||||
|
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家准备连接到代理服务器
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerPreLoginEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final String playerName;
|
||||||
|
}
|
@@ -0,0 +1,17 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.server;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 服务器离线
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ServerOfflineEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final BallServerInfo serverInfo;
|
||||||
|
}
|
@@ -0,0 +1,17 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.event.server;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Getter;
|
||||||
|
import net.md_5.bungee.api.plugin.Event;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 服务器上线
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class ServerOnlineEvent extends Event {
|
||||||
|
@NotNull
|
||||||
|
private final BallServerInfo serverInfo;
|
||||||
|
}
|
@@ -0,0 +1,201 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.bungee.listener;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.HamsterBallPlugin;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.event.operate.*;
|
||||||
|
import cn.hamster3.mc.plugin.ball.bungee.util.BallBungeeCordUtils;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.event.BallActions;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.event.player.*;
|
||||||
|
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
||||||
|
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.audience.Audience;
|
||||||
|
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.text.serializer.bungeecord.BungeeComponentSerializer;
|
||||||
|
import net.md_5.bungee.api.ProxyServer;
|
||||||
|
import net.md_5.bungee.api.chat.BaseComponent;
|
||||||
|
import net.md_5.bungee.api.config.ServerInfo;
|
||||||
|
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
||||||
|
import net.md_5.bungee.api.event.*;
|
||||||
|
import net.md_5.bungee.api.plugin.Listener;
|
||||||
|
import net.md_5.bungee.event.EventHandler;
|
||||||
|
import net.md_5.bungee.event.EventPriority;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
public final class BallBungeeCordListener implements Listener {
|
||||||
|
public static final BallBungeeCordListener INSTANCE = new BallBungeeCordListener();
|
||||||
|
|
||||||
|
private BallBungeeCordListener() {
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onPreLogin(PreLoginEvent event) {
|
||||||
|
BallAPI.getInstance().sendBallMessage(
|
||||||
|
BallAPI.BALL_CHANNEL,
|
||||||
|
BallActions.PlayerPreLogin.name(),
|
||||||
|
new BallPlayerPreLogin(event.getConnection().getName())
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onLogin(LoginEvent event) {
|
||||||
|
if (event.isCancelled()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
BallAPI.getInstance().sendBallMessage(
|
||||||
|
BallAPI.BALL_CHANNEL,
|
||||||
|
BallActions.PlayerLogin.name(),
|
||||||
|
new BallPlayerLogin(
|
||||||
|
new BallPlayerInfo(
|
||||||
|
event.getConnection().getUniqueId(),
|
||||||
|
event.getConnection().getName(),
|
||||||
|
"connecting",
|
||||||
|
BallAPI.getInstance().getLocalServerId(),
|
||||||
|
true
|
||||||
|
))
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onPostLogin(PostLoginEvent event) {
|
||||||
|
ProxiedPlayer player = event.getPlayer();
|
||||||
|
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, true);
|
||||||
|
BallAPI.getInstance().sendBallMessage(
|
||||||
|
BallAPI.BALL_CHANNEL,
|
||||||
|
BallActions.PlayerPostLogin.name(),
|
||||||
|
new BallPlayerPostLogin(playerInfo)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onServerConnect(ServerConnectEvent event) {
|
||||||
|
ProxiedPlayer player = event.getPlayer();
|
||||||
|
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, true);
|
||||||
|
playerInfo.setGameServer(event.getTarget().getName());
|
||||||
|
BallAPI.getInstance().sendBallMessage(
|
||||||
|
BallAPI.BALL_CHANNEL,
|
||||||
|
BallActions.PlayerPreConnectServer.name(),
|
||||||
|
new BallPlayerPreConnectServer(playerInfo, playerInfo.getGameServer(), event.getTarget().getName())
|
||||||
|
);
|
||||||
|
BallBungeeCordUtils.uploadPlayerInfo(playerInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onServerConnected(ServerConnectedEvent event) {
|
||||||
|
ProxiedPlayer player = event.getPlayer();
|
||||||
|
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, true);
|
||||||
|
String from = playerInfo.getGameServer();
|
||||||
|
String to = event.getServer().getInfo().getName();
|
||||||
|
playerInfo.setGameServer(to);
|
||||||
|
BallAPI.getInstance().sendBallMessage(
|
||||||
|
BallAPI.BALL_CHANNEL,
|
||||||
|
BallActions.PlayerPostConnectServer.name(),
|
||||||
|
new BallPlayerPostConnectServer(playerInfo, from, to)
|
||||||
|
);
|
||||||
|
BallBungeeCordUtils.uploadPlayerInfo(playerInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
public void onServerSwitch(ServerSwitchEvent event) {
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onServerDisconnect(ServerDisconnectEvent event) {
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onPlayerDisconnect(PlayerDisconnectEvent event) {
|
||||||
|
ProxiedPlayer player = event.getPlayer();
|
||||||
|
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, false);
|
||||||
|
BallAPI.getInstance().sendBallMessage(
|
||||||
|
BallAPI.BALL_CHANNEL,
|
||||||
|
BallActions.PlayerLogout.name(),
|
||||||
|
new BallPlayerLogout(playerInfo)
|
||||||
|
);
|
||||||
|
BallBungeeCordUtils.uploadPlayerInfo(playerInfo);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onDispatchConsoleCommand(DispatchConsoleCommandEvent event) {
|
||||||
|
if (event.getServerType() != null && event.getServerType() != BallServerType.PROXY) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (event.getServerID() != null && !BallAPI.getInstance().isLocalServer(event.getServerID())) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ProxyServer server = ProxyServer.getInstance();
|
||||||
|
server.getPluginManager().dispatchCommand(server.getConsole(), event.getCommand());
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onDispatchPlayerCommand(DispatchPlayerCommandEvent event) {
|
||||||
|
if (event.getServerType() != null && event.getServerType() != BallServerType.GAME) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ProxyServer server = ProxyServer.getInstance();
|
||||||
|
if (event.getUuid() != null) {
|
||||||
|
ProxiedPlayer player = server.getPlayer(event.getUuid());
|
||||||
|
if (player == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
server.getPluginManager().dispatchCommand(player, event.getCommand());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (ProxiedPlayer player : server.getPlayers()) {
|
||||||
|
server.getPluginManager().dispatchCommand(player, event.getCommand());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onKickPlayer(KickPlayerEvent event) {
|
||||||
|
ProxiedPlayer player = ProxyServer.getInstance().getPlayer(event.getUuid());
|
||||||
|
BaseComponent[] components = BungeeComponentSerializer.get().serialize(event.getReason());
|
||||||
|
player.disconnect(components);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onSendMessageToPlayer(SendMessageToPlayerEvent event) {
|
||||||
|
for (UUID receiver : event.getReceivers()) {
|
||||||
|
Audience audience = CoreAPI.getInstance().getAudienceProvider().player(receiver);
|
||||||
|
event.getMessage().show(audience);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onSendPlayerToLocation(SendPlayerToLocationEvent event) {
|
||||||
|
String serverID = event.getLocation().getServerID();
|
||||||
|
ServerInfo serverInfo = ProxyServer.getInstance().getServerInfo(serverID);
|
||||||
|
if (serverInfo == null) {
|
||||||
|
HamsterBallPlugin.getInstance().getLogger().warning("试图传送玩家时失败: 服务器 " + serverID + " 不在线");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (UUID uuid : event.getSendPlayer()) {
|
||||||
|
ProxiedPlayer player = ProxyServer.getInstance().getPlayer(uuid);
|
||||||
|
if (player == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (player.getServer().getInfo().getName().equals(serverID)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
player.connect(serverInfo);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler(priority = EventPriority.HIGH)
|
||||||
|
public void onSendPlayerToPlayer(SendPlayerToPlayerEvent event) {
|
||||||
|
UUID toPlayerUUID = event.getToPlayer();
|
||||||
|
ProxiedPlayer toPlayer = ProxyServer.getInstance().getPlayer(toPlayerUUID);
|
||||||
|
if (toPlayer == null) {
|
||||||
|
HamsterBallPlugin.getInstance().getLogger().warning("试图传送玩家时失败: 目标玩家 " + toPlayerUUID + " 不在线");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
ServerInfo toServer = toPlayer.getServer().getInfo();
|
||||||
|
for (UUID uuid : event.getSendPlayer()) {
|
||||||
|
ProxiedPlayer sendPlayer = ProxyServer.getInstance().getPlayer(uuid);
|
||||||
|
if (sendPlayer.getServer().getInfo().getName().equals(toServer.getName())) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
sendPlayer.connect(toServer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@@ -1,8 +1,9 @@
|
|||||||
package cn.hamster3.mc.plugin.core.bungee.util;
|
package cn.hamster3.mc.plugin.ball.bungee.util;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.player.BallPlayerInfoUpdateEvent;
|
import cn.hamster3.mc.plugin.ball.common.event.BallActions;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.event.player.BallPlayerInfoUpdate;
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
||||||
import cn.hamster3.mc.plugin.core.lib.com.zaxxer.hikari.HikariConfig;
|
import cn.hamster3.mc.plugin.core.lib.com.zaxxer.hikari.HikariConfig;
|
||||||
import cn.hamster3.mc.plugin.core.lib.com.zaxxer.hikari.HikariDataSource;
|
import cn.hamster3.mc.plugin.core.lib.com.zaxxer.hikari.HikariDataSource;
|
||||||
@@ -51,8 +52,8 @@ public final class BallBungeeCordUtils {
|
|||||||
}
|
}
|
||||||
BallAPI.getInstance().sendBallMessage(
|
BallAPI.getInstance().sendBallMessage(
|
||||||
BallAPI.BALL_CHANNEL,
|
BallAPI.BALL_CHANNEL,
|
||||||
BallPlayerInfoUpdateEvent.ACTION,
|
BallActions.PlayerInfoUpdate.name(),
|
||||||
new BallPlayerInfoUpdateEvent(playerInfo)
|
new BallPlayerInfoUpdate(playerInfo)
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
}
|
}
|
@@ -1,75 +0,0 @@
|
|||||||
package cn.hamster3.mc.plugin.core.bungee.api;
|
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.HamsterBallPlugin;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.util.BallBungeeCordUtils;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.util.CoreBungeeCordUtils;
|
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
|
||||||
import io.lettuce.core.RedisClient;
|
|
||||||
import net.md_5.bungee.config.Configuration;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
import org.jetbrains.annotations.Nullable;
|
|
||||||
|
|
||||||
import javax.sql.DataSource;
|
|
||||||
import java.sql.SQLException;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.logging.Logger;
|
|
||||||
|
|
||||||
public class BallBungeeCordAPI extends BallAPI {
|
|
||||||
public BallBungeeCordAPI(@NotNull BallServerInfo localServerInfo, @Nullable DataSource datasource, @NotNull RedisClient redisClient, boolean debug) {
|
|
||||||
super(localServerInfo, datasource, redisClient, debug);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static BallBungeeCordAPI getInstance() {
|
|
||||||
return (BallBungeeCordAPI) instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
public static void init() {
|
|
||||||
if (instance != null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
HamsterBallPlugin plugin = HamsterBallPlugin.getInstance();
|
|
||||||
Configuration config = CoreBungeeCordUtils.getPluginConfig(plugin);
|
|
||||||
Map<String, String> env = System.getenv();
|
|
||||||
|
|
||||||
BallServerInfo serverInfo = new BallServerInfo(
|
|
||||||
env.getOrDefault("BALL_LOCAL_SERVER_INFO_ID", config.getString("server-info.id")),
|
|
||||||
env.getOrDefault("BALL_LOCAL_SERVER_INFO_NAME", config.getString("server-info.name")),
|
|
||||||
BallServerType.PROXY,
|
|
||||||
env.getOrDefault("BALL_LOCAL_SERVER_IP", config.getString("server-info.host", "0.0.0.0")),
|
|
||||||
Integer.parseInt(
|
|
||||||
env.getOrDefault("BALL_LOCAL_SERVER_PORT", config.getString("server-info.port", "25577"))
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
DataSource datasource;
|
|
||||||
if (config.contains("datasource")) {
|
|
||||||
plugin.getLogger().info("检测到配置文件中包含 datasource 节点,启用自定义数据库连接");
|
|
||||||
datasource = BallBungeeCordUtils.getDataSource(config.getSection("datasource"));
|
|
||||||
} else {
|
|
||||||
plugin.getLogger().info("未检测到配置文件中的 datasource 节点,复用 HamsterCore 数据库连接");
|
|
||||||
datasource = CoreAPI.getInstance().getDataSource();
|
|
||||||
}
|
|
||||||
|
|
||||||
RedisClient redisClient = RedisClient.create(config.getString("redis-url", "redis://localhost:6379?clientName=HamsterBall"));
|
|
||||||
|
|
||||||
instance = new BallBungeeCordAPI(serverInfo, datasource, redisClient, config.getBoolean("debug", false));
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void enable() throws SQLException, InterruptedException {
|
|
||||||
super.enable();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void disable() throws SQLException, InterruptedException {
|
|
||||||
super.disable();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public @NotNull Logger getLogger() {
|
|
||||||
return HamsterBallPlugin.getInstance().getLogger();
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,205 +0,0 @@
|
|||||||
package cn.hamster3.mc.plugin.core.bungee.listener;
|
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.operate.*;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.player.*;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.listener.BallListener;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.HamsterBallPlugin;
|
|
||||||
import cn.hamster3.mc.plugin.core.bungee.util.BallBungeeCordUtils;
|
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
|
||||||
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.audience.Audience;
|
|
||||||
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.text.serializer.bungeecord.BungeeComponentSerializer;
|
|
||||||
import net.md_5.bungee.api.ProxyServer;
|
|
||||||
import net.md_5.bungee.api.chat.BaseComponent;
|
|
||||||
import net.md_5.bungee.api.config.ServerInfo;
|
|
||||||
import net.md_5.bungee.api.connection.ProxiedPlayer;
|
|
||||||
import net.md_5.bungee.api.event.*;
|
|
||||||
import net.md_5.bungee.api.plugin.Listener;
|
|
||||||
import net.md_5.bungee.event.EventHandler;
|
|
||||||
import net.md_5.bungee.event.EventPriority;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
import java.util.UUID;
|
|
||||||
|
|
||||||
public final class BallBungeeCordListener implements Listener, BallListener {
|
|
||||||
public static final BallBungeeCordListener INSTANCE = new BallBungeeCordListener();
|
|
||||||
|
|
||||||
private BallBungeeCordListener() {
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onMessageReceived(@NotNull BallMessageInfo info) {
|
|
||||||
switch (info.getAction()) {
|
|
||||||
case DispatchConsoleCommandEvent.ACTION: {
|
|
||||||
DispatchConsoleCommandEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), DispatchConsoleCommandEvent.class);
|
|
||||||
if (event.getType() != null && event.getType() != BallServerType.PROXY) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (event.getServerID() != null && !BallAPI.getInstance().isLocalServer(event.getServerID())) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
ProxyServer server = ProxyServer.getInstance();
|
|
||||||
server.getPluginManager().dispatchCommand(server.getConsole(), event.getCommand());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case DispatchPlayerCommandEvent.ACTION: {
|
|
||||||
DispatchPlayerCommandEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), DispatchPlayerCommandEvent.class);
|
|
||||||
if (event.getType() != null && event.getType() != BallServerType.GAME) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
ProxyServer server = ProxyServer.getInstance();
|
|
||||||
if (event.getUuid() != null) {
|
|
||||||
ProxiedPlayer player = server.getPlayer(event.getUuid());
|
|
||||||
if (player == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
server.getPluginManager().dispatchCommand(player, event.getCommand());
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for (ProxiedPlayer player : server.getPlayers()) {
|
|
||||||
server.getPluginManager().dispatchCommand(player, event.getCommand());
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case KickPlayerEvent.ACTION: {
|
|
||||||
KickPlayerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), KickPlayerEvent.class);
|
|
||||||
ProxiedPlayer player = ProxyServer.getInstance().getPlayer(event.getUuid());
|
|
||||||
BaseComponent[] components = BungeeComponentSerializer.get().serialize(event.getReason());
|
|
||||||
player.disconnect(components);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case SendMessageToPlayerEvent.ACTION: {
|
|
||||||
SendMessageToPlayerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), SendMessageToPlayerEvent.class);
|
|
||||||
for (UUID receiver : event.getReceivers()) {
|
|
||||||
Audience audience = CoreAPI.getInstance().getAudienceProvider().player(receiver);
|
|
||||||
event.getMessage().show(audience);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case SendPlayerToLocationEvent.ACTION: {
|
|
||||||
SendPlayerToLocationEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), SendPlayerToLocationEvent.class);
|
|
||||||
String serverID = event.getLocation().getServerID();
|
|
||||||
ServerInfo serverInfo = ProxyServer.getInstance().getServerInfo(serverID);
|
|
||||||
if (serverInfo == null) {
|
|
||||||
HamsterBallPlugin.getInstance().getLogger().warning("试图传送玩家时失败: 服务器 " + serverID + " 不在线");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
for (UUID uuid : event.getSendPlayerUUID()) {
|
|
||||||
ProxiedPlayer player = ProxyServer.getInstance().getPlayer(uuid);
|
|
||||||
if (player == null) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (player.getServer().getInfo().getName().equals(serverID)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
player.connect(serverInfo);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case SendPlayerToPlayerEvent.ACTION: {
|
|
||||||
SendPlayerToPlayerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), SendPlayerToPlayerEvent.class);
|
|
||||||
UUID toPlayerUUID = event.getToPlayerUUID();
|
|
||||||
ProxiedPlayer toPlayer = ProxyServer.getInstance().getPlayer(toPlayerUUID);
|
|
||||||
if (toPlayer == null) {
|
|
||||||
HamsterBallPlugin.getInstance().getLogger().warning("试图传送玩家时失败: 目标玩家 " + toPlayerUUID + " 不在线");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
ServerInfo toServer = toPlayer.getServer().getInfo();
|
|
||||||
for (UUID uuid : event.getSendPlayerUUID()) {
|
|
||||||
ProxiedPlayer sendPlayer = ProxyServer.getInstance().getPlayer(uuid);
|
|
||||||
if (sendPlayer.getServer().getInfo().getName().equals(toServer.getName())) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
sendPlayer.connect(toServer);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onPreLogin(PreLoginEvent event) {
|
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
BallPlayerPreLoginEvent.ACTION,
|
|
||||||
new BallPlayerPreLoginEvent(event.getConnection().getName())
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onLogin(LoginEvent event) {
|
|
||||||
if (event.isCancelled()) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
BallPlayerLoginEvent.ACTION,
|
|
||||||
new BallPlayerLoginEvent(new BallPlayerInfo(
|
|
||||||
event.getConnection().getUniqueId(),
|
|
||||||
event.getConnection().getName(),
|
|
||||||
"connecting",
|
|
||||||
BallAPI.getInstance().getLocalServerId(),
|
|
||||||
true
|
|
||||||
))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onPostLogin(PostLoginEvent event) {
|
|
||||||
ProxiedPlayer player = event.getPlayer();
|
|
||||||
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, true);
|
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
BallPlayerPostLoginEvent.ACTION,
|
|
||||||
new BallPlayerPostLoginEvent(playerInfo)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onServerConnect(ServerConnectEvent event) {
|
|
||||||
ProxiedPlayer player = event.getPlayer();
|
|
||||||
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, true);
|
|
||||||
playerInfo.setGameServer(event.getTarget().getName());
|
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
BallPlayerPreConnectServerEvent.ACTION,
|
|
||||||
new BallPlayerPreConnectServerEvent(playerInfo, playerInfo.getGameServer(), event.getTarget().getName())
|
|
||||||
);
|
|
||||||
BallBungeeCordUtils.uploadPlayerInfo(playerInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onServerConnected(ServerConnectedEvent event) {
|
|
||||||
ProxiedPlayer player = event.getPlayer();
|
|
||||||
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, true);
|
|
||||||
playerInfo.setGameServer(event.getServer().getInfo().getName());
|
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
BallPlayerPostConnectServerEvent.ACTION,
|
|
||||||
new BallPlayerPostConnectServerEvent(playerInfo)
|
|
||||||
);
|
|
||||||
BallBungeeCordUtils.uploadPlayerInfo(playerInfo);
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler
|
|
||||||
public void onServerSwitch(ServerSwitchEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onServerDisconnect(ServerDisconnectEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
@EventHandler(priority = EventPriority.HIGH)
|
|
||||||
public void onPlayerDisconnect(PlayerDisconnectEvent event) {
|
|
||||||
ProxiedPlayer player = event.getPlayer();
|
|
||||||
BallPlayerInfo playerInfo = BallBungeeCordUtils.getPlayerInfo(player, false);
|
|
||||||
BallAPI.getInstance().sendBallMessage(
|
|
||||||
BallAPI.BALL_CHANNEL,
|
|
||||||
BallPlayerLogoutEvent.ACTION,
|
|
||||||
new BallPlayerLogoutEvent(playerInfo)
|
|
||||||
);
|
|
||||||
BallBungeeCordUtils.uploadPlayerInfo(playerInfo);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,5 +1,5 @@
|
|||||||
name: HamsterBall
|
name: HamsterBall
|
||||||
main: cn.hamster3.mc.plugin.core.bungee.HamsterBallPlugin
|
main: cn.hamster3.mc.plugin.ball.bungee.HamsterBallPlugin
|
||||||
version: ${version}
|
version: ${version}
|
||||||
|
|
||||||
author: MiniDay
|
author: MiniDay
|
||||||
|
@@ -1,23 +1,20 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.api;
|
package cn.hamster3.mc.plugin.ball.common.api;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallLocation;
|
import cn.hamster3.mc.plugin.ball.common.data.BallLocation;
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerType;
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.event.BallActions;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.operate.*;
|
import cn.hamster3.mc.plugin.ball.common.event.operate.*;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.player.BallPlayerConnectServerEvent;
|
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOffline;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.player.BallPlayerInfoUpdateEvent;
|
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOnline;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOfflineEvent;
|
import cn.hamster3.mc.plugin.ball.common.listener.BallDebugLogListener;
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOnlineEvent;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.listener.BallDebugListener;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.listener.BallListener;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.listener.BallMessageListener;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.listener.ListenerPriority;
|
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
||||||
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
import cn.hamster3.mc.plugin.core.common.data.DisplayMessage;
|
||||||
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.text.Component;
|
import cn.hamster3.mc.plugin.core.lib.net.kyori.adventure.text.Component;
|
||||||
import io.lettuce.core.RedisClient;
|
import io.lettuce.core.RedisClient;
|
||||||
|
import io.lettuce.core.pubsub.RedisPubSubListener;
|
||||||
import io.lettuce.core.pubsub.StatefulRedisPubSubConnection;
|
import io.lettuce.core.pubsub.StatefulRedisPubSubConnection;
|
||||||
import lombok.Getter;
|
import lombok.Getter;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@@ -45,111 +42,32 @@ public abstract class BallAPI {
|
|||||||
@NotNull
|
@NotNull
|
||||||
protected final Map<UUID, BallPlayerInfo> playerInfo;
|
protected final Map<UUID, BallPlayerInfo> playerInfo;
|
||||||
@NotNull
|
@NotNull
|
||||||
|
protected final StatefulRedisPubSubConnection<String, BallMessage> pubConnection;
|
||||||
|
@NotNull
|
||||||
|
protected final StatefulRedisPubSubConnection<String, BallMessage> subConnection;
|
||||||
|
@NotNull
|
||||||
private final BallServerInfo localServerInfo;
|
private final BallServerInfo localServerInfo;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final DataSource datasource;
|
private final DataSource datasource;
|
||||||
@NotNull
|
@NotNull
|
||||||
private final RedisClient redisClient;
|
private final RedisClient redisClient;
|
||||||
@NotNull
|
|
||||||
private final StatefulRedisPubSubConnection<String, BallMessageInfo> pubSubConnection;
|
|
||||||
|
|
||||||
@NotNull
|
|
||||||
private List<BallListener> listeners;
|
|
||||||
@Getter
|
|
||||||
private boolean enabled;
|
|
||||||
|
|
||||||
public BallAPI(@NotNull BallServerInfo localServerInfo, @Nullable DataSource datasource, @NotNull RedisClient redisClient, boolean debug) {
|
public BallAPI(@NotNull BallServerInfo localServerInfo, @Nullable DataSource datasource, @NotNull RedisClient redisClient, boolean debug) {
|
||||||
this.localServerInfo = localServerInfo;
|
this.localServerInfo = localServerInfo;
|
||||||
this.datasource = datasource;
|
this.datasource = datasource;
|
||||||
this.redisClient = redisClient;
|
this.redisClient = redisClient;
|
||||||
pubSubConnection = redisClient.connectPubSub(BallMessageInfo.CODEC);
|
pubConnection = redisClient.connectPubSub(BallMessage.REDIS_CODEC);
|
||||||
|
subConnection = redisClient.connectPubSub(BallMessage.REDIS_CODEC);
|
||||||
serverInfo = new ConcurrentHashMap<>();
|
serverInfo = new ConcurrentHashMap<>();
|
||||||
playerInfo = new ConcurrentHashMap<>();
|
playerInfo = new ConcurrentHashMap<>();
|
||||||
listeners = new ArrayList<>();
|
|
||||||
enabled = false;
|
|
||||||
initListener(debug);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void initListener(boolean debug) {
|
|
||||||
addListener(new BallListener() {
|
|
||||||
@Override
|
|
||||||
public ListenerPriority getPriority() {
|
|
||||||
return ListenerPriority.LOW;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBallPlayerConnectServer(@NotNull BallPlayerConnectServerEvent event) {
|
|
||||||
BallPlayerInfo info = event.getPlayerInfo();
|
|
||||||
playerInfo.put(info.getUuid(), info);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBallPlayerInfoUpdate(@NotNull BallPlayerInfoUpdateEvent event) {
|
|
||||||
BallPlayerInfo info = event.getPlayerInfo();
|
|
||||||
playerInfo.put(info.getUuid(), info);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onServerOnline(@NotNull ServerOnlineEvent event) {
|
|
||||||
BallServerInfo info = event.getServerInfo();
|
|
||||||
serverInfo.put(info.getId(), info);
|
|
||||||
switch (info.getType()) {
|
|
||||||
case GAME: {
|
|
||||||
playerInfo.forEach((uuid, playerInfo) -> {
|
|
||||||
if (playerInfo.getGameServer().equals(info.getId())) {
|
|
||||||
playerInfo.setOnline(false);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case PROXY: {
|
|
||||||
playerInfo.forEach((uuid, playerInfo) -> {
|
|
||||||
if (playerInfo.getProxyServer().equals(info.getId())) {
|
|
||||||
playerInfo.setOnline(false);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onServerOffline(@NotNull ServerOfflineEvent event) {
|
|
||||||
String serverID = event.getServerID();
|
|
||||||
BallServerInfo info = serverInfo.remove(serverID);
|
|
||||||
if (info == null) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
switch (info.getType()) {
|
|
||||||
case GAME: {
|
|
||||||
playerInfo.forEach((uuid, playerInfo) -> {
|
|
||||||
if (playerInfo.getGameServer().equals(info.getId())) {
|
|
||||||
playerInfo.setOnline(false);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case PROXY: {
|
|
||||||
playerInfo.forEach((uuid, playerInfo) -> {
|
|
||||||
if (playerInfo.getProxyServer().equals(info.getId())) {
|
|
||||||
playerInfo.setOnline(false);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
if (debug) {
|
if (debug) {
|
||||||
getLogger().warning("已启用调试模式");
|
getLogger().warning("已启用调试模式");
|
||||||
pubSubConnection.addListener(BallDebugListener.INSTANCE);
|
subConnection.addListener(BallDebugLogListener.INSTANCE);
|
||||||
}
|
}
|
||||||
|
subConnection.addListener(new InnerListener());
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void enable() throws SQLException, InterruptedException {
|
protected void enable() throws SQLException, InterruptedException {
|
||||||
if (enabled) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
BallServerInfo localInfo = getLocalServerInfo();
|
BallServerInfo localInfo = getLocalServerInfo();
|
||||||
|
|
||||||
try (Connection connection = BallAPI.getInstance().getDatasource().getConnection()) {
|
try (Connection connection = BallAPI.getInstance().getDatasource().getConnection()) {
|
||||||
@@ -199,6 +117,7 @@ public abstract class BallAPI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
getLogger().info("已加载 " + serverInfo.size() + " 条服务器信息");
|
||||||
try (PreparedStatement statement = connection.prepareStatement(
|
try (PreparedStatement statement = connection.prepareStatement(
|
||||||
"SELECT * FROM `hamster_ball_player_info`;"
|
"SELECT * FROM `hamster_ball_player_info`;"
|
||||||
)) {
|
)) {
|
||||||
@@ -214,15 +133,15 @@ public abstract class BallAPI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
getLogger().info("已加载 " + playerInfo.size() + " 条玩家信息");
|
||||||
}
|
}
|
||||||
RedisClient client = getRedisClient();
|
|
||||||
pubSubConnection.addListener(BallMessageListener.INSTANCE);
|
subscribe(BALL_CHANNEL);
|
||||||
pubSubConnection.async().subscribe("HamsterBall");
|
sendBallMessage(BALL_CHANNEL, new BallMessage(BallActions.ServerOnline.name(), new ServerOnline(getLocalServerInfo())), true);
|
||||||
enabled = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void disable() throws SQLException, InterruptedException {
|
protected void disable() throws SQLException, InterruptedException {
|
||||||
sendBallMessage(new BallMessageInfo(BALL_CHANNEL, ServerOfflineEvent.ACTION, new ServerOfflineEvent(getLocalServerId())), true);
|
sendBallMessage(BALL_CHANNEL, new BallMessage(BallActions.ServerOffline.name(), new ServerOffline(getLocalServerInfo())), true);
|
||||||
|
|
||||||
try (Connection connection = BallAPI.getInstance().getDatasource().getConnection()) {
|
try (Connection connection = BallAPI.getInstance().getDatasource().getConnection()) {
|
||||||
try (PreparedStatement statement = connection.prepareStatement(
|
try (PreparedStatement statement = connection.prepareStatement(
|
||||||
@@ -239,9 +158,9 @@ public abstract class BallAPI {
|
|||||||
statement.executeUpdate();
|
statement.executeUpdate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
getLogger().info("正在关闭 redission");
|
getLogger().info("正在关闭 redis 客户端");
|
||||||
getRedisClient().close();
|
getRedisClient().close();
|
||||||
getLogger().info("已关闭 redission");
|
getLogger().info("已关闭 redis 客户端");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -279,14 +198,13 @@ public abstract class BallAPI {
|
|||||||
* @param message 消息
|
* @param message 消息
|
||||||
*/
|
*/
|
||||||
public void broadcastPlayerMessage(@NotNull DisplayMessage message) {
|
public void broadcastPlayerMessage(@NotNull DisplayMessage message) {
|
||||||
sendBallMessage(new BallMessageInfo(
|
sendBallMessage(BALL_CHANNEL, new BallMessage(
|
||||||
BALL_CHANNEL,
|
|
||||||
getLocalServerId(),
|
getLocalServerId(),
|
||||||
null,
|
null,
|
||||||
BallServerType.PROXY,
|
BallServerType.PROXY,
|
||||||
BroadcastPlayerMessageEvent.ACTION,
|
BallActions.BroadcastPlayerMessage.name(),
|
||||||
CoreAPI.getInstance().getGson().toJsonTree(
|
CoreAPI.getInstance().getGson().toJsonTree(
|
||||||
new BroadcastPlayerMessageEvent(message)
|
new BroadcastPlayerMessage(message)
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
@@ -299,14 +217,13 @@ public abstract class BallAPI {
|
|||||||
* @param command 命令内容
|
* @param command 命令内容
|
||||||
*/
|
*/
|
||||||
public void dispatchConsoleCommand(@Nullable BallServerType type, @Nullable String serverID, @NotNull String command) {
|
public void dispatchConsoleCommand(@Nullable BallServerType type, @Nullable String serverID, @NotNull String command) {
|
||||||
sendBallMessage(new BallMessageInfo(
|
sendBallMessage(BALL_CHANNEL, new BallMessage(
|
||||||
BALL_CHANNEL,
|
|
||||||
getLocalServerId(),
|
getLocalServerId(),
|
||||||
null,
|
null,
|
||||||
BallServerType.GAME,
|
BallServerType.GAME,
|
||||||
DispatchConsoleCommandEvent.ACTION,
|
BallActions.DispatchConsoleCommand.name(),
|
||||||
CoreAPI.getInstance().getGson().toJsonTree(
|
CoreAPI.getInstance().getGson().toJsonTree(
|
||||||
new DispatchConsoleCommandEvent(type, serverID, command)
|
new DispatchConsoleCommand(type, serverID, command)
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
@@ -319,14 +236,13 @@ public abstract class BallAPI {
|
|||||||
* @param command 命令内容
|
* @param command 命令内容
|
||||||
*/
|
*/
|
||||||
public void dispatchPlayerCommand(@Nullable BallServerType type, @Nullable UUID uuid, @NotNull String command) {
|
public void dispatchPlayerCommand(@Nullable BallServerType type, @Nullable UUID uuid, @NotNull String command) {
|
||||||
sendBallMessage(new BallMessageInfo(
|
sendBallMessage(BALL_CHANNEL, new BallMessage(
|
||||||
BALL_CHANNEL,
|
|
||||||
getLocalServerId(),
|
getLocalServerId(),
|
||||||
null,
|
null,
|
||||||
BallServerType.GAME,
|
BallServerType.GAME,
|
||||||
DispatchPlayerCommandEvent.ACTION,
|
BallActions.DispatchPlayerCommand.name(),
|
||||||
CoreAPI.getInstance().getGson().toJsonTree(
|
CoreAPI.getInstance().getGson().toJsonTree(
|
||||||
new DispatchPlayerCommandEvent(type, uuid, command)
|
new DispatchPlayerCommand(type, uuid, command)
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
@@ -348,14 +264,13 @@ public abstract class BallAPI {
|
|||||||
* @param reason 原因
|
* @param reason 原因
|
||||||
*/
|
*/
|
||||||
public void kickPlayer(@NotNull UUID uuid, @NotNull Component reason) {
|
public void kickPlayer(@NotNull UUID uuid, @NotNull Component reason) {
|
||||||
sendBallMessage(new BallMessageInfo(
|
sendBallMessage(BALL_CHANNEL, new BallMessage(
|
||||||
BALL_CHANNEL,
|
|
||||||
getLocalServerId(),
|
getLocalServerId(),
|
||||||
null,
|
null,
|
||||||
BallServerType.PROXY,
|
BallServerType.PROXY,
|
||||||
KickPlayerEvent.ACTION,
|
BallActions.KickPlayer.name(),
|
||||||
CoreAPI.getInstance().getGson().toJsonTree(
|
CoreAPI.getInstance().getGson().toJsonTree(
|
||||||
new KickPlayerEvent(uuid, reason)
|
new KickPlayer(uuid, reason)
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
@@ -386,14 +301,13 @@ public abstract class BallAPI {
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
sendBallMessage(new BallMessageInfo(
|
sendBallMessage(BALL_CHANNEL, new BallMessage(
|
||||||
BALL_CHANNEL,
|
|
||||||
getLocalServerId(),
|
getLocalServerId(),
|
||||||
null,
|
null,
|
||||||
BallServerType.PROXY,
|
BallServerType.PROXY,
|
||||||
SendMessageToPlayerEvent.ACTION,
|
BallActions.SendMessageToPlayer.name(),
|
||||||
CoreAPI.getInstance().getGson().toJsonTree(
|
CoreAPI.getInstance().getGson().toJsonTree(
|
||||||
new SendMessageToPlayerEvent(Collections.singleton(receiver), message)
|
new SendMessageToPlayer(Collections.singleton(receiver), message)
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
@@ -425,14 +339,13 @@ public abstract class BallAPI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sendBallMessage(new BallMessageInfo(
|
sendBallMessage(BALL_CHANNEL, new BallMessage(
|
||||||
BALL_CHANNEL,
|
|
||||||
getLocalServerId(),
|
getLocalServerId(),
|
||||||
null,
|
null,
|
||||||
BallServerType.PROXY,
|
BallServerType.PROXY,
|
||||||
SendMessageToPlayerEvent.ACTION,
|
BallActions.SendMessageToPlayer.name(),
|
||||||
CoreAPI.getInstance().getGson().toJsonTree(
|
CoreAPI.getInstance().getGson().toJsonTree(
|
||||||
new SendMessageToPlayerEvent(new HashSet<>(receivers), message)
|
new SendMessageToPlayer(new HashSet<>(receivers), message)
|
||||||
)
|
)
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
@@ -444,15 +357,15 @@ public abstract class BallAPI {
|
|||||||
* <p>
|
* <p>
|
||||||
* 则会先尝试将玩家连接至目标服务器再进行传送
|
* 则会先尝试将玩家连接至目标服务器再进行传送
|
||||||
*
|
*
|
||||||
* @param sendPlayerUUID 玩家的uuid
|
* @param sendPlayer 玩家的uuid
|
||||||
* @param location 坐标
|
* @param location 坐标
|
||||||
* @param doneMessage 传送完成后显示的消息
|
* @param doneMessage 传送完成后显示的消息
|
||||||
*/
|
*/
|
||||||
public void sendPlayerToLocation(@NotNull UUID sendPlayerUUID, @NotNull BallLocation location, @Nullable DisplayMessage doneMessage) {
|
public void sendPlayerToLocation(@NotNull UUID sendPlayer, @NotNull BallLocation location, @Nullable DisplayMessage doneMessage) {
|
||||||
sendBallMessage(
|
sendBallMessage(
|
||||||
BALL_CHANNEL,
|
BALL_CHANNEL,
|
||||||
SendPlayerToLocationEvent.ACTION,
|
BallActions.SendPlayerToLocation.name(),
|
||||||
new SendPlayerToLocationEvent(Collections.singleton(sendPlayerUUID), location, doneMessage)
|
new SendPlayerToLocation(Collections.singleton(sendPlayer), location, doneMessage)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -463,15 +376,15 @@ public abstract class BallAPI {
|
|||||||
* <p>
|
* <p>
|
||||||
* 则会先尝试将玩家连接至目标服务器再进行传送
|
* 则会先尝试将玩家连接至目标服务器再进行传送
|
||||||
*
|
*
|
||||||
* @param sendPlayerUUID 玩家的uuid
|
* @param sendPlayer 玩家的uuid
|
||||||
* @param location 坐标
|
* @param location 坐标
|
||||||
* @param doneMessage 传送完成后显示的消息
|
* @param doneMessage 传送完成后显示的消息
|
||||||
*/
|
*/
|
||||||
public void sendPlayerToLocation(@NotNull Collection<UUID> sendPlayerUUID, @NotNull BallLocation location, @Nullable DisplayMessage doneMessage) {
|
public void sendPlayerToLocation(@NotNull Collection<UUID> sendPlayer, @NotNull BallLocation location, @Nullable DisplayMessage doneMessage) {
|
||||||
sendBallMessage(
|
sendBallMessage(
|
||||||
BALL_CHANNEL,
|
BALL_CHANNEL,
|
||||||
SendPlayerToLocationEvent.ACTION,
|
BallActions.SendPlayerToLocation.name(),
|
||||||
new SendPlayerToLocationEvent(new HashSet<>(sendPlayerUUID), location, doneMessage)
|
new SendPlayerToLocation(new HashSet<>(sendPlayer), location, doneMessage)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -488,8 +401,8 @@ public abstract class BallAPI {
|
|||||||
public void sendPlayerToPlayer(@NotNull UUID sendPlayer, @NotNull UUID toPlayer, @Nullable DisplayMessage doneMessage, @Nullable DisplayMessage doneTargetMessage) {
|
public void sendPlayerToPlayer(@NotNull UUID sendPlayer, @NotNull UUID toPlayer, @Nullable DisplayMessage doneMessage, @Nullable DisplayMessage doneTargetMessage) {
|
||||||
sendBallMessage(
|
sendBallMessage(
|
||||||
BALL_CHANNEL,
|
BALL_CHANNEL,
|
||||||
SendPlayerToPlayerEvent.ACTION,
|
BallActions.SendPlayerToPlayer.name(),
|
||||||
new SendPlayerToPlayerEvent(Collections.singleton(sendPlayer), toPlayer, doneMessage, doneTargetMessage)
|
new SendPlayerToPlayer(Collections.singleton(sendPlayer), toPlayer, doneMessage, doneTargetMessage)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -498,16 +411,16 @@ public abstract class BallAPI {
|
|||||||
* <p>
|
* <p>
|
||||||
* 支持跨服传送
|
* 支持跨服传送
|
||||||
*
|
*
|
||||||
* @param sendPlayerUUID 被传送的玩家
|
* @param sendPlayer 被传送的玩家
|
||||||
* @param toPlayer 传送的目标玩家
|
* @param toPlayer 传送的目标玩家
|
||||||
* @param doneMessage 传送完成后显示的消息,自动将 %player_name% 替换成传送目标玩家的名称
|
* @param doneMessage 传送完成后显示的消息,自动将 %player_name% 替换成传送目标玩家的名称
|
||||||
* @param doneTargetMessage 传送完成后目标玩家显示的消息,自动将 %player_name% 替换成被传送者的名称
|
* @param doneTargetMessage 传送完成后目标玩家显示的消息,自动将 %player_name% 替换成被传送者的名称
|
||||||
*/
|
*/
|
||||||
public void sendPlayerToPlayer(@NotNull Collection<UUID> sendPlayerUUID, @NotNull UUID toPlayer, @Nullable DisplayMessage doneMessage, @Nullable DisplayMessage doneTargetMessage) {
|
public void sendPlayerToPlayer(@NotNull Collection<UUID> sendPlayer, @NotNull UUID toPlayer, @Nullable DisplayMessage doneMessage, @Nullable DisplayMessage doneTargetMessage) {
|
||||||
sendBallMessage(
|
sendBallMessage(
|
||||||
BALL_CHANNEL,
|
BALL_CHANNEL,
|
||||||
SendPlayerToPlayerEvent.ACTION,
|
BallActions.SendPlayerToPlayer.name(),
|
||||||
new SendPlayerToPlayerEvent(new HashSet<>(sendPlayerUUID), toPlayer, doneMessage, doneTargetMessage)
|
new SendPlayerToPlayer(new HashSet<>(sendPlayer), toPlayer, doneMessage, doneTargetMessage)
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -518,7 +431,7 @@ public abstract class BallAPI {
|
|||||||
* @param action 执行动作
|
* @param action 执行动作
|
||||||
*/
|
*/
|
||||||
public void sendBallMessage(@NotNull String channel, @NotNull String action) {
|
public void sendBallMessage(@NotNull String channel, @NotNull String action) {
|
||||||
sendBallMessage(new BallMessageInfo(channel, action));
|
sendBallMessage(channel, new BallMessage(action));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -529,53 +442,48 @@ public abstract class BallAPI {
|
|||||||
* @param content 附加参数
|
* @param content 附加参数
|
||||||
*/
|
*/
|
||||||
public void sendBallMessage(@NotNull String channel, @NotNull String action, @NotNull Object content) {
|
public void sendBallMessage(@NotNull String channel, @NotNull String action, @NotNull Object content) {
|
||||||
sendBallMessage(new BallMessageInfo(channel, action, content));
|
sendBallMessage(channel, new BallMessage(action, content));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 发送自定义消息
|
* 发送自定义消息
|
||||||
*
|
*
|
||||||
* @param messageInfo 消息内容
|
* @param channel 消息频道
|
||||||
|
* @param message 消息内容
|
||||||
*/
|
*/
|
||||||
public void sendBallMessage(@NotNull BallMessageInfo messageInfo) {
|
public void sendBallMessage(@NotNull String channel, @NotNull BallMessage message) {
|
||||||
sendBallMessage(messageInfo, false);
|
sendBallMessage(channel, message, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 自定义服务消息信息并发送
|
* 自定义服务消息信息并发送
|
||||||
*
|
*
|
||||||
* @param messageInfo 消息内容
|
* @param channel 消息频道
|
||||||
* @param block 是否阻塞(设置为 true 则必须等待消息写入网络的操作完成后,该方法才会退出)
|
* @param message 消息内容
|
||||||
|
* @param block 是否阻塞(设置为 true 则必须等待消息写入网络的操作完成后,该方法才会退出)
|
||||||
*/
|
*/
|
||||||
public void sendBallMessage(@NotNull BallMessageInfo messageInfo, boolean block) {
|
public void sendBallMessage(@NotNull String channel, @NotNull BallMessage message, boolean block) {
|
||||||
String string = CoreAPI.getInstance().getGson().toJson(messageInfo);
|
if (block) {
|
||||||
try (StatefulRedisPubSubConnection<String, BallMessageInfo> connection = getRedisClient().connectPubSub(BallMessageInfo.CODEC)) {
|
pubConnection.sync().publish(channel, message);
|
||||||
if (block) {
|
} else {
|
||||||
connection.sync().publish("HamsterBall", messageInfo);
|
pubConnection.async().publish(channel, message);
|
||||||
} else {
|
|
||||||
connection.async().publish("HamsterBall", messageInfo);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onMessageSend(messageInfo);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addListener(@NotNull BallListener listener) {
|
public void subscribe(@NotNull String... channel) {
|
||||||
ArrayList<BallListener> newListeners = new ArrayList<>(listeners);
|
subConnection.sync().subscribe(channel);
|
||||||
newListeners.add(listener);
|
|
||||||
newListeners.sort(Comparator.comparing(BallListener::getPriority));
|
|
||||||
listeners = newListeners;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void removeListener(@NotNull BallListener listener) {
|
public void subscribePatterns(@NotNull String patterns) {
|
||||||
ArrayList<BallListener> newListeners = new ArrayList<>(listeners);
|
subConnection.sync().psubscribe(patterns);
|
||||||
newListeners.remove(listener);
|
}
|
||||||
listeners = newListeners;
|
|
||||||
|
public void unsubscribe(@NotNull String... channel) {
|
||||||
|
subConnection.sync().unsubscribe(channel);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void unsubscribePatterns(@NotNull String patterns) {
|
||||||
|
subConnection.sync().punsubscribe(patterns);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -715,10 +623,7 @@ public abstract class BallAPI {
|
|||||||
return playerInfo;
|
return playerInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
@NotNull
|
protected abstract void onMessage(String channel, BallMessage message);
|
||||||
public List<BallListener> getListeners() {
|
|
||||||
return listeners;
|
|
||||||
}
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
public abstract Logger getLogger();
|
public abstract Logger getLogger();
|
||||||
@@ -732,4 +637,36 @@ public abstract class BallAPI {
|
|||||||
public RedisClient getRedisClient() {
|
public RedisClient getRedisClient() {
|
||||||
return redisClient;
|
return redisClient;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private class InnerListener implements RedisPubSubListener<String, BallMessage> {
|
||||||
|
@Override
|
||||||
|
public void message(String channel, BallMessage message) {
|
||||||
|
onMessage(channel, message);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void message(String pattern, String channel, BallMessage message) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void subscribed(String channel, long count) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void psubscribed(String pattern, long count) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void unsubscribed(String channel, long count) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void punsubscribed(String pattern, long count) {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@@ -1,17 +0,0 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.config;
|
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
|
||||||
import lombok.AllArgsConstructor;
|
|
||||||
import lombok.Data;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
@Data
|
|
||||||
@AllArgsConstructor
|
|
||||||
public class BallConfig {
|
|
||||||
@NotNull
|
|
||||||
private BallServerInfo localInfo;
|
|
||||||
@NotNull
|
|
||||||
private String host;
|
|
||||||
private int port;
|
|
||||||
private int eventLoopThread;
|
|
||||||
}
|
|
@@ -20,22 +20,22 @@ import java.util.UUID;
|
|||||||
/**
|
/**
|
||||||
* 服务消息
|
* 服务消息
|
||||||
*/
|
*/
|
||||||
@Data
|
|
||||||
@SuppressWarnings("unused")
|
@SuppressWarnings("unused")
|
||||||
public class BallMessageInfo {
|
@Data
|
||||||
|
public class BallMessage {
|
||||||
/**
|
/**
|
||||||
* 编解码器
|
* 编解码器
|
||||||
*/
|
*/
|
||||||
public static final RedisCodec<String, BallMessageInfo> CODEC = new RedisCodec<String, BallMessageInfo>() {
|
public static final RedisCodec<String, BallMessage> REDIS_CODEC = new RedisCodec<String, BallMessage>() {
|
||||||
@Override
|
@Override
|
||||||
public String decodeKey(ByteBuffer bytes) {
|
public String decodeKey(ByteBuffer bytes) {
|
||||||
return StringCodec.UTF8.decodeKey(bytes);
|
return StringCodec.UTF8.decodeKey(bytes);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public BallMessageInfo decodeValue(ByteBuffer bytes) {
|
public BallMessage decodeValue(ByteBuffer bytes) {
|
||||||
String string = StringCodec.UTF8.decodeValue(bytes);
|
String string = StringCodec.UTF8.decodeValue(bytes);
|
||||||
return CoreAPI.getInstance().getGson().fromJson(string, BallMessageInfo.class);
|
return CoreAPI.getInstance().getGson().fromJson(string, BallMessage.class);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -44,7 +44,7 @@ public class BallMessageInfo {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ByteBuffer encodeValue(BallMessageInfo value) {
|
public ByteBuffer encodeValue(BallMessage value) {
|
||||||
return StringCodec.UTF8.encodeValue(CoreAPI.getInstance().getGson().toJson(value));
|
return StringCodec.UTF8.encodeValue(CoreAPI.getInstance().getGson().toJson(value));
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@@ -71,11 +71,6 @@ public class BallMessageInfo {
|
|||||||
*/
|
*/
|
||||||
@Nullable
|
@Nullable
|
||||||
private BallServerType receiverType;
|
private BallServerType receiverType;
|
||||||
/**
|
|
||||||
* 消息的频道
|
|
||||||
*/
|
|
||||||
@NotNull
|
|
||||||
private String channel;
|
|
||||||
/**
|
/**
|
||||||
* 消息动作
|
* 消息动作
|
||||||
* <p>
|
* <p>
|
||||||
@@ -90,22 +85,19 @@ public class BallMessageInfo {
|
|||||||
*/
|
*/
|
||||||
private JsonElement content;
|
private JsonElement content;
|
||||||
|
|
||||||
public BallMessageInfo(@NotNull String channel, @NotNull String action) {
|
public BallMessage(@NotNull String action) {
|
||||||
senderID = BallAPI.getInstance().getLocalServerId();
|
senderID = BallAPI.getInstance().getLocalServerId();
|
||||||
this.channel = channel;
|
|
||||||
this.action = action;
|
this.action = action;
|
||||||
}
|
}
|
||||||
|
|
||||||
public BallMessageInfo(@NotNull String channel, @NotNull String action, @NotNull Object content) {
|
public BallMessage(@NotNull String action, @NotNull Object content) {
|
||||||
this.channel = channel;
|
|
||||||
senderID = BallAPI.getInstance().getLocalServerId();
|
senderID = BallAPI.getInstance().getLocalServerId();
|
||||||
this.action = action;
|
this.action = action;
|
||||||
this.content = CoreAPI.getInstance().getGson().toJsonTree(content);
|
this.content = CoreAPI.getInstance().getGson().toJsonTree(content);
|
||||||
}
|
}
|
||||||
|
|
||||||
public BallMessageInfo(@NotNull String channel, @NotNull String senderID, @Nullable String receiverID,
|
public BallMessage(@NotNull String senderID, @Nullable String receiverID,
|
||||||
@Nullable BallServerType receiverType, @NotNull String action, @Nullable JsonElement content) {
|
@Nullable BallServerType receiverType, @NotNull String action, @Nullable JsonElement content) {
|
||||||
this.channel = channel;
|
|
||||||
this.senderID = senderID;
|
this.senderID = senderID;
|
||||||
this.receiverID = receiverID;
|
this.receiverID = receiverID;
|
||||||
this.receiverType = receiverType;
|
this.receiverType = receiverType;
|
||||||
@@ -121,7 +113,6 @@ public class BallMessageInfo {
|
|||||||
@NotNull
|
@NotNull
|
||||||
public JsonObject toJson() {
|
public JsonObject toJson() {
|
||||||
JsonObject object = new JsonObject();
|
JsonObject object = new JsonObject();
|
||||||
object.addProperty("channel", channel);
|
|
||||||
object.addProperty("senderID", senderID);
|
object.addProperty("senderID", senderID);
|
||||||
if (receiverID != null) {
|
if (receiverID != null) {
|
||||||
object.addProperty("toServer", receiverID);
|
object.addProperty("toServer", receiverID);
|
@@ -0,0 +1,26 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.common.event;
|
||||||
|
|
||||||
|
public enum BallActions {
|
||||||
|
// Operate
|
||||||
|
BroadcastPlayerMessage,
|
||||||
|
DispatchConsoleCommand,
|
||||||
|
DispatchPlayerCommand,
|
||||||
|
KickPlayer,
|
||||||
|
SendMessageToPlayer,
|
||||||
|
SendPlayerToLocation,
|
||||||
|
SendPlayerToPlayer,
|
||||||
|
|
||||||
|
// Player
|
||||||
|
PlayerInfoUpdate,
|
||||||
|
PlayerPreLogin,
|
||||||
|
PlayerLogin,
|
||||||
|
PlayerPostLogin,
|
||||||
|
PlayerPreConnectServer,
|
||||||
|
PlayerConnectServer,
|
||||||
|
PlayerPostConnectServer,
|
||||||
|
PlayerLogout,
|
||||||
|
|
||||||
|
// Server
|
||||||
|
ServerOffline,
|
||||||
|
ServerOnline
|
||||||
|
}
|
@@ -7,10 +7,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BroadcastPlayerMessageEvent {
|
public class BroadcastPlayerMessage {
|
||||||
public static final String ACTION = "BroadcastPlayerMessage";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final DisplayMessage message;
|
private final DisplayMessage message;
|
||||||
|
|
||||||
}
|
}
|
@@ -8,11 +8,9 @@ import org.jetbrains.annotations.Nullable;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class DispatchConsoleCommandEvent {
|
public class DispatchConsoleCommand {
|
||||||
public static final String ACTION = "DispatchConsoleCommand";
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private final BallServerType type;
|
private final BallServerType serverType;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final String serverID;
|
private final String serverID;
|
||||||
@NotNull
|
@NotNull
|
@@ -10,11 +10,9 @@ import java.util.UUID;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class DispatchPlayerCommandEvent {
|
public class DispatchPlayerCommand {
|
||||||
public static final String ACTION = "DispatchPlayerCommand";
|
|
||||||
|
|
||||||
@Nullable
|
@Nullable
|
||||||
private final BallServerType type;
|
private final BallServerType serverType;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final UUID uuid;
|
private final UUID uuid;
|
||||||
@NotNull
|
@NotNull
|
@@ -9,12 +9,9 @@ import java.util.UUID;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class KickPlayerEvent {
|
public class KickPlayer {
|
||||||
public static final String ACTION = "KickPlayer";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final UUID uuid;
|
private final UUID uuid;
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Component reason;
|
private final Component reason;
|
||||||
|
|
||||||
}
|
}
|
@@ -10,9 +10,7 @@ import java.util.UUID;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class SendMessageToPlayerEvent {
|
public class SendMessageToPlayer {
|
||||||
public static final String ACTION = "SendMessageToPlayer";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Set<UUID> receivers;
|
private final Set<UUID> receivers;
|
||||||
@NotNull
|
@NotNull
|
@@ -12,14 +12,11 @@ import java.util.UUID;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class SendPlayerToLocationEvent {
|
public class SendPlayerToLocation {
|
||||||
public static final String ACTION = "SendPlayerToLocation";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Set<UUID> sendPlayerUUID;
|
private final Set<UUID> sendPlayer;
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallLocation location;
|
private final BallLocation location;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final DisplayMessage doneMessage;
|
private final DisplayMessage doneMessage;
|
||||||
|
|
||||||
}
|
}
|
@@ -11,16 +11,13 @@ import java.util.UUID;
|
|||||||
|
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class SendPlayerToPlayerEvent {
|
public class SendPlayerToPlayer {
|
||||||
public static final String ACTION = "SendPlayerToPlayer";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final Set<UUID> sendPlayerUUID;
|
private final Set<UUID> sendPlayer;
|
||||||
@NotNull
|
@NotNull
|
||||||
private final UUID toPlayerUUID;
|
private final UUID toPlayer;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final DisplayMessage doneMessage;
|
private final DisplayMessage doneMessage;
|
||||||
@Nullable
|
@Nullable
|
||||||
private final DisplayMessage doneTargetMessage;
|
private final DisplayMessage doneTargetMessage;
|
||||||
|
|
||||||
}
|
}
|
@@ -0,0 +1,27 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.common.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Data;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家进入子服
|
||||||
|
* <p>
|
||||||
|
* 仅在使用 velocity 代理端时才会触发这个事件
|
||||||
|
*
|
||||||
|
* @see BallPlayerPreConnectServer 玩家准备进入子服
|
||||||
|
* @see BallPlayerConnectServer 玩家进入子服
|
||||||
|
* @see BallPlayerPostConnectServer 玩家已经进入子服
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerConnectServer {
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@Nullable
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
|
}
|
@@ -10,9 +10,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerInfoUpdateEvent {
|
public class BallPlayerInfoUpdate {
|
||||||
public static final String ACTION = "PlayerInfoUpdateEvent";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallPlayerInfo playerInfo;
|
private final BallPlayerInfo playerInfo;
|
||||||
}
|
}
|
@@ -10,10 +10,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerLoginEvent {
|
public class BallPlayerLogin {
|
||||||
public static final String ACTION = "PlayerLogin";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallPlayerInfo playerInfo;
|
private final BallPlayerInfo playerInfo;
|
||||||
|
|
||||||
}
|
}
|
@@ -10,9 +10,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerLogoutEvent {
|
public class BallPlayerLogout {
|
||||||
public static final String ACTION = "PlayerLogout";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private BallPlayerInfo playerInfo;
|
private BallPlayerInfo playerInfo;
|
||||||
}
|
}
|
@@ -0,0 +1,24 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.common.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Data;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家已经进入子服
|
||||||
|
*
|
||||||
|
* @see BallPlayerPreConnectServer 玩家准备进入子服
|
||||||
|
* @see BallPlayerConnectServer 玩家进入子服
|
||||||
|
* @see BallPlayerPostConnectServer 玩家已经进入子服
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerPostConnectServer {
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@NotNull
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
|
}
|
@@ -10,9 +10,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerPostLoginEvent {
|
public class BallPlayerPostLogin {
|
||||||
public static final String ACTION = "PlayerPostLogin";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallPlayerInfo playerInfo;
|
private final BallPlayerInfo playerInfo;
|
||||||
}
|
}
|
@@ -0,0 +1,25 @@
|
|||||||
|
package cn.hamster3.mc.plugin.ball.common.event.player;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallPlayerInfo;
|
||||||
|
import lombok.AllArgsConstructor;
|
||||||
|
import lombok.Data;
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 玩家准备进入子服
|
||||||
|
*
|
||||||
|
* @see BallPlayerPreConnectServer 玩家准备进入子服
|
||||||
|
* @see BallPlayerConnectServer 玩家进入子服
|
||||||
|
* @see BallPlayerPostConnectServer 玩家已经进入子服
|
||||||
|
*/
|
||||||
|
@Data
|
||||||
|
@AllArgsConstructor
|
||||||
|
public class BallPlayerPreConnectServer {
|
||||||
|
@NotNull
|
||||||
|
private final BallPlayerInfo playerInfo;
|
||||||
|
@Nullable
|
||||||
|
private final String from;
|
||||||
|
@NotNull
|
||||||
|
private final String to;
|
||||||
|
}
|
@@ -9,9 +9,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class BallPlayerPreLoginEvent {
|
public class BallPlayerPreLogin {
|
||||||
public static final String ACTION = "PlayerPreLogin";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final String playerName;
|
private final String playerName;
|
||||||
}
|
}
|
@@ -1,5 +1,6 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.event.server;
|
package cn.hamster3.mc.plugin.ball.common.event.server;
|
||||||
|
|
||||||
|
import cn.hamster3.mc.plugin.ball.common.entity.BallServerInfo;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
import org.jetbrains.annotations.NotNull;
|
import org.jetbrains.annotations.NotNull;
|
||||||
@@ -9,9 +10,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class ServerOfflineEvent {
|
public class ServerOffline {
|
||||||
public static final String ACTION = "ServerOffline";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final String serverID;
|
private final BallServerInfo serverInfo;
|
||||||
}
|
}
|
@@ -10,10 +10,7 @@ import org.jetbrains.annotations.NotNull;
|
|||||||
*/
|
*/
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
public class ServerOnlineEvent {
|
public class ServerOnline {
|
||||||
public static final String ACTION = "ServerOnline";
|
|
||||||
|
|
||||||
@NotNull
|
@NotNull
|
||||||
private final BallServerInfo serverInfo;
|
private final BallServerInfo serverInfo;
|
||||||
|
|
||||||
}
|
}
|
@@ -1,34 +1,33 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.listener;
|
package cn.hamster3.mc.plugin.ball.common.listener;
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
|
import cn.hamster3.mc.plugin.ball.common.data.BallMessage;
|
||||||
import io.lettuce.core.pubsub.RedisPubSubListener;
|
import io.lettuce.core.pubsub.RedisPubSubListener;
|
||||||
|
|
||||||
public class BallDebugListener implements RedisPubSubListener<String, BallMessageInfo> {
|
public class BallDebugLogListener implements RedisPubSubListener<String, BallMessage> {
|
||||||
public static final BallDebugListener INSTANCE = new BallDebugListener();
|
public static final BallDebugLogListener INSTANCE = new BallDebugLogListener();
|
||||||
|
|
||||||
private BallDebugListener() {
|
private BallDebugLogListener() {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void message(String channel, BallMessageInfo event) {
|
public void message(String channel, BallMessage message) {
|
||||||
BallAPI.getInstance().getLogger().info("从 " + channel + " 收到了一条消息: " + event);
|
BallAPI.getInstance().getLogger().info("从 " + channel + " 收到了一条消息: " + message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void message(String pattern, String channel, BallMessageInfo event) {
|
public void message(String pattern, String channel, BallMessage message) {
|
||||||
BallAPI.getInstance().getLogger().info("从 " + pattern + "(" + channel + ") 收到了一条消息: " + event);
|
BallAPI.getInstance().getLogger().info("从 " + channel + "(" + pattern + ") 收到了一条消息: " + message);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void subscribed(String channel, long count) {
|
public void subscribed(String channel, long count) {
|
||||||
BallAPI.getInstance().getLogger().info("已订阅 redis 频道: " + channel);
|
BallAPI.getInstance().getLogger().info("已订阅 redis 频道: " + channel);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void psubscribed(String pattern, long count) {
|
public void psubscribed(String pattern, long count) {
|
||||||
BallAPI.getInstance().getLogger().info("已取消订阅 redis 频道(正则): " + pattern);
|
BallAPI.getInstance().getLogger().info("已订阅 redis 频道(正则): " + pattern);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
@@ -1,55 +0,0 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.listener;
|
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.player.*;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOfflineEvent;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOnlineEvent;
|
|
||||||
import org.jetbrains.annotations.NotNull;
|
|
||||||
|
|
||||||
public interface BallListener {
|
|
||||||
/**
|
|
||||||
* 该监听器的执行优先级
|
|
||||||
*
|
|
||||||
* @return 优先级
|
|
||||||
*/
|
|
||||||
default ListenerPriority getPriority() {
|
|
||||||
return ListenerPriority.NORMAL;
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onMessageReceived(@NotNull BallMessageInfo event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onMessageSend(@NotNull BallMessageInfo event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerPreLogin(@NotNull BallPlayerPreLoginEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerLogin(@NotNull BallPlayerLoginEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerPostLogin(@NotNull BallPlayerPostLoginEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerPreConnectServer(@NotNull BallPlayerPreConnectServerEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerConnectServer(@NotNull BallPlayerConnectServerEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerPostConnectServer(@NotNull BallPlayerPostConnectServerEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerLogout(@NotNull BallPlayerLogoutEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onBallPlayerInfoUpdate(@NotNull BallPlayerInfoUpdateEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onServerOnline(@NotNull ServerOnlineEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
default void onServerOffline(@NotNull ServerOfflineEvent event) {
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,167 +0,0 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.listener;
|
|
||||||
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.api.BallAPI;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.data.BallMessageInfo;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.player.*;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOfflineEvent;
|
|
||||||
import cn.hamster3.mc.plugin.ball.common.event.server.ServerOnlineEvent;
|
|
||||||
import cn.hamster3.mc.plugin.core.common.api.CoreAPI;
|
|
||||||
import io.lettuce.core.pubsub.RedisPubSubListener;
|
|
||||||
|
|
||||||
public class BallMessageListener implements RedisPubSubListener<String, BallMessageInfo> {
|
|
||||||
public static final BallMessageListener INSTANCE = new BallMessageListener();
|
|
||||||
|
|
||||||
private BallMessageListener() {
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void message(String channel, BallMessageInfo info) {
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onMessageReceived(info);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!BallAPI.BALL_CHANNEL.equals(info.getChannel())) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
switch (info.getAction()) {
|
|
||||||
case BallPlayerPreLoginEvent.ACTION: {
|
|
||||||
BallPlayerPreLoginEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerPreLoginEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerPreLogin(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerLoginEvent.ACTION: {
|
|
||||||
BallPlayerLoginEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerLoginEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerLogin(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerPostLoginEvent.ACTION: {
|
|
||||||
BallPlayerPostLoginEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerPostLoginEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerPostLogin(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerPreConnectServerEvent.ACTION: {
|
|
||||||
BallPlayerPreConnectServerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerPreConnectServerEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerPreConnectServer(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerConnectServerEvent.ACTION: {
|
|
||||||
BallPlayerConnectServerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerConnectServerEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerConnectServer(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerPostConnectServerEvent.ACTION: {
|
|
||||||
BallPlayerPostConnectServerEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerPostConnectServerEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerPostConnectServer(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerLogoutEvent.ACTION: {
|
|
||||||
BallPlayerLogoutEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerLogoutEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerLogout(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case BallPlayerInfoUpdateEvent.ACTION: {
|
|
||||||
BallPlayerInfoUpdateEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), BallPlayerInfoUpdateEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onBallPlayerInfoUpdate(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ServerOfflineEvent.ACTION: {
|
|
||||||
ServerOfflineEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), ServerOfflineEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onServerOffline(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case ServerOnlineEvent.ACTION: {
|
|
||||||
ServerOnlineEvent event = CoreAPI.getInstance().getGson().fromJson(info.getContent(), ServerOnlineEvent.class);
|
|
||||||
for (BallListener listener : BallAPI.getInstance().getListeners()) {
|
|
||||||
try {
|
|
||||||
listener.onServerOnline(event);
|
|
||||||
} catch (Exception | Error e) {
|
|
||||||
e.printStackTrace();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void message(String pattern, String channel, BallMessageInfo info) {
|
|
||||||
message(channel, info);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void subscribed(String channel, long count) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void psubscribed(String pattern, long count) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void unsubscribed(String channel, long count) {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void punsubscribed(String pattern, long count) {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,45 +0,0 @@
|
|||||||
package cn.hamster3.mc.plugin.ball.common.listener;
|
|
||||||
|
|
||||||
@SuppressWarnings("unused")
|
|
||||||
public enum ListenerPriority {
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Event call is of very low importance and should be run first, to allow
|
|
||||||
* other plugins to further customise the outcome
|
|
||||||
*/
|
|
||||||
LOWEST(0),
|
|
||||||
/**
|
|
||||||
* Event call is of low importance
|
|
||||||
*/
|
|
||||||
LOW(1),
|
|
||||||
/**
|
|
||||||
* Event call is neither important nor unimportant, and may be run
|
|
||||||
* normally
|
|
||||||
*/
|
|
||||||
NORMAL(2),
|
|
||||||
/**
|
|
||||||
* Event call is of high importance
|
|
||||||
*/
|
|
||||||
HIGH(3),
|
|
||||||
/**
|
|
||||||
* Event call is critical and must have the final say in what happens
|
|
||||||
* to the event
|
|
||||||
*/
|
|
||||||
HIGHEST(4),
|
|
||||||
/**
|
|
||||||
* Event is listened to purely for monitoring the outcome of an event.
|
|
||||||
* <p>
|
|
||||||
* No modifications to the event should be made under this priority
|
|
||||||
*/
|
|
||||||
MONITOR(5);
|
|
||||||
|
|
||||||
private final int slot;
|
|
||||||
|
|
||||||
ListenerPriority(int slot) {
|
|
||||||
this.slot = slot;
|
|
||||||
}
|
|
||||||
|
|
||||||
public int getSlot() {
|
|
||||||
return slot;
|
|
||||||
}
|
|
||||||
}
|
|
Reference in New Issue
Block a user