diff --git a/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDao.java b/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDao.java index 5b0e748adf1..b89d04ad15a 100644 --- a/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDao.java +++ b/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDao.java @@ -44,7 +44,7 @@ public interface PortForwardingRulesDao extends GenericDao listByDestIpAddr(String ip4Address); - List listByVmidAndDestIpAddr(String ip4Address,long vmid); - PortForwardingRuleVO findByIdAndIp(long id, String secondaryIp); + + List listByNetworkAndDestIpAddr(String ip4Address, long networkId); } diff --git a/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDaoImpl.java b/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDaoImpl.java index 6bc401b3941..3aa6181ff70 100644 --- a/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDaoImpl.java +++ b/engine/schema/src/com/cloud/network/rules/dao/PortForwardingRulesDaoImpl.java @@ -158,10 +158,10 @@ public class PortForwardingRulesDaoImpl extends GenericDaoBase listByVmidAndDestIpAddr(String ip4Address,long vmid) { + public List listByNetworkAndDestIpAddr(String ip4Address, long networkId) { SearchCriteria sc = AllFieldsSearch.create(); sc.setParameters("dstIp", ip4Address); - sc.setParameters("vmId", vmid); + sc.setParameters("networkId", networkId); return listBy(sc); } diff --git a/server/src/com/cloud/network/rules/RulesManagerImpl.java b/server/src/com/cloud/network/rules/RulesManagerImpl.java index 59025f2da77..56a075def23 100755 --- a/server/src/com/cloud/network/rules/RulesManagerImpl.java +++ b/server/src/com/cloud/network/rules/RulesManagerImpl.java @@ -1463,14 +1463,20 @@ public class RulesManagerImpl extends ManagerBase implements RulesManager, Rules @Override public List listAssociatedRulesForGuestNic(Nic nic) { + s_logger.debug("Checking if PF/StaticNat/LoadBalancer rules are configured for nic " + nic.getId()); List result = new ArrayList(); // add PF rules - result.addAll(_portForwardingDao.listByVmidAndDestIpAddr(nic.getIp4Address(),nic.getInstanceId())); + result.addAll(_portForwardingDao.listByNetworkAndDestIpAddr(nic.getIp4Address(), nic.getNetworkId())); + if(result.size() > 0) { + s_logger.debug("Found " + result.size() + " portforwarding rule configured for the nic in the network " + nic.getNetworkId()); + } // add static NAT rules List staticNatRules = _firewallDao.listStaticNatByVmId(nic.getInstanceId()); for (FirewallRuleVO rule : staticNatRules) { - if (rule.getNetworkId() == nic.getNetworkId()) + if (rule.getNetworkId() == nic.getNetworkId()) { result.add(rule); + s_logger.debug("Found rule " + rule.getId() + " " + rule.getPurpose() + " configured"); + } } List staticNatIps = _ipAddressDao.listStaticNatPublicIps(nic.getNetworkId()); for (IpAddress ip : staticNatIps) { @@ -1479,17 +1485,20 @@ public class RulesManagerImpl extends ManagerBase implements RulesManager, Rules // generate a static Nat rule on the fly because staticNATrule does not persist into db anymore // FIX ME FirewallRuleVO staticNatRule = - new FirewallRuleVO(null, ip.getId(), 0, 65535, NetUtils.ALL_PROTO.toString(), nic.getNetworkId(), vm.getAccountId(), vm.getDomainId(), - Purpose.StaticNat, null, null, null, null, null); + new FirewallRuleVO(null, ip.getId(), 0, 65535, NetUtils.ALL_PROTO.toString(), nic.getNetworkId(), vm.getAccountId(), vm.getDomainId(), + Purpose.StaticNat, null, null, null, null, null); result.add(staticNatRule); + s_logger.debug("Found rule " + staticNatRule.getId() + " " + staticNatRule.getPurpose() + " configured"); } } // add LB rules List lbMapList = _loadBalancerVMMapDao.listByInstanceId(nic.getInstanceId()); for (LoadBalancerVMMapVO lb : lbMapList) { FirewallRuleVO lbRule = _firewallDao.findById(lb.getLoadBalancerId()); - if (lbRule.getNetworkId() == nic.getNetworkId()) + if (lbRule.getNetworkId() == nic.getNetworkId()) { result.add(lbRule); + s_logger.debug("Found rule " + lbRule.getId() + " " + lbRule.getPurpose() + " configured"); + } } return result; }