org.cloudfoundry.multiapps.controller.process.steps.DeleteIdleRoutesStep Maven / Gradle / Ivy
package org.cloudfoundry.multiapps.controller.process.steps;
import java.util.HashSet;
import java.util.Set;
import jakarta.inject.Named;
import org.apache.commons.collections4.SetUtils;
import org.cloudfoundry.multiapps.controller.client.lib.domain.CloudApplicationExtended;
import org.cloudfoundry.multiapps.controller.process.Messages;
import org.cloudfoundry.multiapps.controller.process.variables.Variables;
import org.springframework.beans.factory.config.BeanDefinition;
import org.springframework.context.annotation.Scope;
import org.springframework.http.HttpStatus;
import com.sap.cloudfoundry.client.facade.CloudControllerClient;
import com.sap.cloudfoundry.client.facade.CloudOperationException;
import com.sap.cloudfoundry.client.facade.domain.CloudApplication;
import com.sap.cloudfoundry.client.facade.domain.CloudRoute;
@Named("deleteIdleRoutesStep")
@Scope(BeanDefinition.SCOPE_PROTOTYPE)
public class DeleteIdleRoutesStep extends SyncFlowableStep {
@Override
protected StepPhase executeStep(ProcessContext context) {
boolean deleteIdleRoutes = context.getVariable(Variables.DELETE_IDLE_URIS);
CloudApplication existingApp = context.getVariable(Variables.EXISTING_APP);
if (!deleteIdleRoutes || existingApp == null) {
return StepPhase.DONE;
}
getStepLogger().debug(Messages.DELETING_IDLE_URIS);
CloudControllerClient client = context.getControllerClient();
CloudApplicationExtended app = context.getVariable(Variables.APP_TO_PROCESS);
deleteIdleRoutes(context, client, app);
getStepLogger().debug(Messages.IDLE_URIS_DELETED);
return StepPhase.DONE;
}
@Override
protected String getStepErrorMessage(ProcessContext context) {
return Messages.ERROR_DELETING_IDLE_ROUTES;
}
private void deleteIdleRoutes(ProcessContext context, CloudControllerClient client, CloudApplicationExtended newLiveApp) {
var currentRoutes = context.getVariable(Variables.CURRENT_ROUTES);
Set idleRoutes = SetUtils.difference(new HashSet<>(currentRoutes), newLiveApp.getRoutes())
.toSet();
getStepLogger().debug(Messages.IDLE_URIS_FOR_APPLICATION, idleRoutes);
for (CloudRoute idleRoute : idleRoutes) {
deleteRoute(idleRoute, client);
getStepLogger().debug(Messages.ROUTE_DELETED, idleRoute.getUrl());
}
}
private void deleteRoute(CloudRoute route, CloudControllerClient client) {
try {
client.deleteRoute(route.getHost(), route.getDomain()
.getName(), route.getPath());
} catch (CloudOperationException e) {
handleCloudOperationException(e, route);
}
}
private void handleCloudOperationException(CloudOperationException e, CloudRoute route) {
if (e.getStatusCode() == HttpStatus.CONFLICT) {
getStepLogger().info(Messages.ROUTE_NOT_DELETED, route);
return;
}
if (e.getStatusCode() == HttpStatus.NOT_FOUND) {
getStepLogger().info(org.cloudfoundry.multiapps.controller.core.Messages.ROUTE_NOT_FOUND, route);
return;
}
throw e;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy