// 
// Decompiled by Procyon v0.6.0
// 

package com.hypixel.hytale.builtin.teleport.commands.warp;

import com.hypixel.hytale.builtin.teleport.Warp;
import java.util.Map;
import java.util.logging.Level;
import com.hypixel.hytale.builtin.teleport.TeleportPlugin;
import javax.annotation.Nonnull;
import com.hypixel.hytale.server.core.command.system.CommandContext;
import com.hypixel.hytale.server.core.permissions.HytalePermissions;
import com.hypixel.hytale.server.core.Message;
import com.hypixel.hytale.logger.HytaleLogger;
import com.hypixel.hytale.server.core.command.system.basecommands.CommandBase;

public class WarpReloadCommand extends CommandBase
{
    private static final HytaleLogger logger;
    private static final Message MESSAGE_COMMANDS_TELEPORT_WARP_NOT_LOADED;
    private static final Message MESSAGE_COMMANDS_TELEPORT_WARP_FAILED_TO_RELOAD;
    
    public WarpReloadCommand() {
        super("reload", "server.commands.warp.reload.desc");
        this.requirePermission(HytalePermissions.fromCommand("warp.reload"));
    }
    
    @Override
    protected void executeSync(@Nonnull final CommandContext context) {
        if (!TeleportPlugin.get().isWarpsLoaded()) {
            context.sendMessage(WarpReloadCommand.MESSAGE_COMMANDS_TELEPORT_WARP_NOT_LOADED);
            return;
        }
        final Map<String, Warp> warps = TeleportPlugin.get().getWarps();
        try {
            TeleportPlugin.get().loadWarps();
            context.sendMessage(Message.translation("server.commands.teleport.warp.reloaded").param("count", warps.size()));
        }
        catch (final Throwable t) {
            context.sendMessage(WarpReloadCommand.MESSAGE_COMMANDS_TELEPORT_WARP_FAILED_TO_RELOAD);
            WarpReloadCommand.logger.at(Level.SEVERE).withCause(t).log("Failed to reload warps:");
        }
    }
    
    static {
        logger = HytaleLogger.forEnclosingClass();
        MESSAGE_COMMANDS_TELEPORT_WARP_NOT_LOADED = Message.translation("server.commands.teleport.warp.notLoaded");
        MESSAGE_COMMANDS_TELEPORT_WARP_FAILED_TO_RELOAD = Message.translation("server.commands.teleport.warp.failedToReload");
    }
}
