soiz1's picture
Upload folder using huggingface_hub
d46f4a3 verified
package com.mojang.realmsclient.util.task;
import com.mojang.logging.LogUtils;
import com.mojang.realmsclient.client.RealmsClient;
import com.mojang.realmsclient.dto.RealmsServer;
import com.mojang.realmsclient.exception.RetryCallException;
import com.mojang.realmsclient.gui.screens.RealmsConfigureWorldScreen;
import net.minecraft.network.chat.Component;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
import org.slf4j.Logger;
@OnlyIn(Dist.CLIENT)
public class CloseServerTask extends LongRunningTask {
private static final Logger LOGGER = LogUtils.getLogger();
private static final Component TITLE = Component.translatable("mco.configure.world.closing");
private final RealmsServer serverData;
private final RealmsConfigureWorldScreen configureScreen;
public CloseServerTask(RealmsServer p_90302_, RealmsConfigureWorldScreen p_90303_) {
this.serverData = p_90302_;
this.configureScreen = p_90303_;
}
@Override
public void run() {
RealmsClient realmsclient = RealmsClient.create();
for (int i = 0; i < 25; i++) {
if (this.aborted()) {
return;
}
try {
boolean flag = realmsclient.close(this.serverData.id);
if (flag) {
this.configureScreen.stateChanged();
this.serverData.state = RealmsServer.State.CLOSED;
setScreen(this.configureScreen);
break;
}
} catch (RetryCallException retrycallexception) {
if (this.aborted()) {
return;
}
pause((long)retrycallexception.delaySeconds);
} catch (Exception exception) {
if (this.aborted()) {
return;
}
LOGGER.error("Failed to close server", (Throwable)exception);
this.error(exception);
}
}
}
@Override
public Component getTitle() {
return TITLE;
}
}