/* * This file is part of Player Analytics (Plan). * * Plan is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License v3 as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Plan is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Plan. If not, see . */ package net.playeranalytics.plan.gathering.listeners.fabric; import com.djrapitops.plan.gathering.cache.SessionCache; import com.djrapitops.plan.gathering.domain.ActiveSession; import com.djrapitops.plan.identification.ServerInfo; import com.djrapitops.plan.settings.config.WorldAliasSettings; import com.djrapitops.plan.storage.database.DBSystem; import com.djrapitops.plan.storage.database.transactions.events.WorldNameStoreTransaction; import com.djrapitops.plan.utilities.logging.ErrorContext; import com.djrapitops.plan.utilities.logging.ErrorLogger; import net.minecraft.server.network.ServerPlayerEntity; import net.minecraft.world.GameMode; import net.playeranalytics.plan.gathering.listeners.FabricListener; import net.playeranalytics.plan.gathering.listeners.events.PlanFabricEvents; import javax.inject.Inject; import java.util.Optional; import java.util.UUID; /** * Event Listener for PlayerGameModeChangeEvents. * * @author AuroraLS3 */ public class GameModeChangeListener implements FabricListener { private final WorldAliasSettings worldAliasSettings; private final ServerInfo serverInfo; private final DBSystem dbSystem; private final ErrorLogger errorLogger; private boolean isEnabled = false; @Inject public GameModeChangeListener( WorldAliasSettings worldAliasSettings, ServerInfo serverInfo, DBSystem dbSystem, ErrorLogger errorLogger ) { this.worldAliasSettings = worldAliasSettings; this.serverInfo = serverInfo; this.dbSystem = dbSystem; this.errorLogger = errorLogger; } public void onGameModeChange(ServerPlayerEntity player, GameMode newGameMode) { try { actOnEvent(player, newGameMode); } catch (Exception e) { errorLogger.error(e, ErrorContext.builder().related(getClass(), player, newGameMode).build()); } } private void actOnEvent(ServerPlayerEntity player, GameMode newGameMode) { UUID uuid = player.getUuid(); long time = System.currentTimeMillis(); String gameMode = newGameMode.name(); String worldName = player.getWorld().getRegistryKey().getValue().toString(); dbSystem.getDatabase().executeTransaction(new WorldNameStoreTransaction(serverInfo.getServerUUID(), worldName)); worldAliasSettings.addWorld(worldName); Optional cachedSession = SessionCache.getCachedSession(uuid); cachedSession.ifPresent(session -> session.changeState(worldName, gameMode, time)); } @Override public void register() { if (!this.isEnabled) { return; } PlanFabricEvents.ON_GAMEMODE_CHANGE.register(this::onGameModeChange); this.enable(); } @Override public boolean isEnabled() { return this.isEnabled; } @Override public void enable() { this.isEnabled = true; } @Override public void disable() { this.isEnabled = false; } }