package org.openstack.atlas.api.async;
import org.openstack.atlas.service.domain.entities.*;
import org.openstack.atlas.service.domain.exceptions.EntityNotFoundException;
import org.openstack.atlas.service.domain.services.helpers.NodesHelper;
import org.openstack.atlas.api.atom.EntryHelper;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import javax.jms.Message;
import static org.openstack.atlas.service.domain.services.helpers.AlertType.DATABASE_FAILURE;
import static org.openstack.atlas.service.domain.services.helpers.AlertType.ZEUS_FAILURE;
import static org.openstack.atlas.service.domain.events.entities.CategoryType.CREATE;
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.CREATE_NODE;
import static org.openstack.atlas.api.atom.EntryHelper.CREATE_NODE_TITLE;
public class CreateNodesListener extends BaseListener {
private final Log LOG = LogFactory.getLog(CreateNodesListener.class);
@Override
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;
}
try {
if (isRestAdapter()) {
LOG.debug("Setting nodes in STM...");
reverseProxyLoadBalancerStmService.setNodes(dbLoadBalancer);
LOG.debug("Nodes successfully set.");
} else {
LOG.debug("Setting nodes in ZXTM...");
reverseProxyLoadBalancerService.setNodes(dbLoadBalancer);
LOG.debug("Nodes successfully set.");
}
} catch (Exception e) {
loadBalancerService.setStatus(dbLoadBalancer, LoadBalancerStatus.ERROR);
String alertDescription = "Error setting nodes in Zeus for loadbalancer #" + dbLoadBalancer.getId();
LOG.error(alertDescription, e);
notificationService.saveAlert(dbLoadBalancer.getAccountId(), dbLoadBalancer.getId(), e, ZEUS_FAILURE.name(), alertDescription);
sendErrorToEventResource(queueLb);
return;
}
// Update load balancer in DB
dbLoadBalancer.setStatus(LoadBalancerStatus.ACTIVE);
NodesHelper.setNodesToStatus(queueLb, dbLoadBalancer, NodeStatus.ONLINE);
loadBalancerService.update(dbLoadBalancer);
//Set status record
loadBalancerStatusHistoryService.save(dbLoadBalancer.getAccountId(), dbLoadBalancer.getId(), LoadBalancerStatus.ACTIVE);
// Add atom entries for new nodes only
for (Node dbNode : dbLoadBalancer.getNodes()) {
for (Node queueNode : queueLb.getNodes()) {
if (queueNode.getIpAddress().equals(dbNode.getIpAddress()) && queueNode.getPort().equals(dbNode.getPort()))
notificationService.saveNodeEvent(queueLb.getUserName(), dbLoadBalancer.getAccountId(), dbLoadBalancer.getId(),
dbNode.getId(), CREATE_NODE_TITLE, EntryHelper.createNodeSummary(dbNode), CREATE_NODE, CREATE, INFO);
}
}
LOG.info(String.format("Create nodes operation successfully completed for load balancer '%d'", dbLoadBalancer.getId()));
}
private void sendErrorToEventResource(LoadBalancer lb) {
String title = "Error Creating Node";
String desc = "Could not create the node at this time";
for (Node node : lb.getNodes()) {
notificationService.saveNodeEvent(lb.getUserName(), lb.getAccountId(), lb.getId(), node.getId(), title, desc, CREATE_NODE, CREATE, CRITICAL);
}
}
}