aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/moe/ymc/acron/mixin/ServerLoginNetworkHandlerMixin.java
blob: 94a48b54f9c77536a9d230b7ace034e7444e9658 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
package moe.ymc.acron.mixin;

import com.mojang.authlib.GameProfile;
import moe.ymc.acron.s2c.Entity;
import moe.ymc.acron.s2c.EventQueue;
import moe.ymc.acron.s2c.event.EventDisconnected;
import moe.ymc.acron.s2c.event.EventPlayerJoined;
import net.minecraft.network.ClientConnection;
import net.minecraft.server.network.ServerLoginNetworkHandler;
import net.minecraft.server.network.ServerPlayerEntity;
import net.minecraft.text.Text;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.jetbrains.annotations.Nullable;
import org.spongepowered.asm.mixin.Final;
import org.spongepowered.asm.mixin.Mixin;
import org.spongepowered.asm.mixin.Shadow;
import org.spongepowered.asm.mixin.injection.At;
import org.spongepowered.asm.mixin.injection.Inject;
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;

@Mixin(ServerLoginNetworkHandler.class)
public class ServerLoginNetworkHandlerMixin {
    private static final Logger AC_LOGGER = LogManager.getLogger();

    @Shadow
    @Nullable
    GameProfile profile;

    @Shadow
    @Final
    public ClientConnection connection;

    @Inject(at = @At("RETURN"), method = "onDisconnected")
    private void onDisconnected(Text reason, CallbackInfo ci) {
        EventQueue.enqueue(new EventDisconnected(profile == null ? null :
                new Entity(profile),
                reason.getString()));
    }

    @Inject(at = @At("RETURN"), method = "addToServer")
    private void addToServer(ServerPlayerEntity entity, CallbackInfo ci) {
        AC_LOGGER.debug("addToServer: {}",
                entity.getUuid());
        EventQueue.enqueue(new EventPlayerJoined(new Entity(entity)));
    }
}