Search in sources :

Example 1 with ReportAction

use of com.faforever.client.notification.ReportAction in project downlords-faf-client by FAForever.

the class GameServiceImpl method startGame.

/**
 * Actually starts the game, including relay and replay server. Call this method when everything else is prepared
 * (mod/map download, connectivity check etc.)
 */
private void startGame(GameLaunchMessage gameLaunchMessage, Faction faction, RatingMode ratingMode) {
    if (isRunning()) {
        logger.warn("Forged Alliance is already running, not starting game");
        return;
    }
    stopSearchLadder1v1();
    replayService.startReplayServer(gameLaunchMessage.getUid()).thenCompose(aVoid -> iceAdapter.start()).thenAccept(adapterPort -> {
        List<String> args = fixMalformedArgs(gameLaunchMessage.getArgs());
        process = noCatch(() -> forgedAllianceService.startGame(gameLaunchMessage.getUid(), faction, args, ratingMode, adapterPort, clientProperties.getReplay().getLocalServerPort(), rehostRequested, getCurrentPlayer()));
        setGameRunning(true);
        this.ratingMode = ratingMode;
        spawnTerminationListener(process);
    }).exceptionally(throwable -> {
        logger.warn("Game could not be started", throwable);
        notificationService.addNotification(new ImmediateNotification(i18n.get("errorTitle"), i18n.get("game.start.couldNotStart"), ERROR, throwable, Arrays.asList(new ReportAction(i18n, reportingService, throwable), new DismissAction(i18n))));
        setGameRunning(false);
        return null;
    });
}
Also used : Arrays(java.util.Arrays) RehostRequestEvent(com.faforever.client.fa.relay.event.RehostRequestEvent) CompletableFuture.completedFuture(java.util.concurrent.CompletableFuture.completedFuture) LoggerFactory(org.slf4j.LoggerFactory) ReadOnlyBooleanProperty(javafx.beans.property.ReadOnlyBooleanProperty) ReportingService(com.faforever.client.reporting.ReportingService) ConnectionState(com.faforever.client.net.ConnectionState) GameInfoMessage(com.faforever.client.remote.domain.GameInfoMessage) Collections.singletonList(java.util.Collections.singletonList) ListChangeListener(javafx.collections.ListChangeListener) Map(java.util.Map) GameStatus(com.faforever.client.remote.domain.GameStatus) URI(java.net.URI) PlayerService(com.faforever.client.player.PlayerService) Path(java.nio.file.Path) ClientProperties(com.faforever.client.config.ClientProperties) CancellationException(java.util.concurrent.CancellationException) MethodHandles(java.lang.invoke.MethodHandles) ConcurrentHashMap(java.util.concurrent.ConcurrentHashMap) Set(java.util.Set) ObservableMap(javafx.collections.ObservableMap) Observable(javafx.beans.Observable) DismissAction(com.faforever.client.notification.DismissAction) FeaturedMod(com.faforever.client.mod.FeaturedMod) Platform(javafx.application.Platform) Player(com.faforever.client.player.Player) Nullable(org.jetbrains.annotations.Nullable) RatingMode(com.faforever.client.fa.RatingMode) BooleanProperty(javafx.beans.property.BooleanProperty) Slf4j(lombok.extern.slf4j.Slf4j) List(java.util.List) ForgedAllianceService(com.faforever.client.fa.ForgedAllianceService) PostConstruct(javax.annotation.PostConstruct) ModService(com.faforever.client.mod.ModService) Lazy(org.springframework.context.annotation.Lazy) ObservableList(javafx.collections.ObservableList) NotNull(org.jetbrains.annotations.NotNull) PreferencesService(com.faforever.client.preferences.PreferencesService) WeakChangeListener(javafx.beans.value.WeakChangeListener) GameLaunchMessage(com.faforever.client.remote.domain.GameLaunchMessage) LoginMessage(com.faforever.client.remote.domain.LoginMessage) FXCollections(javafx.collections.FXCollections) CompletableFuture(java.util.concurrent.CompletableFuture) ArrayList(java.util.ArrayList) IceAdapter(com.faforever.client.fa.relay.ice.IceAdapter) PlatformService(com.faforever.client.fx.PlatformService) GameUpdater(com.faforever.client.patch.GameUpdater) EventBus(com.google.common.eventbus.EventBus) Inject(javax.inject.Inject) HashSet(java.util.HashSet) NotificationService(com.faforever.client.notification.NotificationService) Service(org.springframework.stereotype.Service) ERROR(com.faforever.client.notification.Severity.ERROR) Subscribe(com.google.common.eventbus.Subscribe) ReportAction(com.faforever.client.notification.ReportAction) Collections.emptyMap(java.util.Collections.emptyMap) Logger(org.slf4j.Logger) Collections.emptySet(java.util.Collections.emptySet) Executor(java.util.concurrent.Executor) JavaFxUtil(com.faforever.client.fx.JavaFxUtil) Action(com.faforever.client.notification.Action) ReplayService(com.faforever.client.replay.ReplayService) IOException(java.io.IOException) MatchmakerMessage(com.faforever.client.rankedmatch.MatchmakerMessage) PersistentNotification(com.faforever.client.notification.PersistentNotification) FafService(com.faforever.client.remote.FafService) Consumer(java.util.function.Consumer) SimpleBooleanProperty(javafx.beans.property.SimpleBooleanProperty) Severity(com.faforever.client.notification.Severity) SimpleObjectProperty(javafx.beans.property.SimpleObjectProperty) LADDER_1V1(com.faforever.client.game.KnownFeaturedMod.LADDER_1V1) ImmediateNotification(com.faforever.client.notification.ImmediateNotification) NONE(com.faforever.client.fa.RatingMode.NONE) ExternalReplayInfoGenerator(com.faforever.client.replay.ExternalReplayInfoGenerator) VisibleForTesting(com.google.common.annotations.VisibleForTesting) I18n(com.faforever.client.i18n.I18n) MapService(com.faforever.client.map.MapService) Collections(java.util.Collections) NoCatch.noCatch(com.github.nocatch.NoCatch.noCatch) ImmediateNotification(com.faforever.client.notification.ImmediateNotification) DismissAction(com.faforever.client.notification.DismissAction) ReportAction(com.faforever.client.notification.ReportAction) Collections.singletonList(java.util.Collections.singletonList) List(java.util.List) ObservableList(javafx.collections.ObservableList) ArrayList(java.util.ArrayList)

Example 2 with ReportAction

use of com.faforever.client.notification.ReportAction in project downlords-faf-client by FAForever.

the class CreateGameController method onCreateButtonClicked.

public void onCreateButtonClicked() {
    ObservableList<ModVersion> selectedModVersions = modListView.getSelectionModel().getSelectedItems();
    try {
        modService.overrideActivatedMods(modListView.getSelectionModel().getSelectedItems());
    } catch (IOException e) {
        logger.warn("Activated mods could not be updated", e);
    }
    Set<String> simMods = selectedModVersions.stream().map(ModVersion::getUid).collect(Collectors.toSet());
    NewGameInfo newGameInfo = new NewGameInfo(titleTextField.getText(), Strings.emptyToNull(passwordTextField.getText()), featuredModListView.getSelectionModel().getSelectedItem(), mapListView.getSelectionModel().getSelectedItem().getFolderName(), simMods);
    gameService.hostGame(newGameInfo).exceptionally(throwable -> {
        logger.warn("Game could not be hosted", throwable);
        notificationService.addNotification(new ImmediateNotification(i18n.get("errorTitle"), i18n.get("game.create.failed"), Severity.WARN, throwable, Collections.singletonList(new ReportAction(i18n, reportingService, throwable))));
        return null;
    });
    onCloseButtonClicked();
}
Also used : ModVersion(com.faforever.client.mod.ModVersion) ImmediateNotification(com.faforever.client.notification.ImmediateNotification) ReportAction(com.faforever.client.notification.ReportAction) IOException(java.io.IOException)

Example 3 with ReportAction

use of com.faforever.client.notification.ReportAction in project downlords-faf-client by FAForever.

the class ModDetailController method onUninstallButtonClicked.

public void onUninstallButtonClicked() {
    progressBar.progressProperty().unbind();
    progressBar.setProgress(-1);
    uninstallButton.setVisible(false);
    modService.uninstallMod(modVersion).exceptionally(throwable -> {
        notificationService.addNotification(new ImmediateNotification(i18n.get("errorTitle"), i18n.get("modVault.couldNotDeleteMod", modVersion.getDisplayName(), throwable.getLocalizedMessage()), Severity.ERROR, throwable, singletonList(new ReportAction(i18n, reportingService, throwable))));
        return null;
    });
}
Also used : ImmediateNotification(com.faforever.client.notification.ImmediateNotification) ReportAction(com.faforever.client.notification.ReportAction)

Example 4 with ReportAction

use of com.faforever.client.notification.ReportAction in project downlords-faf-client by FAForever.

the class MapDetailController method onUninstallButtonClicked.

public void onUninstallButtonClicked() {
    progressBar.progressProperty().unbind();
    progressBar.setProgress(-1);
    uninstallButton.setVisible(false);
    mapService.uninstallMap(map).thenRun(() -> setInstalled(false)).exceptionally(throwable -> {
        notificationService.addNotification(new ImmediateNotification(i18n.get("errorTitle"), i18n.get("mapVault.couldNotDeleteMap", map.getDisplayName(), throwable.getLocalizedMessage()), Severity.ERROR, throwable, singletonList(new ReportAction(i18n, reportingService, throwable))));
        setInstalled(true);
        return null;
    });
}
Also used : ImmediateNotification(com.faforever.client.notification.ImmediateNotification) ReportAction(com.faforever.client.notification.ReportAction)

Example 5 with ReportAction

use of com.faforever.client.notification.ReportAction in project downlords-faf-client by FAForever.

the class ReplayVaultController method loadLocalReplaysInBackground.

public CompletableFuture<Void> loadLocalReplaysInBackground() {
    // TODO use replay service
    LoadLocalReplaysTask task = applicationContext.getBean(LoadLocalReplaysTask.class);
    replayVaultRoot.getItems().clear();
    return taskService.submitTask(task).getFuture().thenAccept(this::addLocalReplays).exceptionally(throwable -> {
        logger.warn("Error while loading local replays", throwable);
        notificationService.addNotification(new PersistentNotification(i18n.get("replays.loadingLocalTask.failed"), Severity.ERROR, asList(new ReportAction(i18n, reportingService, throwable), new DismissAction(i18n))));
        return null;
    });
}
Also used : LoadLocalReplaysTask(com.faforever.client.replay.LoadLocalReplaysTask) DismissAction(com.faforever.client.notification.DismissAction) ReportAction(com.faforever.client.notification.ReportAction) PersistentNotification(com.faforever.client.notification.PersistentNotification)

Aggregations

ReportAction (com.faforever.client.notification.ReportAction)12 ImmediateNotification (com.faforever.client.notification.ImmediateNotification)11 DismissAction (com.faforever.client.notification.DismissAction)6 I18n (com.faforever.client.i18n.I18n)4 NotificationService (com.faforever.client.notification.NotificationService)4 Severity (com.faforever.client.notification.Severity)4 ReportingService (com.faforever.client.reporting.ReportingService)4 Player (com.faforever.client.player.Player)3 PlayerService (com.faforever.client.player.PlayerService)3 PreferencesService (com.faforever.client.preferences.PreferencesService)3 VisibleForTesting (com.google.common.annotations.VisibleForTesting)3 MethodHandles (java.lang.invoke.MethodHandles)3 Logger (org.slf4j.Logger)3 LoggerFactory (org.slf4j.LoggerFactory)3 ClientProperties (com.faforever.client.config.ClientProperties)2 JavaFxUtil (com.faforever.client.fx.JavaFxUtil)2 PlatformService (com.faforever.client.fx.PlatformService)2 NavigateEvent (com.faforever.client.main.event.NavigateEvent)2 PersistentNotification (com.faforever.client.notification.PersistentNotification)2 UiService (com.faforever.client.theme.UiService)2