package org.openstack.atlas.api.mgmt.async; import org.openstack.atlas.service.domain.entities.Host; import org.openstack.atlas.service.domain.exceptions.EntityNotFoundException; import org.openstack.atlas.service.domain.pojos.Hostssubnet; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import javax.jms.Message; public class MgmtSetHostSubnetMappingListener extends BaseListener { private final Log LOG = LogFactory.getLog(MgmtSetHostSubnetMappingListener.class); @Override public void doOnMessage(final Message message) throws Exception { LOG.debug("Entering " + getClass()); LOG.debug(message); Host rHost = getEsbRequestFromMessage(message).getHost(); Host dHost = null; try { dHost = hostService.getById(rHost.getId()); } catch (EntityNotFoundException enfe) { return; } Hostssubnet hostssubnet = getEsbRequestFromMessage(message).getHostssubnet(); hostssubnet.getHostsubnets().get(0).setName(dHost.getTrafficManagerName()); if (isRestAdapter()) { //TODO: currently not supported in REST... LOG.debug("Setting Host Subnet Mappings..."); reverseProxyLoadBalancerService.setSubnetMappings(dHost, hostssubnet); } else { LOG.debug("Setting Host Subnet Mappings..."); reverseProxyLoadBalancerService.setSubnetMappings(dHost, hostssubnet); } //sendSuccessfulResponse(message, hostssubnet); } }