package org.openstack.atlas.api.async; import org.openstack.atlas.service.domain.entities.AccessList; import org.openstack.atlas.service.domain.entities.LoadBalancer; import org.openstack.atlas.service.domain.entities.LoadBalancerStatus; import org.openstack.atlas.service.domain.entities.UserPages; import org.openstack.atlas.service.domain.exceptions.EntityNotFoundException; import javax.jms.Message; import java.util.ArrayList; import java.util.HashSet; import java.util.List; import java.util.Set; 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_ACCESS_LIST; 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 DeleteAccessListListener extends BaseListener { @Override public void doOnMessage(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 ex) { String alertDescription = String.format("Load balancer '%d' not found in database.", queueLb.getId()); notificationService.saveAlert(queueLb.getAccountId(), queueLb.getId(), ex, DATABASE_FAILURE.name(), alertDescription); sendErrorToEventResource(queueLb, queueLb.getAccessLists()); return; } List<Integer> accessListsToDelete = new ArrayList<Integer>(); for (AccessList item : queueLb.getAccessLists()) { accessListsToDelete.add(item.getId()); } try { if (isRestAdapter()) { LOG.debug(String.format("Deleting access list for load balancer '%s' in STM...", dbLoadBalancer.getId())); reverseProxyLoadBalancerStmService.deleteAccessList(dbLoadBalancer, accessListsToDelete); LOG.debug(String.format("Access list successfully deleted for load balancer '%s' in Zeus.", dbLoadBalancer.getId())); } else { LOG.debug(String.format("Deleting access list for load balancer '%s' in ZXTM...", dbLoadBalancer.getId())); reverseProxyLoadBalancerService.deleteAccessList(dbLoadBalancer.getId(), dbLoadBalancer.getAccountId()); LOG.debug(String.format("Access list successfully deleted for load balancer '%s' in Zeus.", dbLoadBalancer.getId())); } } catch (Exception e) { loadBalancerService.setStatus(dbLoadBalancer, LoadBalancerStatus.ERROR); String alertDescription = String.format("Error deleting access list in Zeus for loadbalancer '%d'.", queueLb.getId()); LOG.error(alertDescription, e); notificationService.saveAlert(dbLoadBalancer.getAccountId(), dbLoadBalancer.getId(), e, ZEUS_FAILURE.name(), alertDescription); sendErrorToEventResource(queueLb, queueLb.getAccessLists()); return; } String atomTitle = "Network Item Successfully Deleted"; for (Integer id : accessListsToDelete) { String atomSummary = String.format("Network Item '%d' successfully deleted", id); notificationService.saveAccessListEvent(queueLb.getUserName(), queueLb.getAccountId(), queueLb.getId(), id, atomTitle, atomSummary, DELETE_ACCESS_LIST, DELETE, INFO); LOG.debug(String.format("Removing access list item '%d' from database...", id)); } Set<AccessList> saveList = new HashSet<AccessList>(); for (AccessList item : dbLoadBalancer.getAccessLists()) { if (!accessListsToDelete.contains(item.getId())) { saveList.add(item); } } dbLoadBalancer.setAccessLists(saveList); dbLoadBalancer.setStatus(LoadBalancerStatus.ACTIVE); loadBalancerService.update(dbLoadBalancer); //Set status record loadBalancerStatusHistoryService.save(dbLoadBalancer.getAccountId(), dbLoadBalancer.getId(), LoadBalancerStatus.ACTIVE); } private void sendErrorToEventResource(LoadBalancer lb, Set<AccessList> accessLists) { Integer itemId; String title = "Error Updating Access List"; for (AccessList accessList : accessLists) { String desc = createAtomErrorSummary(accessList).toString(); itemId = accessList == null ? lb.getId() : accessList.getId(); // TODO: Find a better way of dealing with null id notificationService.saveAccessListEvent(lb.getUserName(), lb.getAccountId(), lb.getId(), itemId, title, desc, DELETE_ACCESS_LIST, DELETE, CRITICAL); } } private StringBuilder createAtomErrorSummary(AccessList accessListItem) { StringBuilder atomSummary = new StringBuilder(); atomSummary.append("Error updating access list with the following network item: "); atomSummary.append("address: '").append(accessListItem.getIpAddress()).append("', "); atomSummary.append("type: '").append(accessListItem.getType()).append("'"); return atomSummary; } }