package org.openstack.atlas.api.async;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.openstack.atlas.adapter.helpers.ZxtmNameBuilder;
import org.openstack.atlas.service.domain.entities.LoadBalancer;
import org.openstack.atlas.service.domain.entities.LoadBalancerStatus;
import org.openstack.atlas.service.domain.entities.Node;
import org.openstack.atlas.service.domain.exceptions.EntityNotFoundException;
import javax.jms.Message;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import static org.openstack.atlas.service.domain.events.entities.CategoryType.DELETE;
import static org.openstack.atlas.service.domain.events.entities.EventSeverity.CRITICAL;
import static org.openstack.atlas.service.domain.events.entities.EventSeverity.INFO;
import static org.openstack.atlas.service.domain.events.entities.EventType.DELETE_NODE;
import static org.openstack.atlas.service.domain.services.helpers.AlertType.DATABASE_FAILURE;
import static org.openstack.atlas.service.domain.services.helpers.AlertType.ZEUS_FAILURE;
public class DeleteNodeListener extends BaseListener {
private final Log LOG = LogFactory.getLog(DeleteNodeListener.class);
public void doOnMessage(final Message message) throws Exception {
LOG.debug("Entering " + getClass());
LOG.debug(message);
LoadBalancer queueLb = getLoadbalancerFromMessage(message);
LoadBalancer dbLoadBalancer;
try {
dbLoadBalancer = loadBalancerService.get(queueLb.getId(), queueLb.getAccountId());
} catch (EntityNotFoundException enfe) {
String alertDescription = String.format("Load balancer '%d' not found in database.", queueLb.getId());
LOG.error(alertDescription, enfe);
notificationService.saveAlert(queueLb.getAccountId(), queueLb.getId(), enfe, DATABASE_FAILURE.name(), alertDescription);
sendErrorToEventResource(queueLb);
return;
}
Node nodeToDelete = queueLb.getNodes().iterator().next();
for (Node node : dbLoadBalancer.getNodes()) {
if (node.getId().equals(nodeToDelete.getId())) {
nodeToDelete = node;
break;
}
}
try {
if (isRestAdapter()) {
LOG.debug(String.format("Removing node '%d' from load balancer '%d' in STM...", nodeToDelete.getId(), queueLb.getId()));
// dbLoadBalancer.setNodes(nodeService.getAllNodesByAccountIdLoadBalancerId(dbLoadBalancer.getAccountId(), dbLoadBalancer.getId()));
reverseProxyLoadBalancerStmService.removeNode(dbLoadBalancer, nodeToDelete);
LOG.debug(String.format("Successfully removed node '%d' from load balancer '%d' in STM.", nodeToDelete.getId(), queueLb.getId()));
} else {
LOG.debug(String.format("Removing node '%d' from load balancer '%d' in ZXTM...", nodeToDelete.getId(), queueLb.getId()));
reverseProxyLoadBalancerService.setNodesPriorities(ZxtmNameBuilder.genVSName(dbLoadBalancer), dbLoadBalancer);
reverseProxyLoadBalancerService.removeNode(queueLb.getId(), queueLb.getAccountId(), nodeToDelete);
LOG.debug(String.format("Successfully removed node '%d' from load balancer '%d' in Zeus.", nodeToDelete.getId(), queueLb.getId()));
}
} catch (Exception e) {
loadBalancerService.setStatusForOp(dbLoadBalancer, LoadBalancerStatus.ERROR);
String alertDescription = String.format("Error removing node '%d' in Zeus for loadbalancer '%d'.", nodeToDelete.getId(), queueLb.getId());
LOG.error(alertDescription, e);
notificationService.saveAlert(queueLb.getAccountId(), queueLb.getId(), e, ZEUS_FAILURE.name(), alertDescription);
sendErrorToEventResource(queueLb, nodeToDelete);
return;
}
// Remove node from load balancer in DB
dbLoadBalancer = nodeService.delNodes(dbLoadBalancer, Arrays.asList(nodeToDelete));
// Update load balancer status in DB
loadBalancerService.setStatusForOp(dbLoadBalancer, LoadBalancerStatus.ACTIVE);
//Set status record
loadBalancerStatusHistoryService.save(dbLoadBalancer.getAccountId(), dbLoadBalancer.getId(), LoadBalancerStatus.ACTIVE);
// Add atom entry
String atomTitle = "Node Successfully Deleted";
String atomSummary = "Node successfully deleted";
notificationService.saveNodeEvent(queueLb.getUserName(), queueLb.getAccountId(), queueLb.getId(), nodeToDelete.getId(), atomTitle, atomSummary, DELETE_NODE, DELETE, INFO);
LOG.info(String.format("Delete node operation complete for load balancer '%d'.", queueLb.getId()));
}
private void sendErrorToEventResource(LoadBalancer lb) {
String title = "Error Deleting Node";
String desc = "Could not delete the node at this time.";
notificationService.saveLoadBalancerEvent(lb.getUserName(), lb.getAccountId(), lb.getId(), title, desc, DELETE_NODE, DELETE, CRITICAL);
}
private void sendErrorToEventResource(LoadBalancer lb, Node nodeToDelete) {
String title = "Error Deleting Node";
String desc = "Could not delete the node at this time.";
notificationService.saveNodeEvent(lb.getUserName(), lb.getAccountId(), lb.getId(), nodeToDelete.getId(), title, desc, DELETE_NODE, DELETE, CRITICAL);
}
}