minecraft-src/com/mojang/realmsclient/util/task/CloseServerTask.java
2025-07-04 03:45:38 +03:00

63 lines
1.7 KiB
Java

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.dto.RealmsServer.State;
import com.mojang.realmsclient.exception.RetryCallException;
import com.mojang.realmsclient.gui.screens.RealmsConfigureWorldScreen;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.minecraft.network.chat.Component;
import org.slf4j.Logger;
@Environment(EnvType.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 serverData, RealmsConfigureWorldScreen configureScreen) {
this.serverData = serverData;
this.configureScreen = configureScreen;
}
public void run() {
RealmsClient realmsClient = RealmsClient.getOrCreate();
for (int i = 0; i < 25; i++) {
if (this.aborted()) {
return;
}
try {
boolean bl = realmsClient.close(this.serverData.id);
if (bl) {
this.configureScreen.stateChanged();
this.serverData.state = State.CLOSED;
setScreen(this.configureScreen);
break;
}
} catch (RetryCallException var4) {
if (this.aborted()) {
return;
}
pause(var4.delaySeconds);
} catch (Exception var5) {
if (this.aborted()) {
return;
}
LOGGER.error("Failed to close server", (Throwable)var5);
this.error(var5);
}
}
}
@Override
public Component getTitle() {
return TITLE;
}
}