mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	Incorportaed the review changes Now dhcpservice IPs are removed when last vm from the subnet is removed. Rebased with master.
Signed-off-by: Abhinandan Prateek <aprateek@apache.org>
This commit is contained in:
		
							parent
							
								
									4ac6ebb2db
								
							
						
					
					
						commit
						d73bb22802
					
				| @ -16,13 +16,13 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.agent.api.to; | package com.cloud.agent.api.to; | ||||||
| 
 | 
 | ||||||
| public class DnsmasqTO { | public class DhcpTO { | ||||||
|     String routerIp; |     String routerIp; | ||||||
|     String gateway; |     String gateway; | ||||||
|     String netmask; |     String netmask; | ||||||
|     String startIpOfSubnet; |     String startIpOfSubnet; | ||||||
| 
 | 
 | ||||||
|     public DnsmasqTO(String routerIp, String gateway, String netmask, String StartIpOfSubnet) { |     public DhcpTO(String routerIp, String gateway, String netmask, String StartIpOfSubnet) { | ||||||
|         this.routerIp = routerIp; |         this.routerIp = routerIp; | ||||||
|         this.startIpOfSubnet = StartIpOfSubnet; |         this.startIpOfSubnet = StartIpOfSubnet; | ||||||
|         this.gateway = gateway; |         this.gateway = gateway; | ||||||
| @ -180,6 +180,7 @@ public interface Network extends ControlledEntity, StateObject<Network.State>, I | |||||||
|         public static final Capability SupportedEgressProtocols = new Capability("SupportedEgressProtocols"); |         public static final Capability SupportedEgressProtocols = new Capability("SupportedEgressProtocols"); | ||||||
|         public static final Capability HealthCheckPolicy = new Capability("HealthCheckPolicy"); |         public static final Capability HealthCheckPolicy = new Capability("HealthCheckPolicy"); | ||||||
|         public static final Capability LbSchemes = new Capability("LbSchemes"); |         public static final Capability LbSchemes = new Capability("LbSchemes"); | ||||||
|  |         public static final Capability DhcpAccrossMultipleSubnets = new Capability("DhcpAccrossMultipleSubnets"); | ||||||
| 
 | 
 | ||||||
|         private String name; |         private String name; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -17,7 +17,9 @@ | |||||||
| package com.cloud.network; | package com.cloud.network; | ||||||
| 
 | 
 | ||||||
| import java.util.List; | import java.util.List; | ||||||
|  | import java.util.Map; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.offering.NetworkOffering; | ||||||
| import org.apache.cloudstack.api.command.admin.network.DedicateGuestVlanRangeCmd; | import org.apache.cloudstack.api.command.admin.network.DedicateGuestVlanRangeCmd; | ||||||
| import org.apache.cloudstack.api.command.admin.network.ListDedicatedGuestVlanRangesCmd; | import org.apache.cloudstack.api.command.admin.network.ListDedicatedGuestVlanRangesCmd; | ||||||
| import org.apache.cloudstack.api.command.admin.usage.ListTrafficTypeImplementorsCmd; | import org.apache.cloudstack.api.command.admin.usage.ListTrafficTypeImplementorsCmd; | ||||||
| @ -180,4 +182,5 @@ public interface NetworkService { | |||||||
|     /* lists the nic informaton */ |     /* lists the nic informaton */ | ||||||
|     List<? extends Nic> listNics(ListNicsCmd listNicsCmd); |     List<? extends Nic> listNics(ListNicsCmd listNicsCmd); | ||||||
| 
 | 
 | ||||||
|  |     Map<Network.Capability, String> getNetworkOfferingServiceCapabilities(NetworkOffering offering, Service service); | ||||||
| } | } | ||||||
|  | |||||||
| @ -29,5 +29,5 @@ import com.cloud.vm.VirtualMachineProfile; | |||||||
| public interface DhcpServiceProvider extends NetworkElement { | public interface DhcpServiceProvider extends NetworkElement { | ||||||
|     boolean addDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm, DeployDestination dest, ReservationContext context) throws ConcurrentOperationException, InsufficientCapacityException, ResourceUnavailableException; |     boolean addDhcpEntry(Network network, NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm, DeployDestination dest, ReservationContext context) throws ConcurrentOperationException, InsufficientCapacityException, ResourceUnavailableException; | ||||||
|     boolean configDhcpSupportForSubnet(Network network, NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm, DeployDestination dest, ReservationContext context) throws ConcurrentOperationException, InsufficientCapacityException, ResourceUnavailableException; |     boolean configDhcpSupportForSubnet(Network network, NicProfile nic, VirtualMachineProfile<? extends VirtualMachine> vm, DeployDestination dest, ReservationContext context) throws ConcurrentOperationException, InsufficientCapacityException, ResourceUnavailableException; | ||||||
|     boolean  removeDhcpSupportForSubnet(Network network); |     boolean  removeDhcpSupportForSubnet(Network network) throws ResourceUnavailableException; | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.agent.api.routing; | package com.cloud.agent.api.routing; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.to.DnsmasqTO; | import com.cloud.agent.api.to.DhcpTO; | ||||||
| 
 | 
 | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| @ -26,11 +26,14 @@ public class DnsMasqConfigCommand extends NetworkElementCommand { | |||||||
|     String dns2; |     String dns2; | ||||||
|     String internal_dns1; |     String internal_dns1; | ||||||
|     String internal_dns2; |     String internal_dns2; | ||||||
|     List<DnsmasqTO> dnsmasqTOs; |     List<DhcpTO> dhcpTOs; | ||||||
|  |     boolean useExternal_dns; | ||||||
|  |     String domain_suffix; | ||||||
|  |     boolean dns; | ||||||
| 
 | 
 | ||||||
|     public DnsMasqConfigCommand(String domain, List<DnsmasqTO> dnsmasqTOs, String dns1, String dns2, String internal_dns1, String internal_dns2) { |     public DnsMasqConfigCommand(String domain, List<DhcpTO> dhcpTOs, String dns1, String dns2, String internal_dns1, String internal_dns2) { | ||||||
|         this.domain = domain; |         this.domain = domain; | ||||||
|         this.dnsmasqTOs = dnsmasqTOs; |         this.dhcpTOs = dhcpTOs; | ||||||
|         this.dns1= dns1; |         this.dns1= dns1; | ||||||
|         this.dns2= dns2; |         this.dns2= dns2; | ||||||
|         this.internal_dns1 = internal_dns1; |         this.internal_dns1 = internal_dns1; | ||||||
| @ -38,8 +41,8 @@ public class DnsMasqConfigCommand extends NetworkElementCommand { | |||||||
| 
 | 
 | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public List<DnsmasqTO> getIps() { |     public List<DhcpTO> getIps() { | ||||||
|         return  dnsmasqTOs; |         return dhcpTOs; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public  String getDomain() { |     public  String getDomain() { | ||||||
| @ -62,4 +65,29 @@ public class DnsMasqConfigCommand extends NetworkElementCommand { | |||||||
|         return internal_dns2; |         return internal_dns2; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public void setUseExternalDns(boolean useExternal_dns) { | ||||||
|  |         this.useExternal_dns = useExternal_dns; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setDomainSuffix(String domain_suffix) { | ||||||
|  |         this.domain_suffix = domain_suffix; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setIfDnsProvided(boolean dns) { | ||||||
|  |         this.dns =dns; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public String getDomainSuffix() { | ||||||
|  |         return this.domain_suffix; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public boolean getUseExternalDns() { | ||||||
|  |         return useExternal_dns; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public boolean isDnsProvided() { | ||||||
|  |         return dns; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -17,7 +17,7 @@ | |||||||
| package com.cloud.network; | package com.cloud.network; | ||||||
| 
 | 
 | ||||||
| import com.cloud.agent.api.routing.DnsMasqConfigCommand; | import com.cloud.agent.api.routing.DnsMasqConfigCommand; | ||||||
| import com.cloud.agent.api.to.DnsmasqTO; | import com.cloud.agent.api.to.DhcpTO; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import java.util.Arrays; | import java.util.Arrays; | ||||||
| @ -74,11 +74,10 @@ import java.util.List; | |||||||
|                                            "dhcp-option=6,router_ip,external_dns\n", |                                            "dhcp-option=6,router_ip,external_dns\n", | ||||||
|                                            "dhcp-optsfile=/etc/dhcpopts.txt\n", |                                            "dhcp-optsfile=/etc/dhcpopts.txt\n", | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
|          }; |          }; | ||||||
| 
 | 
 | ||||||
|      public String[] generateConfiguration(DnsMasqConfigCommand dnsMasqconfigcmd) { |      public String[] generateConfiguration(DnsMasqConfigCommand dnsMasqconfigcmd) { | ||||||
|          List<DnsmasqTO> dnsmasqTOs = dnsMasqconfigcmd.getIps(); |          List<DhcpTO> dhcpTOs = dnsMasqconfigcmd.getIps(); | ||||||
|          List <String> dnsMasqconf = Arrays.asList(Dnsmasq_config); |          List <String> dnsMasqconf = Arrays.asList(Dnsmasq_config); | ||||||
|          String range=""; |          String range=""; | ||||||
|          String gateway=""; |          String gateway=""; | ||||||
| @ -95,15 +94,42 @@ import java.util.List; | |||||||
|          dns_external = dns_external + "*"; |          dns_external = dns_external + "*"; | ||||||
|          dns_external = dns_external.replace(",*",""); |          dns_external = dns_external.replace(",*",""); | ||||||
|          int i=0; |          int i=0; | ||||||
|          for (; i< dnsmasqTOs.size(); i++) { |          for (; i< dhcpTOs.size(); i++) { | ||||||
|               range=range + "dhcp-range=set:range"+i+","+dnsmasqTOs.get(i).getStartIpOfSubnet()+",static\n"; |               range=range + "dhcp-range=set:range"+i+","+ dhcpTOs.get(i).getStartIpOfSubnet()+",static\n"; | ||||||
|               gateway=gateway +"dhcp-option=tag:range"+i+",3,"+dnsmasqTOs.get(i).getGateway()+"\n"; |               gateway=gateway +"dhcp-option=tag:range"+i+",3,"+ dhcpTOs.get(i).getGateway()+"\n"; | ||||||
|               netmask=netmask +"dhcp-option=tag:range"+i+",1,"+dnsmasqTOs.get(i).getNetmask()+"\n"; |               netmask=netmask +"dhcp-option=tag:range"+i+",1,"+ dhcpTOs.get(i).getNetmask()+"\n"; | ||||||
|               dnsServers=dnsServers+"dhcp-option=tag:range"+i+",6,"+dnsmasqTOs.get(i).getRouterIp()+","+dns_external+"\n"; |               if (!dnsMasqconfigcmd.isDnsProvided()) { | ||||||
|  |                   dnsServers = dnsServers+"dhcp-option=tag:range"+i+",6,"+dns_external+"\n"; | ||||||
|  |               } | ||||||
|  |               else { | ||||||
|  |                   dnsServers=dnsServers+"dhcp-option=tag:range"+i+",6,"+ dhcpTOs.get(i).getRouterIp()+","+dns_external+"\n"; | ||||||
|  |               } | ||||||
|  | 
 | ||||||
|          } |          } | ||||||
|          dnsMasqconf.set(12, "domain="+domain+"\n"); |          String domain_suffix= dnsMasqconfigcmd.getDomainSuffix(); | ||||||
|          dnsMasqconf.set(14, "domain="+domain+"\n"); | 
 | ||||||
|          dnsMasqconf.set(16,"domain="+domain+"\n"); |          if (domain != null) { | ||||||
|  |              if (domain_suffix != null) { | ||||||
|  | 
 | ||||||
|  |                  dnsMasqconf.get(5).replace(" local=/cs1cloud.internal/"," local=/"+domain+"/"); | ||||||
|  |                  dnsMasqconf.set(12, "domain="+domain_suffix+domain+"\n"); | ||||||
|  |                  dnsMasqconf.set(14, "domain="+domain_suffix+domain+"\n"); | ||||||
|  |                  dnsMasqconf.set(16,"domain="+domain_suffix+domain+"\n"); | ||||||
|  |              } else { | ||||||
|  |                  dnsMasqconf.get(5).replace(" local=/cs1cloud.internal/"," local=/"+domain+"/"); | ||||||
|  |                  dnsMasqconf.set(12, "domain="+domain+"\n"); | ||||||
|  |                  dnsMasqconf.set(14, "domain="+domain+"\n"); | ||||||
|  |                  dnsMasqconf.set(16,"domain="+domain+"\n"); | ||||||
|  |              } | ||||||
|  |          } | ||||||
|  |          ///if no domain is specified. this happens when dns service is not provided by the virtualrouter. | ||||||
|  |          else { | ||||||
|  |              dnsMasqconf.get(5).replace(" local=/cs1cloud.internal/"," local=/"+domain+"/"); | ||||||
|  |              dnsMasqconf.set(12, "domain="+"cloudnine.internal\n"); | ||||||
|  |              dnsMasqconf.set(14, "domain="+"cloudnine.internal\n"); | ||||||
|  |              dnsMasqconf.set(16,"domain="+"cloudnine.internal\n"); | ||||||
|  |          } | ||||||
|  | 
 | ||||||
|          dnsMasqconf.set(18, range); |          dnsMasqconf.set(18, range); | ||||||
|          dnsMasqconf.set(22, gateway); |          dnsMasqconf.set(22, gateway); | ||||||
|          dnsMasqconf.set(23, netmask); |          dnsMasqconf.set(23, netmask); | ||||||
|  | |||||||
| @ -387,7 +387,7 @@ public class CapacityDaoImpl extends GenericDaoBase<CapacityVO, Long> implements | |||||||
|             SummedCapacitySearch.and("clusterId", SummedCapacitySearch.entity().getClusterId(), Op.EQ); |             SummedCapacitySearch.and("clusterId", SummedCapacitySearch.entity().getClusterId(), Op.EQ); | ||||||
|         } |         } | ||||||
|         if (capacityType != null){ |         if (capacityType != null){ | ||||||
|             SummedCapacitySearch.and("capacityType", SummedCapacitySearch.entity().getCapacityType(), Op.EQ);	 |             SummedCapacitySearch.and("capacityType", SummedCapacitySearch.entity().getCapacityType(), Op.EQ); | ||||||
|         }         |         }         | ||||||
| 
 | 
 | ||||||
|         SummedCapacitySearch.done(); |         SummedCapacitySearch.done(); | ||||||
|  | |||||||
| @ -75,7 +75,9 @@ public interface IPAddressDao extends GenericDao<IPAddressVO, Long> { | |||||||
| 
 | 
 | ||||||
|     long countFreeIpsInVlan(long vlanDbId); |     long countFreeIpsInVlan(long vlanDbId); | ||||||
| 
 | 
 | ||||||
|     boolean deletePublicIPRangeExceptAliasIP(long vlanDbId, String aliasIp) throws SQLException; |     void deletePublicIPRangeExceptAliasIP(long vlanDbId, String aliasIp); | ||||||
| 
 | 
 | ||||||
|     boolean deletePublicIPRange(long vlanDbId) throws SQLException; |     boolean deletePublicIPRange(long vlanDbId) ; | ||||||
|  | 
 | ||||||
|  |     void lockRange(long vlandbId); | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| // under the License. | // under the License. | ||||||
| package com.cloud.network.dao; | package com.cloud.network.dao; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.dc.DataCenterVnetVO; | ||||||
| import com.cloud.dc.Vlan.VlanType; | import com.cloud.dc.Vlan.VlanType; | ||||||
| import com.cloud.dc.VlanVO; | import com.cloud.dc.VlanVO; | ||||||
| import com.cloud.dc.dao.VlanDao; | import com.cloud.dc.dao.VlanDao; | ||||||
| @ -54,7 +55,8 @@ public class IPAddressDaoImpl extends GenericDaoBase<IPAddressVO, Long> implemen | |||||||
|     protected SearchBuilder<IPAddressVO> VlanDbIdSearchUnallocated; |     protected SearchBuilder<IPAddressVO> VlanDbIdSearchUnallocated; | ||||||
|     protected GenericSearchBuilder<IPAddressVO, Integer> AllIpCount; |     protected GenericSearchBuilder<IPAddressVO, Integer> AllIpCount; | ||||||
|     protected GenericSearchBuilder<IPAddressVO, Integer> AllocatedIpCount; |     protected GenericSearchBuilder<IPAddressVO, Integer> AllocatedIpCount; | ||||||
|     protected GenericSearchBuilder<IPAddressVO, Integer> AllIpCountForDashboard;     |     protected GenericSearchBuilder<IPAddressVO, Integer> AllIpCountForDashboard; | ||||||
|  |     protected SearchBuilder<IPAddressVO> DeleteAllExceptGivenIp; | ||||||
|     protected GenericSearchBuilder<IPAddressVO, Long> AllocatedIpCountForAccount;     |     protected GenericSearchBuilder<IPAddressVO, Long> AllocatedIpCountForAccount;     | ||||||
|     @Inject protected VlanDao _vlanDao; |     @Inject protected VlanDao _vlanDao; | ||||||
|     protected GenericSearchBuilder<IPAddressVO, Long> CountFreePublicIps; |     protected GenericSearchBuilder<IPAddressVO, Long> CountFreePublicIps; | ||||||
| @ -128,6 +130,10 @@ public class IPAddressDaoImpl extends GenericDaoBase<IPAddressVO, Long> implemen | |||||||
|         join.and("vlanType", join.entity().getVlanType(), Op.EQ); |         join.and("vlanType", join.entity().getVlanType(), Op.EQ); | ||||||
|         CountFreePublicIps.join("vlans", join, CountFreePublicIps.entity().getVlanId(), join.entity().getId(), JoinBuilder.JoinType.INNER); |         CountFreePublicIps.join("vlans", join, CountFreePublicIps.entity().getVlanId(), join.entity().getId(), JoinBuilder.JoinType.INNER); | ||||||
|         CountFreePublicIps.done(); |         CountFreePublicIps.done(); | ||||||
|  | 
 | ||||||
|  |         DeleteAllExceptGivenIp = createSearchBuilder(); | ||||||
|  |         DeleteAllExceptGivenIp.and("vlanDbId", DeleteAllExceptGivenIp.entity().getVlanId(), Op.EQ); | ||||||
|  |         DeleteAllExceptGivenIp.and("ip", DeleteAllExceptGivenIp.entity().getAddress(), Op.NEQ); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
| @ -366,21 +372,15 @@ public class IPAddressDaoImpl extends GenericDaoBase<IPAddressVO, Long> implemen | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean deletePublicIPRangeExceptAliasIP(long vlanDbId, String aliasIp) throws SQLException { |     public void deletePublicIPRangeExceptAliasIP(long vlanDbId, String aliasIp)  { | ||||||
|         Transaction txn = Transaction.currentTxn(); |         SearchCriteria<IPAddressVO> sc =DeleteAllExceptGivenIp .create(); | ||||||
|         String deleteSql = "DELETE FROM `cloud`.`user_ip_address` WHERE vlan_db_id = ? and public_ip_address!=?"; |         sc.setParameters("vlan", vlanDbId); | ||||||
| 
 |         sc.setParameters("ip", aliasIp); | ||||||
|         txn.start(); |         remove(sc); | ||||||
|         PreparedStatement stmt = txn.prepareAutoCloseStatement(deleteSql); |  | ||||||
|         stmt.setLong(1, vlanDbId); |  | ||||||
|         stmt.setString(2, aliasIp); |  | ||||||
|         stmt.executeUpdate(); |  | ||||||
|         txn.commit(); |  | ||||||
|         return true; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean deletePublicIPRange(long vlanDbId) throws SQLException{ |     public boolean deletePublicIPRange(long vlanDbId) { | ||||||
|         SearchCriteria<IPAddressVO> sc = AllFieldsSearch.create(); |         SearchCriteria<IPAddressVO> sc = AllFieldsSearch.create(); | ||||||
|         sc.setParameters("vlan", vlanDbId); |         sc.setParameters("vlan", vlanDbId); | ||||||
|         remove(sc); |         remove(sc); | ||||||
| @ -408,4 +408,11 @@ public class IPAddressDaoImpl extends GenericDaoBase<IPAddressVO, Long> implemen | |||||||
|         sc.setParameters("associatedVmIp", vmIp); |         sc.setParameters("associatedVmIp", vmIp); | ||||||
|         return findOneBy(sc); |         return findOneBy(sc); | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     @Override | ||||||
|  |     public void lockRange(long vlandbId) { | ||||||
|  |         SearchCriteria<IPAddressVO> sc = AllFieldsSearch.create(); | ||||||
|  |         sc.setParameters("vlan", vlandbId); | ||||||
|  |         lockRows(sc,null,true); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -20,6 +20,7 @@ import com.cloud.utils.db.GenericDao; | |||||||
| import com.cloud.vm.NicVO; | import com.cloud.vm.NicVO; | ||||||
| import com.cloud.vm.VirtualMachine; | import com.cloud.vm.VirtualMachine; | ||||||
| 
 | 
 | ||||||
|  | import java.net.URI; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| public interface NicDao extends GenericDao<NicVO, Long> { | public interface NicDao extends GenericDao<NicVO, Long> { | ||||||
| @ -68,4 +69,6 @@ public interface NicDao extends GenericDao<NicVO, Long> { | |||||||
|     List<NicVO> listPlaceholderNicsByNetworkIdAndVmType(long networkId, VirtualMachine.Type vmType); |     List<NicVO> listPlaceholderNicsByNetworkIdAndVmType(long networkId, VirtualMachine.Type vmType); | ||||||
| 
 | 
 | ||||||
|     NicVO findByInstanceIdAndIpAddressAndVmtype(long instanceId, String ipaddress, VirtualMachine.Type type); |     NicVO findByInstanceIdAndIpAddressAndVmtype(long instanceId, String ipaddress, VirtualMachine.Type type); | ||||||
|  | 
 | ||||||
|  |     List<NicVO> listByNetworkIdTypeAndGatewayAndBroadcastUri(long networkId, VirtualMachine.Type vmType, String gateway, URI broadcastUri); | ||||||
| } | } | ||||||
|  | |||||||
| @ -29,6 +29,7 @@ import com.cloud.vm.VirtualMachine; | |||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| 
 | 
 | ||||||
| import javax.ejb.Local; | import javax.ejb.Local; | ||||||
|  | import java.net.URI; | ||||||
| import java.util.List; | import java.util.List; | ||||||
| 
 | 
 | ||||||
| @Component | @Component | ||||||
| @ -151,7 +152,17 @@ public class NicDaoImpl extends GenericDaoBase<NicVO, Long> implements NicDao { | |||||||
|         sc.setParameters("gateway", gateway); |         sc.setParameters("gateway", gateway); | ||||||
|         return findOneBy(sc); |         return findOneBy(sc); | ||||||
|     } |     } | ||||||
|      | 
 | ||||||
|  |     @Override | ||||||
|  |     public List<NicVO> listByNetworkIdTypeAndGatewayAndBroadcastUri(long networkId, VirtualMachine.Type vmType, String gateway, URI broadcasturi) { | ||||||
|  |         SearchCriteria<NicVO> sc = AllFieldsSearch.create(); | ||||||
|  |         sc.setParameters("network", networkId); | ||||||
|  |         sc.setParameters("vmType", vmType); | ||||||
|  |         sc.setParameters("gateway", gateway); | ||||||
|  |         sc.setParameters("broadcastUri", broadcasturi); | ||||||
|  |         return listBy(sc); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public NicVO findByIp4AddressAndNetworkId(String ip4Address, long networkId) { |     public NicVO findByIp4AddressAndNetworkId(String ip4Address, long networkId) { | ||||||
|         SearchCriteria<NicVO> sc = AllFieldsSearch.create(); |         SearchCriteria<NicVO> sc = AllFieldsSearch.create(); | ||||||
|  | |||||||
| @ -19,8 +19,16 @@ | |||||||
| usage() { | usage() { | ||||||
|   printf " %s   <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 |   printf " %s   <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 | ||||||
| } | } | ||||||
|  | source /root/func.sh | ||||||
|  | 
 | ||||||
|  | lock="biglock" | ||||||
|  | locked=$(getLockFile $lock) | ||||||
|  | if [ "$locked" != "1" ] | ||||||
|  | then | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| set -x |  | ||||||
| var="$1" | var="$1" | ||||||
| cert="/root/.ssh/id_rsa.cloud" | cert="/root/.ssh/id_rsa.cloud" | ||||||
| 
 | 
 | ||||||
| @ -35,4 +43,4 @@ do | |||||||
| done | done | ||||||
| #restaring the password service to enable it on the ip aliases | #restaring the password service to enable it on the ip aliases | ||||||
| /etc/init.d/cloud-passwd-srvr restart | /etc/init.d/cloud-passwd-srvr restart | ||||||
| exit $? | unlock_exit $? $lock $locked | ||||||
| @ -20,7 +20,15 @@ usage() { | |||||||
|   printf " %s   <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 |   printf " %s   <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| set -x | source /root/func.sh | ||||||
|  | 
 | ||||||
|  | lock="biglock" | ||||||
|  | locked=$(getLockFile $lock) | ||||||
|  | if [ "$locked" != "1" ] | ||||||
|  | then | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| var="$1" | var="$1" | ||||||
| cert="/root/.ssh/id_rsa.cloud" | cert="/root/.ssh/id_rsa.cloud" | ||||||
| 
 | 
 | ||||||
| @ -32,12 +40,8 @@ do | |||||||
|  var=$( echo $var | sed "s/${var1}-//" ) |  var=$( echo $var | sed "s/${var1}-//" ) | ||||||
| done | done | ||||||
| 
 | 
 | ||||||
| #recreating the active ip aliases | releaseLockFile $lock $locked | ||||||
| sh /root/createIpAlias.sh $2 |  | ||||||
| result=$? |  | ||||||
| if [  "$result" -ne "0" ] |  | ||||||
| then |  | ||||||
|  exit $result |  | ||||||
| fi |  | ||||||
| 
 | 
 | ||||||
| exit 0 | #recreating the active ip aliases | ||||||
|  | /root/createIpAlias.sh $2 | ||||||
|  | unlock_exit $? $lock $locked | ||||||
|  | |||||||
| @ -20,6 +20,15 @@ usage() { | |||||||
|   printf "Usage: %s:  <path to new dnsmasq config file>\n" $(basename $0) >&2 |   printf "Usage: %s:  <path to new dnsmasq config file>\n" $(basename $0) >&2 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | source /root/func.sh | ||||||
|  | 
 | ||||||
|  | lock="biglock" | ||||||
|  | locked=$(getLockFile $lock) | ||||||
|  | if [ "$locked" != "1" ] | ||||||
|  | then | ||||||
|  |     exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
| set -x | set -x | ||||||
| #backup the old config file | #backup the old config file | ||||||
| cp /etc/dnsmasq.conf /etc/dnsmasq.conf.bak | cp /etc/dnsmasq.conf /etc/dnsmasq.conf.bak | ||||||
| @ -37,7 +46,7 @@ then | |||||||
|    echo "reverting to the old config" |    echo "reverting to the old config" | ||||||
|    cp /etc/dnsmasq.config.bak /etc/dnsmasq.conf |    cp /etc/dnsmasq.config.bak /etc/dnsmasq.conf | ||||||
|    service dnsmasq restart |    service dnsmasq restart | ||||||
|    exit 2 |    unlock_exit $? $lock $locked | ||||||
| fi | fi | ||||||
| rm $1 | rm $1 | ||||||
| echo "success" | unlock_exit $? $lock $locked | ||||||
|  | |||||||
| @ -20,8 +20,6 @@ usage() { | |||||||
|   printf "Usage: %s:  <domR eth1 ip>  <path_to_new_config_file>\n" $(basename $0) >&2 |   printf "Usage: %s:  <domR eth1 ip>  <path_to_new_config_file>\n" $(basename $0) >&2 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| set -x |  | ||||||
| 
 |  | ||||||
| cert="/root/.ssh/id_rsa.cloud" | cert="/root/.ssh/id_rsa.cloud" | ||||||
| 
 | 
 | ||||||
| ssh -p 3922 -q -o StrictHostKeyChecking=no -i $cert root@$1 "/root/dnsmasq.sh $2"	  | ssh -p 3922 -q -o StrictHostKeyChecking=no -i $cert root@$1 "/root/dnsmasq.sh $2"	  | ||||||
|  | |||||||
| @ -21,6 +21,5 @@ usage() { | |||||||
|   printf " %s  routerip  <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 |   printf " %s  routerip  <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| set -x |  | ||||||
| cert="/root/.ssh/id_rsa.cloud" | cert="/root/.ssh/id_rsa.cloud" | ||||||
| ssh -p 3922 -q -o StrictHostKeyChecking=no -i $cert root@$1 "/root/createIpAlias.sh $2" | ssh -p 3922 -q -o StrictHostKeyChecking=no -i $cert root@$1 "/root/createIpAlias.sh $2" | ||||||
|  | |||||||
| @ -20,6 +20,5 @@ usage() { | |||||||
|   printf " %s  routerip  <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 |   printf " %s  routerip  <alias_count:ip:netmask;alias_count2:ip2:netmask2;....> \n" $(basename $0) >&2 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| set -x |  | ||||||
| cert="/root/.ssh/id_rsa.cloud" | cert="/root/.ssh/id_rsa.cloud" | ||||||
| ssh -p 3922 -q -o StrictHostKeyChecking=no -i $cert root@$1 "/root/deleteIpAlias.sh $2 $3" | ssh -p 3922 -q -o StrictHostKeyChecking=no -i $cert root@$1 "/root/deleteIpAlias.sh $2 $3" | ||||||
|  | |||||||
| @ -2738,9 +2738,14 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|         Transaction txn = Transaction.currentTxn(); |         Transaction txn = Transaction.currentTxn(); | ||||||
|         txn.start(); |         txn.start(); | ||||||
| 
 | 
 | ||||||
|         if (sameSubnet == null || sameSubnet.first() == false) { |         if ((sameSubnet == null || sameSubnet.first() == false) && (network.getTrafficType()== TrafficType.Guest) && (network.getGuestType() == GuestType.Shared) && (_vlanDao.listVlansByNetworkId(networkId) != null)) { | ||||||
|  |             Map<Capability, String> dhcpCapabilities = _networkSvc.getNetworkOfferingServiceCapabilities(_networkOfferingDao.findById(network.getNetworkOfferingId()), Service.Dhcp); | ||||||
|  |             String supportsMultipleSubnets = dhcpCapabilities.get(Capability.DhcpAccrossMultipleSubnets); | ||||||
|  |             if (supportsMultipleSubnets == null || !Boolean.valueOf(supportsMultipleSubnets)) { | ||||||
|  |                        throw new  InvalidParameterValueException("The Dhcp serivice provider for this network dose not support the dhcp  across multiple subnets"); | ||||||
|  |             } | ||||||
|             s_logger.info("adding a new subnet to the network " + network.getId()); |             s_logger.info("adding a new subnet to the network " + network.getId()); | ||||||
|         } else { |         } else if (sameSubnet != null)  { | ||||||
|             // if it is same subnet the user might not send the vlan and the |             // if it is same subnet the user might not send the vlan and the | ||||||
|             // netmask details. so we are |             // netmask details. so we are | ||||||
|             // figuring out while validation and setting them here. |             // figuring out while validation and setting them here. | ||||||
| @ -2757,7 +2762,7 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|         return vlan; |         return vlan; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public int checkIfSubsetOrSuperset(String newVlanGateway, String newVlanNetmask, VlanVO vlan, String startIP, |     public NetUtils.supersetOrSubset checkIfSubsetOrSuperset(String newVlanGateway, String newVlanNetmask, VlanVO vlan, String startIP, | ||||||
|             String endIP) { |             String endIP) { | ||||||
|         if (newVlanGateway == null && newVlanNetmask == null) { |         if (newVlanGateway == null && newVlanNetmask == null) { | ||||||
|             newVlanGateway = vlan.getVlanGateway(); |             newVlanGateway = vlan.getVlanGateway(); | ||||||
| @ -2765,10 +2770,10 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|             // this means he is trying to add to the existing subnet. |             // this means he is trying to add to the existing subnet. | ||||||
|             if (NetUtils.sameSubnet(startIP, newVlanGateway, newVlanNetmask)) { |             if (NetUtils.sameSubnet(startIP, newVlanGateway, newVlanNetmask)) { | ||||||
|                 if (NetUtils.sameSubnet(endIP, newVlanGateway, newVlanNetmask)) { |                 if (NetUtils.sameSubnet(endIP, newVlanGateway, newVlanNetmask)) { | ||||||
|                     return 3; |                     return NetUtils.supersetOrSubset.sameSubnet; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             return 0; |             return NetUtils.supersetOrSubset.neitherSubetNorSuperset; | ||||||
|         } else if (newVlanGateway == null || newVlanGateway == null) { |         } else if (newVlanGateway == null || newVlanGateway == null) { | ||||||
|             throw new InvalidParameterValueException( |             throw new InvalidParameterValueException( | ||||||
|                     "either both netmask and gateway should be passed or both should me omited."); |                     "either both netmask and gateway should be passed or both should me omited."); | ||||||
| @ -2798,25 +2803,30 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|                     vlanGateway = vlan.getVlanGateway(); |                     vlanGateway = vlan.getVlanGateway(); | ||||||
|                     vlanNetmask = vlan.getVlanNetmask(); |                     vlanNetmask = vlan.getVlanNetmask(); | ||||||
|                     // check if subset or super set or neither. |                     // check if subset or super set or neither. | ||||||
|                     int val = checkIfSubsetOrSuperset(newVlanGateway, newVlanNetmask, vlan, startIP, endIP); |                     NetUtils.supersetOrSubset val = checkIfSubsetOrSuperset(newVlanGateway, newVlanNetmask, vlan, startIP, endIP); | ||||||
|                     if (val == 1) { |                     if (val == NetUtils.supersetOrSubset.isSuperset) { | ||||||
|                         // this means that new cidr is a superset of the |                         // this means that new cidr is a superset of the | ||||||
|                         // existing subnet. |                         // existing subnet. | ||||||
|                         throw new InvalidParameterValueException( |                         throw new InvalidParameterValueException( | ||||||
|                                 "The subnet you are trying to add is a superset of the existing subnet having gateway" |                                 "The subnet you are trying to add is a superset of the existing subnet having gateway" | ||||||
|                                         + vlan.getVlanGateway() + " and netmask  " + vlan.getVlanNetmask()); |                                         + vlan.getVlanGateway() + " and netmask  " + vlan.getVlanNetmask()); | ||||||
|                     } else if (val == 0) { |                     } else if (val == NetUtils.supersetOrSubset.neitherSubetNorSuperset) { | ||||||
|                         // this implies the user is trying to add a new subnet |                         // this implies the user is trying to add a new subnet | ||||||
|                         // which is not a superset or subset of this subnet. |                         // which is not a superset or subset of this subnet. | ||||||
|                         // checking with the other subnets. |                         // checking with the other subnets. | ||||||
|                         continue; |                         continue; | ||||||
|                     } else if (val == 2) { |                     } else if (val == NetUtils.supersetOrSubset.isSubset) { | ||||||
|                         // this means he is trying to add to the same subnet. |                         // this means he is trying to add to the same subnet. | ||||||
|                         throw new InvalidParameterValueException( |                         throw new InvalidParameterValueException( | ||||||
|                                 "The subnet you are trying to add is a subset of the existing subnet having gateway" |                                 "The subnet you are trying to add is a subset of the existing subnet having gateway" | ||||||
|                                         + vlan.getVlanGateway() + " and netmask  " + vlan.getVlanNetmask()); |                                         + vlan.getVlanGateway() + " and netmask  " + vlan.getVlanNetmask()); | ||||||
|                     } else if (val == 3) { |                     } else if (val == NetUtils.supersetOrSubset.sameSubnet) { | ||||||
|                         sameSubnet = true; |                         sameSubnet = true; | ||||||
|  |                         //check if the gateway provided by the user is same as that of the subnet. | ||||||
|  |                         if (newVlanGateway != null && !newVlanGateway.equals(vlanGateway)) { | ||||||
|  |                              throw new InvalidParameterValueException("The gateway of the subnet should be unique. The subnet alreaddy has a gateway "+ vlanGateway); | ||||||
|  |                         } | ||||||
|  |                         break; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 if (ipv6) { |                 if (ipv6) { | ||||||
| @ -3021,7 +3031,7 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|                 if (otherVlanGateway == null) { |                 if (otherVlanGateway == null) { | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 String otherVlanSubnet = NetUtils.getSubNet(vlan.getVlanGateway(), vlan.getVlanNetmask()); |                  String otherVlanSubnet = NetUtils.getSubNet(vlan.getVlanGateway(), vlan.getVlanNetmask()); | ||||||
|                 String[] otherVlanIpRange = vlan.getIpRange().split("\\-"); |                 String[] otherVlanIpRange = vlan.getIpRange().split("\\-"); | ||||||
|                 String otherVlanStartIP = otherVlanIpRange[0]; |                 String otherVlanStartIP = otherVlanIpRange[0]; | ||||||
|                 String otherVlanEndIP = null; |                 String otherVlanEndIP = null; | ||||||
| @ -3149,15 +3159,6 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|         return vlan; |         return vlan; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @DB |  | ||||||
|     public void deleteVLANFromDb(long vlanDbId) throws SQLException { |  | ||||||
|         Transaction txn = Transaction.currentTxn(); |  | ||||||
|         txn.start(); |  | ||||||
|         _publicIpAddressDao.deletePublicIPRange(vlanDbId); |  | ||||||
|         _vlanDao.expunge(vlanDbId); |  | ||||||
|         txn.commit(); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @Override |     @Override | ||||||
|     @DB |     @DB | ||||||
|     public boolean deleteVlanAndPublicIpRange(long userId, long vlanDbId, Account caller) { |     public boolean deleteVlanAndPublicIpRange(long userId, long vlanDbId, Account caller) { | ||||||
| @ -3222,102 +3223,38 @@ public class ConfigurationManagerImpl extends ManagerBase implements Configurati | |||||||
|                         s_logger.warn("Some ip addresses failed to be released as a part of vlan " + vlanDbId |                         s_logger.warn("Some ip addresses failed to be released as a part of vlan " + vlanDbId | ||||||
|                                 + " removal"); |                                 + " removal"); | ||||||
|                     } |                     } | ||||||
|  |                     else { | ||||||
|  |                         for (IPAddressVO ip : ips) { | ||||||
|  |                             UsageEventUtils.publishUsageEvent(EventTypes.EVENT_NET_IP_RELEASE, acctVln.get(0).getId(), ip | ||||||
|  |                                     .getDataCenterId(), ip.getId(), ip.getAddress().toString(), ip.isSourceNat(), vlanRange | ||||||
|  |                                     .getVlanType().toString(), ip.getSystem(), ip.getClass().getName(), ip.getUuid()); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|                 } finally { |                 } finally { | ||||||
|                     _vlanDao.releaseFromLockTable(vlanDbId); |                     _vlanDao.releaseFromLockTable(vlanDbId); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  |             else {   // !isAccountSpecific | ||||||
|  |                 NicIpAliasVO ipAlias = _nicIpAliasDao.findByGatewayAndNetworkIdAndState(vlanRange.getVlanGateway(), vlanRange.getNetworkId(), NicIpAlias.state.active); | ||||||
|  |                 //check if the ipalias belongs to the vlan range being deleted. | ||||||
|  |                 if (ipAlias != null && vlanDbId == _publicIpAddressDao.findByIpAndSourceNetworkId(vlanRange.getNetworkId(), ipAlias.getIp4Address()).getVlanId()) { | ||||||
|  |                     throw new InvalidParameterValueException("Cannot delete vlan range "+vlanDbId+" as "+ipAlias.getIp4Address() + | ||||||
|  |                             "is being used for providing dhcp service in this subnet. Delete all VMs in this subnet and try again"); | ||||||
|  |                 } | ||||||
|  |                 allocIpCount = _publicIpAddressDao.countIPs(vlanRange.getDataCenterId(), vlanDbId, true); | ||||||
|  |                 if (allocIpCount > 0) { | ||||||
|  |                     throw new InvalidParameterValueException(allocIpCount + "  Ips are in use. Cannot delete this vlan"); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (success) { |  | ||||||
|             // Delete all public IPs in the VLAN |  | ||||||
|             // if ip range is dedicated to an account generate usage events for |  | ||||||
|             // release of every ip in the range |  | ||||||
|             if (isAccountSpecific) { |  | ||||||
|                 for (IPAddressVO ip : ips) { |  | ||||||
|                     UsageEventUtils.publishUsageEvent(EventTypes.EVENT_NET_IP_RELEASE, acctVln.get(0).getId(), ip |  | ||||||
|                             .getDataCenterId(), ip.getId(), ip.getAddress().toString(), ip.isSourceNat(), vlanRange |  | ||||||
|                             .getVlanType().toString(), ip.getSystem(), ip.getClass().getName(), ip.getUuid()); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             try { |  | ||||||
|                 if (_networkModel.areServicesSupportedInNetwork(vlanRange.getNetworkId(), Service.Dhcp)) { |  | ||||||
|                     Network network = _networkDao.findById(vlanRange.getNetworkId()); |  | ||||||
|                     DhcpServiceProvider dhcpServiceProvider = _networkMgr.getDhcpServiceProvider(network); |  | ||||||
|                     if (!dhcpServiceProvider.getProvider().getName().equalsIgnoreCase(Provider.VirtualRouter.getName())) { |  | ||||||
|                         deleteVLANFromDb(vlanDbId); |  | ||||||
|                     } else { |  | ||||||
|                         return  handleIpAliasDeletion(vlanRange, vlanDbId, dhcpServiceProvider, network); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
| 
 | 
 | ||||||
|                 else { |  | ||||||
|                     deleteVLANFromDb(vlanDbId); |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             catch ( SQLException e) { |  | ||||||
|                throw  new CloudRuntimeException(e.getMessage()); |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     @DB |  | ||||||
|     private boolean handleIpAliasDeletion(VlanVO vlanRange, long vlanDbId, DhcpServiceProvider dhcpServiceProvider, Network network) throws SQLException { |  | ||||||
|         Transaction txn = Transaction.currentTxn(); |         Transaction txn = Transaction.currentTxn(); | ||||||
|         txn.start(); |         txn.start(); | ||||||
|         IPAddressVO ip = null; |         _publicIpAddressDao.deletePublicIPRange(vlanDbId); | ||||||
|         NicIpAliasVO ipAlias = null; |         _vlanDao.expunge(vlanDbId); | ||||||
|         try{ |  | ||||||
|             Integer allocIpCount=0; |  | ||||||
|             //search if the vlan has any allocated ips. |  | ||||||
|             allocIpCount = _publicIpAddressDao.countIPs(vlanRange.getDataCenterId(), vlanDbId, true); |  | ||||||
|             if (allocIpCount > 1) { |  | ||||||
|                 throw  new InvalidParameterValueException ("Cannot delete this range as some of the vlans are in use."); |  | ||||||
|             } |  | ||||||
|             else if (allocIpCount == 0){ |  | ||||||
|                 deleteVLANFromDb(vlanDbId); |  | ||||||
|             } |  | ||||||
|             else { |  | ||||||
|                 ipAlias = _nicIpAliasDao.findByGatewayAndNetworkIdAndState(vlanRange.getVlanGateway(), vlanRange.getNetworkId(),  NicIpAlias.state.active); |  | ||||||
|                 if (ipAlias == null) { |  | ||||||
|                     throw  new InvalidParameterValueException ("Cannot delete this range as some of the Ips are in use."); |  | ||||||
|                 } |  | ||||||
| 
 |  | ||||||
|                 //check if this ip belongs to this vlan and is allocated. |  | ||||||
|                 ip = _publicIpAddressDao.findByIpAndVlanId(ipAlias.getIp4Address(), vlanDbId); |  | ||||||
|                 if (ip != null && ip.getState() == IpAddress.State.Allocated) { |  | ||||||
|                     //check if there any other vlan ranges in the same subnet having free ips |  | ||||||
|                     List<VlanVO> vlanRanges = _vlanDao.listVlansByNetworkIdAndGateway(vlanRange.getNetworkId(), vlanRange.getVlanGateway()); |  | ||||||
|                     //if there is no other vlanrage in this subnet. free the ip and delete the vlan. |  | ||||||
|                     if (vlanRanges.size() == 1) { |  | ||||||
|                         ipAlias.setState(NicIpAlias.state.revoked); |  | ||||||
|                         _nicIpAliasDao.update(ipAlias.getId(), ipAlias); |  | ||||||
|                         if (!dhcpServiceProvider.removeDhcpSupportForSubnet(network)) { |  | ||||||
|                             s_logger.debug("Failed to delete the vlan range as we could not free the ip used to provide the dhcp service."); |  | ||||||
|                             //setting the state back to active |  | ||||||
|                             ipAlias.setState(NicIpAlias.state.active); |  | ||||||
|                             _nicIpAliasDao.update(ipAlias.getId(), ipAlias); |  | ||||||
|                         } |  | ||||||
|                         else { |  | ||||||
|                             _publicIpAddressDao.unassignIpAddress(ip.getId()); |  | ||||||
|                             deleteVLANFromDb(vlanDbId); |  | ||||||
|                         } |  | ||||||
|                     } else { |  | ||||||
|                         // if there are more vlans in the subnet, free all the ips in the range except the ip alias. |  | ||||||
|                         s_logger.info("vlan Range"+vlanRange.getId()+" id being deleted, one of the Ips in this range is used to provide the dhcp service, will free the rest of the IPs in range."); |  | ||||||
|                         _publicIpAddressDao.deletePublicIPRangeExceptAliasIP(vlanDbId, ipAlias.getIp4Address()); |  | ||||||
|                         VlanVO vlan = _vlanDao.findById(vlanDbId); |  | ||||||
|                         vlan.setIpRange(ipAlias.getIp4Address()+"-"+ipAlias.getIp4Address()); |  | ||||||
|                         _vlanDao.update(vlan.getId(), vlan); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } catch (CloudRuntimeException e) { |  | ||||||
|             txn.rollback(); |  | ||||||
|             throw e; |  | ||||||
|         } |  | ||||||
|         txn.commit(); |         txn.commit(); | ||||||
|  | 
 | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -2002,9 +2002,11 @@ public class NetworkManagerImpl extends ManagerBase implements NetworkManager, L | |||||||
|         if (vmProfile.getType() == Type.User && element.getProvider() != null) { |         if (vmProfile.getType() == Type.User && element.getProvider() != null) { | ||||||
|             if (_networkModel.areServicesSupportedInNetwork(network.getId(), Service.Dhcp) && |             if (_networkModel.areServicesSupportedInNetwork(network.getId(), Service.Dhcp) && | ||||||
|                     _networkModel.isProviderSupportServiceInNetwork(network.getId(), Service.Dhcp, element.getProvider()) && |                     _networkModel.isProviderSupportServiceInNetwork(network.getId(), Service.Dhcp, element.getProvider()) && | ||||||
|                     element instanceof DhcpServiceProvider) { |                     element instanceof DhcpServiceProvider ) { | ||||||
|                 DhcpServiceProvider sp = (DhcpServiceProvider) element; |                 DhcpServiceProvider sp = (DhcpServiceProvider) element; | ||||||
|                 if (profile.getIp6Address() == null) { |                 Map <Capability, String> dhcpCapabilities = element.getCapabilities().get(Service.Dhcp); | ||||||
|  |                 String supportsMultipleSubnets = dhcpCapabilities.get(Capability.DhcpAccrossMultipleSubnets); | ||||||
|  |                 if ((supportsMultipleSubnets != null || Boolean.valueOf(supportsMultipleSubnets)) && profile.getIp6Address() == null) { | ||||||
|                     if (!sp.configDhcpSupportForSubnet(network, profile, vmProfile, dest, context)) { |                     if (!sp.configDhcpSupportForSubnet(network, profile, vmProfile, dest, context)) { | ||||||
|                         return false; |                         return false; | ||||||
|                     } |                     } | ||||||
|  | |||||||
| @ -1822,11 +1822,8 @@ public class NetworkServiceImpl extends ManagerBase implements  NetworkService { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| 
 |     @Override | ||||||
| 
 |     public Map<Capability, String> getNetworkOfferingServiceCapabilities(NetworkOffering offering, Service service) { | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     protected Map<Capability, String> getNetworkOfferingServiceCapabilities(NetworkOffering offering, Service service) { |  | ||||||
| 
 | 
 | ||||||
|         if (!areServicesSupportedByNetworkOffering(offering.getId(), service)) { |         if (!areServicesSupportedByNetworkOffering(offering.getId(), service)) { | ||||||
|             // TBD: We should be sending networkOfferingId and not the offering object itself. |             // TBD: We should be sending networkOfferingId and not the offering object itself. | ||||||
| @ -2676,8 +2673,6 @@ public class NetworkServiceImpl extends ManagerBase implements  NetworkService { | |||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|             if (newVnetRangeString != null) { |             if (newVnetRangeString != null) { | ||||||
|                for (Pair<Integer,Integer> vnetRange : existingRanges ){ |                for (Pair<Integer,Integer> vnetRange : existingRanges ){ | ||||||
|                     value=vnetMap.get(vnetRange.first()); |                     value=vnetMap.get(vnetRange.first()); | ||||||
|  | |||||||
| @ -614,7 +614,10 @@ public class VirtualRouterElement extends AdapterBase implements VirtualRouterEl | |||||||
|         capabilities.put(Service.Dns, dnsCapabilities); |         capabilities.put(Service.Dns, dnsCapabilities); | ||||||
| 
 | 
 | ||||||
|         capabilities.put(Service.UserData, null); |         capabilities.put(Service.UserData, null); | ||||||
|         capabilities.put(Service.Dhcp, null); | 
 | ||||||
|  |         Map<Capability, String> dhcpCapabilities = new HashMap<Capability, String>(); | ||||||
|  |         dhcpCapabilities.put(Capability.DhcpAccrossMultipleSubnets, "true"); | ||||||
|  |         capabilities.put(Service.Dhcp, dhcpCapabilities); | ||||||
| 
 | 
 | ||||||
|         capabilities.put(Service.Gateway, null); |         capabilities.put(Service.Gateway, null); | ||||||
| 
 | 
 | ||||||
| @ -873,24 +876,18 @@ public class VirtualRouterElement extends AdapterBase implements VirtualRouterEl | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean removeDhcpSupportForSubnet(Network network) { |     public boolean removeDhcpSupportForSubnet(Network network) throws ResourceUnavailableException{ | ||||||
|         if (canHandle(network, Service.Dhcp)) { |         if (canHandle(network, Service.Dhcp)) { | ||||||
|             List<DomainRouterVO> routers = _routerDao.listByNetworkAndRole(network.getId(), Role.VIRTUAL_ROUTER); |             List<DomainRouterVO> routers = _routerDao.listByNetworkAndRole(network.getId(), Role.VIRTUAL_ROUTER); | ||||||
|            try { |             if ((routers == null) || (routers.size() == 0)) { | ||||||
|                if ((routers == null) || (routers.size() == 0)) { |  | ||||||
|                    throw new ResourceUnavailableException("Can't find at least one router!", DataCenter.class, network.getDataCenterId()); |                    throw new ResourceUnavailableException("Can't find at least one router!", DataCenter.class, network.getDataCenterId()); | ||||||
|                } |             } | ||||||
|            } |  | ||||||
|            catch (ResourceUnavailableException e) { |  | ||||||
|                s_logger.debug("could not find any router on this network"); |  | ||||||
|            } |  | ||||||
|            try { |            try { | ||||||
|                 return _routerMgr.removeDhcpSupportForSubnet(network, routers); |                 return _routerMgr.removeDhcpSupportForSubnet(network, routers); | ||||||
|            } |            } | ||||||
|            catch (ResourceUnavailableException e) { |            catch (ResourceUnavailableException e) { | ||||||
|                 s_logger.debug("Router resource unavailable "); |                 s_logger.debug("Router resource unavailable "); | ||||||
|            } |            } | ||||||
| 
 |  | ||||||
|         } |         } | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -85,7 +85,7 @@ import com.cloud.agent.api.routing.SetPortForwardingRulesVpcCommand; | |||||||
| import com.cloud.agent.api.routing.SetStaticNatRulesCommand; | import com.cloud.agent.api.routing.SetStaticNatRulesCommand; | ||||||
| import com.cloud.agent.api.routing.VmDataCommand; | import com.cloud.agent.api.routing.VmDataCommand; | ||||||
| import com.cloud.agent.api.routing.VpnUsersCfgCommand; | import com.cloud.agent.api.routing.VpnUsersCfgCommand; | ||||||
| import com.cloud.agent.api.to.DnsmasqTO; | import com.cloud.agent.api.to.DhcpTO; | ||||||
| import com.cloud.agent.api.to.FirewallRuleTO; | import com.cloud.agent.api.to.FirewallRuleTO; | ||||||
| import com.cloud.agent.api.to.IpAddressTO; | import com.cloud.agent.api.to.IpAddressTO; | ||||||
| import com.cloud.agent.api.to.LoadBalancerTO; | import com.cloud.agent.api.to.LoadBalancerTO; | ||||||
| @ -141,6 +141,7 @@ import com.cloud.network.Network.Provider; | |||||||
| import com.cloud.network.Network.Service; | import com.cloud.network.Network.Service; | ||||||
| import com.cloud.network.NetworkManager; | import com.cloud.network.NetworkManager; | ||||||
| import com.cloud.network.NetworkModel; | import com.cloud.network.NetworkModel; | ||||||
|  | import com.cloud.network.NetworkService; | ||||||
| import com.cloud.network.Networks.BroadcastDomainType; | import com.cloud.network.Networks.BroadcastDomainType; | ||||||
| import com.cloud.network.Networks.IsolationType; | import com.cloud.network.Networks.IsolationType; | ||||||
| import com.cloud.network.Networks.TrafficType; | import com.cloud.network.Networks.TrafficType; | ||||||
| @ -356,6 +357,8 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|     Site2SiteVpnManager _s2sVpnMgr; |     Site2SiteVpnManager _s2sVpnMgr; | ||||||
|     @Inject |     @Inject | ||||||
|     UserIpv6AddressDao _ipv6Dao; |     UserIpv6AddressDao _ipv6Dao; | ||||||
|  |     @Inject | ||||||
|  |     NetworkService _networkSvc; | ||||||
| 
 | 
 | ||||||
|      |      | ||||||
|     int _routerRamSize; |     int _routerRamSize; | ||||||
| @ -2497,23 +2500,31 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|         } |         } | ||||||
|         //Reapply dhcp and dns configuration. |         //Reapply dhcp and dns configuration. | ||||||
|         if (_networkModel.isProviderSupportServiceInNetwork(guestNetworkId, Service.Dhcp, provider)) { |         if (_networkModel.isProviderSupportServiceInNetwork(guestNetworkId, Service.Dhcp, provider)) { | ||||||
|             List<NicIpAliasVO> revokedIpAliasVOs = _nicIpAliasDao.listByNetworkIdAndState(guestNetworkId, NicIpAlias.state.revoked); |             Map<Network.Capability, String> dhcpCapabilities = _networkSvc.getNetworkOfferingServiceCapabilities(_networkOfferingDao.findById(_networkDao.findById(guestNetworkId).getNetworkOfferingId()), Service.Dhcp); | ||||||
|             s_logger.debug("Found" + revokedIpAliasVOs.size() + "ip Aliases to revoke on the router as a part of dhcp configuration"); |             String supportsMultipleSubnets = dhcpCapabilities.get(Network.Capability.DhcpAccrossMultipleSubnets); | ||||||
|             List<IpAliasTO> revokedIpAliasTOs = new ArrayList<IpAliasTO>(); |             if (supportsMultipleSubnets == null || !Boolean.valueOf(supportsMultipleSubnets)) { | ||||||
|             for (NicIpAliasVO revokedAliasVO : revokedIpAliasVOs) { |                 List<NicIpAliasVO> revokedIpAliasVOs = _nicIpAliasDao.listByNetworkIdAndState(guestNetworkId, NicIpAlias.state.revoked); | ||||||
|                 revokedIpAliasTOs.add(new IpAliasTO(revokedAliasVO.getIp4Address(), revokedAliasVO.getNetmask(), revokedAliasVO.getAliasCount().toString())); |                 s_logger.debug("Found" + revokedIpAliasVOs.size() + "ip Aliases to revoke on the router as a part of dhcp configuration"); | ||||||
|             } |                 removeRevokedIpAliasFromDb(revokedIpAliasVOs); | ||||||
|             List<NicIpAliasVO> aliasVOs = _nicIpAliasDao.listByNetworkIdAndState(guestNetworkId, NicIpAlias.state.active); |  | ||||||
|             s_logger.debug("Found" + aliasVOs.size() + "ip Aliases to apply on the router as a part of dhcp configuration"); |  | ||||||
|             List<IpAliasTO> activeIpAliasTOs = new ArrayList<IpAliasTO>(); |  | ||||||
|             for (NicIpAliasVO aliasVO : aliasVOs) { |  | ||||||
|                    activeIpAliasTOs.add(new IpAliasTO(aliasVO.getIp4Address(), aliasVO.getNetmask(), aliasVO.getAliasCount().toString())); |  | ||||||
|             } |  | ||||||
|             if (revokedIpAliasTOs.size() != 0 || activeIpAliasTOs.size() != 0){ |  | ||||||
|                 createDeleteIpAliasCommand(router, revokedIpAliasTOs, activeIpAliasTOs, guestNetworkId, cmds); |  | ||||||
|                 configDnsMasq(router, _networkDao.findById(guestNetworkId), cmds); |  | ||||||
|             } |  | ||||||
| 
 | 
 | ||||||
|  |                 List<NicIpAliasVO> aliasVOs = _nicIpAliasDao.listByNetworkIdAndState(guestNetworkId, NicIpAlias.state.active); | ||||||
|  |                 s_logger.debug("Found" + aliasVOs.size() + "ip Aliases to apply on the router as a part of dhcp configuration"); | ||||||
|  |                 List<IpAliasTO> activeIpAliasTOs = new ArrayList<IpAliasTO>(); | ||||||
|  |                 for (NicIpAliasVO aliasVO : aliasVOs) { | ||||||
|  |                     activeIpAliasTOs.add(new IpAliasTO(aliasVO.getIp4Address(), aliasVO.getNetmask(), aliasVO.getAliasCount().toString())); | ||||||
|  |                 } | ||||||
|  |                 if (activeIpAliasTOs.size() != 0){ | ||||||
|  |                     createIpAlias(router, activeIpAliasTOs, guestNetworkId, cmds); | ||||||
|  |                     configDnsMasq(router, _networkDao.findById(guestNetworkId), cmds); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     private void removeRevokedIpAliasFromDb(List<NicIpAliasVO> revokedIpAliasVOs) { | ||||||
|  |         for (NicIpAliasVO ipalias : revokedIpAliasVOs) { | ||||||
|  |             _nicIpAliasDao.expunge(ipalias.getId()); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -2790,9 +2801,6 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|                     router.getState(), DataCenter.class, network.getDataCenterId()); |                     router.getState(), DataCenter.class, network.getDataCenterId()); | ||||||
|         } |         } | ||||||
|         //check if this is not the primary subnet. |         //check if this is not the primary subnet. | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|         //check if the the ip Alias is configured on the virtualrouter. |  | ||||||
|         UserVm vm = updatedProfile.getVirtualMachine(); |         UserVm vm = updatedProfile.getVirtualMachine(); | ||||||
|         NicVO domr_guest_nic = _nicDao.findByInstanceIdAndIpAddressAndVmtype(router.getId(), _nicDao.getIpAddress(nic.getNetworkId(), router.getId()), VirtualMachine.Type.DomainRouter); |         NicVO domr_guest_nic = _nicDao.findByInstanceIdAndIpAddressAndVmtype(router.getId(), _nicDao.getIpAddress(nic.getNetworkId(), router.getId()), VirtualMachine.Type.DomainRouter); | ||||||
|         //check if the router ip address and the vm ip address belong to same subnet. |         //check if the router ip address and the vm ip address belong to same subnet. | ||||||
| @ -2849,8 +2857,11 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|                 boolean result = sendCommandsToRouter(router, cmds); |                 boolean result = sendCommandsToRouter(router, cmds); | ||||||
|                 if (result == false) { |                 if (result == false) { | ||||||
|                     NicIpAliasVO ipAliasVO = _nicIpAliasDao.findByInstanceIdAndNetworkId(network.getId(), router.getId()); |                     NicIpAliasVO ipAliasVO = _nicIpAliasDao.findByInstanceIdAndNetworkId(network.getId(), router.getId()); | ||||||
|  |                     Transaction txn = Transaction.currentTxn(); | ||||||
|  |                     txn.start(); | ||||||
|                     _nicIpAliasDao.expunge(ipAliasVO.getId()); |                     _nicIpAliasDao.expunge(ipAliasVO.getId()); | ||||||
|                     _ipAddressDao.unassignIpAddress(routerPublicIP.getId()); |                     _ipAddressDao.unassignIpAddress(routerPublicIP.getId()); | ||||||
|  |                     txn.commit(); | ||||||
|                     throw new CloudRuntimeException("failed to configure ip alias on the router as a part of dhcp config"); |                     throw new CloudRuntimeException("failed to configure ip alias on the router as a part of dhcp config"); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -2891,10 +2902,13 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|             configDnsMasq(router, network, cmds); |             configDnsMasq(router, network, cmds); | ||||||
|             boolean result = sendCommandsToRouter(router, cmds); |             boolean result = sendCommandsToRouter(router, cmds); | ||||||
|             if (result) { |             if (result) { | ||||||
|  |                 Transaction txn= Transaction.currentTxn(); | ||||||
|  |                 txn.start(); | ||||||
|                 for (NicIpAliasVO revokedAliasVO : revokedIpAliasVOs) { |                 for (NicIpAliasVO revokedAliasVO : revokedIpAliasVOs) { | ||||||
|                     _nicIpAliasDao.expunge(revokedAliasVO.getId()); |                     _nicIpAliasDao.expunge(revokedAliasVO.getId()); | ||||||
|                     return true; |  | ||||||
|                 } |                 } | ||||||
|  |                 txn.commit(); | ||||||
|  |                 return true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return  false; |         return  false; | ||||||
| @ -3461,7 +3475,7 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|         } |         } | ||||||
|         DataCenterVO dcVo = _dcDao.findById(router.getDataCenterId()); |         DataCenterVO dcVo = _dcDao.findById(router.getDataCenterId()); | ||||||
|         List<NicIpAliasVO> ipAliasVOList = _nicIpAliasDao.listByNetworkIdAndState(network.getId(), NicIpAlias.state.active); |         List<NicIpAliasVO> ipAliasVOList = _nicIpAliasDao.listByNetworkIdAndState(network.getId(), NicIpAlias.state.active); | ||||||
|         List<DnsmasqTO> ipList = new ArrayList<DnsmasqTO>(); |         List<DhcpTO> ipList = new ArrayList<DhcpTO>(); | ||||||
| 
 | 
 | ||||||
|         NicVO router_guest_nic = _nicDao.findByNtwkIdAndInstanceId(network.getId(), router.getId()); |         NicVO router_guest_nic = _nicDao.findByNtwkIdAndInstanceId(network.getId(), router.getId()); | ||||||
|         String cidr = NetUtils.getCidrFromGatewayAndNetmask(router_guest_nic.getGateway(), router_guest_nic.getNetmask()); |         String cidr = NetUtils.getCidrFromGatewayAndNetmask(router_guest_nic.getGateway(), router_guest_nic.getNetmask()); | ||||||
| @ -3470,22 +3484,25 @@ public class VirtualNetworkApplianceManagerImpl extends ManagerBase implements V | |||||||
|         long cidrSize = Long.parseLong(cidrPair[1]); |         long cidrSize = Long.parseLong(cidrPair[1]); | ||||||
|         String startIpOfSubnet = NetUtils.getIpRangeStartIpFromCidr(cidrAddress, cidrSize); |         String startIpOfSubnet = NetUtils.getIpRangeStartIpFromCidr(cidrAddress, cidrSize); | ||||||
| 
 | 
 | ||||||
|         ipList.add(new DnsmasqTO(router_guest_nic.getIp4Address(),router_guest_nic.getGateway(),router_guest_nic.getNetmask(), startIpOfSubnet)); |         ipList.add(new DhcpTO(router_guest_nic.getIp4Address(),router_guest_nic.getGateway(),router_guest_nic.getNetmask(), startIpOfSubnet)); | ||||||
|         for (NicIpAliasVO ipAliasVO : ipAliasVOList) { |         for (NicIpAliasVO ipAliasVO : ipAliasVOList) { | ||||||
|              DnsmasqTO dnsmasqTO = new DnsmasqTO(ipAliasVO.getIp4Address(), ipAliasVO.getGateway(), ipAliasVO.getNetmask(), ipAliasVO.getStartIpOfSubnet()); |              DhcpTO DhcpTO = new DhcpTO(ipAliasVO.getIp4Address(), ipAliasVO.getGateway(), ipAliasVO.getNetmask(), ipAliasVO.getStartIpOfSubnet()); | ||||||
|              if (s_logger.isTraceEnabled()) { |              if (s_logger.isTraceEnabled()) { | ||||||
|                  s_logger.trace("configDnsMasq : adding ip {" + dnsmasqTO.getGateway() + ", " + dnsmasqTO.getNetmask() + ", " + dnsmasqTO.getRouterIp() + ", " + dnsmasqTO.getStartIpOfSubnet() + "}"); |                  s_logger.trace("configDnsMasq : adding ip {" + DhcpTO.getGateway() + ", " + DhcpTO.getNetmask() + ", " + DhcpTO.getRouterIp() + ", " + DhcpTO.getStartIpOfSubnet() + "}"); | ||||||
|              } |              } | ||||||
|              ipList.add(dnsmasqTO); |              ipList.add(DhcpTO); | ||||||
|              ipAliasVO.setVmId(router.getId()); |              ipAliasVO.setVmId(router.getId()); | ||||||
|         } |         } | ||||||
|         DataCenterVO dcvo = _dcDao.findById(router.getDataCenterId()); |         DataCenterVO dcvo = _dcDao.findById(router.getDataCenterId()); | ||||||
|  |         boolean dnsProvided = _networkModel.isProviderSupportServiceInNetwork(network.getId(), Service.Dns, Provider.VirtualRouter); | ||||||
|  |         String domain_suffix = dcvo.getDetail(ZoneConfig.DnsSearchOrder.getName()); | ||||||
|         DnsMasqConfigCommand dnsMasqConfigCmd = new DnsMasqConfigCommand(network.getNetworkDomain(),ipList, dcvo.getDns1(), dcvo.getDns2(), dcvo.getInternalDns1(), dcvo.getInternalDns2()); |         DnsMasqConfigCommand dnsMasqConfigCmd = new DnsMasqConfigCommand(network.getNetworkDomain(),ipList, dcvo.getDns1(), dcvo.getDns2(), dcvo.getInternalDns1(), dcvo.getInternalDns2()); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, getRouterControlIp(router.getId())); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, getRouterControlIp(router.getId())); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_GUEST_IP, getRouterIpInNetwork(network.getId(), router.getId())); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_GUEST_IP, getRouterIpInNetwork(network.getId(), router.getId())); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ZONE_NETWORK_TYPE, dcVo.getNetworkType().toString()); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ZONE_NETWORK_TYPE, dcVo.getNetworkType().toString()); | ||||||
| 
 |         dnsMasqConfigCmd.setDomainSuffix(domain_suffix); | ||||||
|  |         dnsMasqConfigCmd.setIfDnsProvided(dnsProvided); | ||||||
|         cmds.addCommand("dnsMasqConfig" ,dnsMasqConfigCmd); |         cmds.addCommand("dnsMasqConfig" ,dnsMasqConfigCmd); | ||||||
|         //To change body of created methods use File | Settings | File Templates. |         //To change body of created methods use File | Settings | File Templates. | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -27,6 +27,7 @@ import java.util.TreeSet; | |||||||
| import javax.ejb.Local; | import javax.ejb.Local; | ||||||
| import javax.inject.Inject; | import javax.inject.Inject; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.configuration.ZoneConfig; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| import org.springframework.stereotype.Component; | import org.springframework.stereotype.Component; | ||||||
| 
 | 
 | ||||||
| @ -44,7 +45,7 @@ import com.cloud.agent.api.routing.SetNetworkACLCommand; | |||||||
| import com.cloud.agent.api.routing.SetSourceNatCommand; | import com.cloud.agent.api.routing.SetSourceNatCommand; | ||||||
| import com.cloud.agent.api.routing.SetStaticRouteCommand; | import com.cloud.agent.api.routing.SetStaticRouteCommand; | ||||||
| import com.cloud.agent.api.routing.Site2SiteVpnCfgCommand; | import com.cloud.agent.api.routing.Site2SiteVpnCfgCommand; | ||||||
| import com.cloud.agent.api.to.DnsmasqTO; | import com.cloud.agent.api.to.DhcpTO; | ||||||
| import com.cloud.agent.api.to.IpAddressTO; | import com.cloud.agent.api.to.IpAddressTO; | ||||||
| import com.cloud.agent.api.to.NetworkACLTO; | import com.cloud.agent.api.to.NetworkACLTO; | ||||||
| import com.cloud.agent.api.to.NicTO; | import com.cloud.agent.api.to.NicTO; | ||||||
| @ -885,24 +886,29 @@ public class VpcVirtualNetworkApplianceManagerImpl extends VirtualNetworkApplian | |||||||
|         } |         } | ||||||
|         VpcVO vpc = _vpcDao.findById(router.getVpcId()); |         VpcVO vpc = _vpcDao.findById(router.getVpcId()); | ||||||
|         DataCenterVO dcVo = _dcDao.findById(router.getDataCenterId()); |         DataCenterVO dcVo = _dcDao.findById(router.getDataCenterId()); | ||||||
|         List<DnsmasqTO> ipList = new ArrayList<DnsmasqTO>(); |         List<DhcpTO> ipList = new ArrayList<DhcpTO>(); | ||||||
| 
 | 
 | ||||||
|         String cidr = vpc.getCidr(); |         String cidr = vpc.getCidr(); | ||||||
|         String[] cidrPair = cidr.split("\\/"); |         String[] cidrPair = cidr.split("\\/"); | ||||||
|         String cidrAddress = cidrPair[0]; |         String cidrAddress = cidrPair[0]; | ||||||
|         long cidrSize = Long.parseLong(cidrPair[1]); |         long cidrSize = Long.parseLong(cidrPair[1]); | ||||||
|         String startIpOfSubnet = NetUtils.getIpRangeStartIpFromCidr(cidrAddress, cidrSize); |         String startIpOfSubnet = NetUtils.getIpRangeStartIpFromCidr(cidrAddress, cidrSize); | ||||||
|         DnsmasqTO dnsmasqTO = new DnsmasqTO(router.getPrivateIpAddress(), router.getPublicIpAddress(), NetUtils.getCidrNetmask(cidrSize), startIpOfSubnet); |         DhcpTO DhcpTO = new DhcpTO(router.getPrivateIpAddress(), router.getPublicIpAddress(), NetUtils.getCidrNetmask(cidrSize), startIpOfSubnet); | ||||||
|         ipList.add(dnsmasqTO); |         ipList.add(DhcpTO); | ||||||
| 
 | 
 | ||||||
|  |         NicVO nic = _nicDao.findByIp4AddressAndVmId(_routerDao.findById(router.getId()).getPrivateIpAddress(), router.getId()); | ||||||
|  |         DataCenterVO dcvo = _dcDao.findById(router.getDataCenterId()); | ||||||
|  |         boolean dnsProvided = _networkModel.isProviderSupportServiceInNetwork(nic.getNetworkId(), Service.Dns, Provider.VirtualRouter); | ||||||
|  |         String domain_suffix = dcvo.getDetail(ZoneConfig.DnsSearchOrder.getName()); | ||||||
|         DnsMasqConfigCommand dnsMasqConfigCmd = new DnsMasqConfigCommand(vpc.getNetworkDomain(),ipList, dcVo.getDns1(), dcVo.getDns2(), dcVo.getInternalDns1(), dcVo.getInternalDns2()); |         DnsMasqConfigCommand dnsMasqConfigCmd = new DnsMasqConfigCommand(vpc.getNetworkDomain(),ipList, dcVo.getDns1(), dcVo.getDns2(), dcVo.getInternalDns1(), dcVo.getInternalDns2()); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, getRouterControlIp(router.getId())); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, getRouterControlIp(router.getId())); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_GUEST_IP, router.getPublicIpAddress()); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ROUTER_GUEST_IP, router.getPublicIpAddress()); | ||||||
|         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ZONE_NETWORK_TYPE, dcVo.getNetworkType().toString()); |         dnsMasqConfigCmd.setAccessDetail(NetworkElementCommand.ZONE_NETWORK_TYPE, dcVo.getNetworkType().toString()); | ||||||
|  |         dnsMasqConfigCmd.setDomainSuffix(domain_suffix); | ||||||
|  |         dnsMasqConfigCmd.setIfDnsProvided(dnsProvided); | ||||||
| 
 | 
 | ||||||
|         cmds.addCommand("dnsMasqConfig" ,dnsMasqConfigCmd); |         cmds.addCommand("dnsMasqConfig" ,dnsMasqConfigCmd); | ||||||
|         //To change body of created methods use File | Settings | File Templates. |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -36,6 +36,13 @@ import javax.ejb.Local; | |||||||
| import javax.inject.Inject; | import javax.inject.Inject; | ||||||
| import javax.naming.ConfigurationException; | import javax.naming.ConfigurationException; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.dc.dao.VlanDao; | ||||||
|  | import com.cloud.network.Networks; | ||||||
|  | import com.cloud.network.dao.IPAddressDao; | ||||||
|  | import com.cloud.network.dao.IPAddressVO; | ||||||
|  | import com.cloud.network.element.DhcpServiceProvider; | ||||||
|  | import com.cloud.vm.dao.NicIpAliasDao; | ||||||
|  | import com.cloud.vm.dao.NicIpAliasVO; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| 
 | 
 | ||||||
| import org.apache.cloudstack.affinity.dao.AffinityGroupVMMapDao; | import org.apache.cloudstack.affinity.dao.AffinityGroupVMMapDao; | ||||||
| @ -267,6 +274,12 @@ public class VirtualMachineManagerImpl extends ManagerBase implements VirtualMac | |||||||
|     protected ConfigurationServer _configServer; |     protected ConfigurationServer _configServer; | ||||||
|     @Inject |     @Inject | ||||||
|     protected ManagementServer _mgmtServer; |     protected ManagementServer _mgmtServer; | ||||||
|  |     @Inject | ||||||
|  |     protected IPAddressDao _publicIpAddressDao; | ||||||
|  |     @Inject | ||||||
|  |     protected VlanDao _vlanDao; | ||||||
|  |     @Inject | ||||||
|  |     protected NicIpAliasDao _nicIpAliasDao; | ||||||
| 
 | 
 | ||||||
|     protected List<DeploymentPlanner> _planners; |     protected List<DeploymentPlanner> _planners; | ||||||
|     public List<DeploymentPlanner> getPlanners() { |     public List<DeploymentPlanner> getPlanners() { | ||||||
| @ -460,6 +473,10 @@ public class VirtualMachineManagerImpl extends ManagerBase implements VirtualMac | |||||||
|             s_logger.debug("Destroying vm " + vm); |             s_logger.debug("Destroying vm " + vm); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         if (vm.getType() == VirtualMachine.Type.User) { | ||||||
|  |               removeDhcpServiceInsubnet(vm); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         VirtualMachineProfile<T> profile = new VirtualMachineProfileImpl<T>(vm); |         VirtualMachineProfile<T> profile = new VirtualMachineProfileImpl<T>(vm); | ||||||
| 
 | 
 | ||||||
|         HypervisorGuru hvGuru = _hvGuruMgr.getGuru(vm.getHypervisorType()); |         HypervisorGuru hvGuru = _hvGuruMgr.getGuru(vm.getHypervisorType()); | ||||||
| @ -517,6 +534,41 @@ public class VirtualMachineManagerImpl extends ManagerBase implements VirtualMac | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @DB | ||||||
|  |     private void removeDhcpServiceInsubnet(VirtualMachine vm) { | ||||||
|  |         //list all the nics which belong to this vm and are the last nics  in the subnets. | ||||||
|  |         //we are using the info in these nics to remove the dhcp sercvice for these subnets. | ||||||
|  |         List<NicVO> nicList = listLastNicsInSubnet(vm); | ||||||
|  | 
 | ||||||
|  |         if(nicList != null && nicList.size() != 0) { | ||||||
|  |             for (NicVO nic : nicList) { | ||||||
|  |                 //free the ipalias on the routers corresponding to each of the nics. | ||||||
|  |                 Network network = _networkDao.findById(nic.getNetworkId()); | ||||||
|  |                 DhcpServiceProvider dhcpServiceProvider = _networkMgr.getDhcpServiceProvider(network); | ||||||
|  |                 try { | ||||||
|  |                     NicIpAliasVO ipAlias = _nicIpAliasDao.findByGatewayAndNetworkIdAndState(nic.getGateway(), network.getId(), NicIpAlias.state.active); | ||||||
|  |                     if (ipAlias != null) { | ||||||
|  |                         ipAlias.setState(NicIpAlias.state.revoked); | ||||||
|  |                         Transaction txn = Transaction.currentTxn(); | ||||||
|  |                         txn.start(); | ||||||
|  |                         _nicIpAliasDao.update(ipAlias.getId(),ipAlias); | ||||||
|  |                         IPAddressVO aliasIpaddressVo = _publicIpAddressDao.findByIpAndSourceNetworkId(ipAlias.getNetworkId(), ipAlias.getIp4Address()); | ||||||
|  |                         _publicIpAddressDao.unassignIpAddress(aliasIpaddressVo.getId()); | ||||||
|  |                         txn.commit(); | ||||||
|  |                         if (!dhcpServiceProvider.removeDhcpSupportForSubnet(network)) { | ||||||
|  |                             s_logger.warn("Failed to remove the ip alias on the router, marking it as removed in db and freed the allocated ip " + ipAlias.getIp4Address()); | ||||||
|  |                         } | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |                 catch (ResourceUnavailableException e) { | ||||||
|  |                     //failed to remove the dhcpconfig on the router. | ||||||
|  |                     s_logger.info ("Unable to delete the ip alias due to unable to contact the virtualrouter."); | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean start() { |     public boolean start() { | ||||||
|         _executor.scheduleAtFixedRate(new CleanupTask(), _cleanupInterval, _cleanupInterval, TimeUnit.SECONDS); |         _executor.scheduleAtFixedRate(new CleanupTask(), _cleanupInterval, _cleanupInterval, TimeUnit.SECONDS); | ||||||
| @ -1337,6 +1389,28 @@ public class VirtualMachineManagerImpl extends ManagerBase implements VirtualMac | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     //list all the nics which belong to this vm and are the last nics  in the subnets. | ||||||
|  |     //we are using the info in these nics to remove the dhcp sercvice for these subnets. | ||||||
|  |     private  List<NicVO> listLastNicsInSubnet(VirtualMachine vm) { | ||||||
|  |         List<NicVO>  nicList  = _nicsDao.listByVmId(vm.getId()); | ||||||
|  |         List<NicVO>  copyOfnicList = new ArrayList<NicVO>(nicList); | ||||||
|  |         for (NicVO nic : nicList) { | ||||||
|  |             Network network = _networkDao.findById(nic.getNetworkId()); | ||||||
|  |             DhcpServiceProvider dhcpServiceProvider = _networkMgr.getDhcpServiceProvider(network); | ||||||
|  |             Map <Network.Capability, String> capabilities = dhcpServiceProvider.getCapabilities().get(Network.Service.Dhcp); | ||||||
|  |             String supportsMultipleSubnets = capabilities.get(Network.Capability.DhcpAccrossMultipleSubnets); | ||||||
|  |             if ((supportsMultipleSubnets != null && Boolean.valueOf(supportsMultipleSubnets) && network.getTrafficType() == Networks.TrafficType.Guest && network.getGuestType() == Network.GuestType.Shared)) { | ||||||
|  |                 //including the ip of the vm and the ipAlias | ||||||
|  |                 if (_nicsDao.listByNetworkIdTypeAndGatewayAndBroadcastUri(nic.getNetworkId(), VirtualMachine.Type.User, nic.getGateway(), nic.getBroadcastUri()).size() > 1) { | ||||||
|  |                     copyOfnicList.remove(nic); | ||||||
|  |                 } | ||||||
|  |             } else { | ||||||
|  |                 copyOfnicList.remove(nic); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         return copyOfnicList; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     protected boolean checkVmOnHost(VirtualMachine vm, long hostId) throws AgentUnavailableException, OperationTimedoutException { |     protected boolean checkVmOnHost(VirtualMachine vm, long hostId) throws AgentUnavailableException, OperationTimedoutException { | ||||||
|         CheckVirtualMachineAnswer answer = (CheckVirtualMachineAnswer) _agentMgr.send(hostId, new CheckVirtualMachineCommand(vm.getInstanceName())); |         CheckVirtualMachineAnswer answer = (CheckVirtualMachineAnswer) _agentMgr.send(hostId, new CheckVirtualMachineCommand(vm.getInstanceName())); | ||||||
|         if (!answer.getResult() || answer.getState() == State.Stopped) { |         if (!answer.getResult() || answer.getState() == State.Stopped) { | ||||||
|  | |||||||
| @ -907,6 +907,11 @@ public class MockNetworkManagerImpl extends ManagerBase implements NetworkManage | |||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public Map<Network.Capability, String> getNetworkOfferingServiceCapabilities(NetworkOffering offering, Service service) { | ||||||
|  |         return null;  //To change body of implemented methods use File | Settings | File Templates. | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public String allocatePublicIpForGuestNic(Long networkId, DataCenter dc, |     public String allocatePublicIpForGuestNic(Long networkId, DataCenter dc, | ||||||
|             Pod pod, Account caller, String requestedIp) |             Pod pod, Account caller, String requestedIp) | ||||||
|  | |||||||
| @ -18,11 +18,21 @@ | |||||||
| package com.cloud.network.router; | package com.cloud.network.router; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | import static org.mockito.Matchers.any; | ||||||
|  | import static org.mockito.Matchers.anyLong; | ||||||
|  | import static org.mockito.Matchers.anyString; | ||||||
| import static org.mockito.Mockito.mock; | import static org.mockito.Mockito.mock; | ||||||
|  | import static org.mockito.Mockito.mockingDetails; | ||||||
| import static org.mockito.Mockito.when; | import static org.mockito.Mockito.when; | ||||||
| 
 | 
 | ||||||
| import java.util.ArrayList; | import java.util.ArrayList; | ||||||
|  | import java.util.HashMap; | ||||||
|  | import java.util.Map; | ||||||
| 
 | 
 | ||||||
|  | import com.cloud.configuration.ZoneConfig; | ||||||
|  | import com.cloud.network.Network; | ||||||
|  | import com.cloud.network.NetworkModel; | ||||||
|  | import com.cloud.vm.VirtualMachine; | ||||||
| import org.apache.log4j.Logger; | import org.apache.log4j.Logger; | ||||||
| import org.junit.Assert; | import org.junit.Assert; | ||||||
| import org.junit.Before; | import org.junit.Before; | ||||||
| @ -58,7 +68,10 @@ public class VpcVirtualNetworkApplianceManagerImplTest { | |||||||
|     @Mock VpcDao _vpcDao; |     @Mock VpcDao _vpcDao; | ||||||
|     @Mock VirtualRouter router; |     @Mock VirtualRouter router; | ||||||
|     @Mock NicDao _nicDao; |     @Mock NicDao _nicDao; | ||||||
|     @Mock DomainRouterDao _routerDao;  |     @Mock DomainRouterDao _routerDao; | ||||||
|  |     @Mock NetworkModel _networkmodel; | ||||||
|  |     @Mock NicVO nicVO; | ||||||
|  |     @Mock DataCenterVO dcVO; | ||||||
| 
 | 
 | ||||||
|     @Before |     @Before | ||||||
|     public void setup() { |     public void setup() { | ||||||
| @ -79,20 +92,28 @@ public class VpcVirtualNetworkApplianceManagerImplTest { | |||||||
|         VpcVO vpc = new VpcVO(1L,"bla","bla",1L,1L,1L,"10.0.0.0/8","blieb.net"); |         VpcVO vpc = new VpcVO(1L,"bla","bla",1L,1L,1L,"10.0.0.0/8","blieb.net"); | ||||||
|         when( _vpcDao.findById(1L)).thenReturn(vpc); |         when( _vpcDao.findById(1L)).thenReturn(vpc); | ||||||
|         DataCenterVO dcVo = new DataCenterVO(1L,"dc","dc","8.8.8.8",null,null,null,"10.0.0.0/8","bla.net",new Long(1L),NetworkType.Advanced,null,".net"); |         DataCenterVO dcVo = new DataCenterVO(1L,"dc","dc","8.8.8.8",null,null,null,"10.0.0.0/8","bla.net",new Long(1L),NetworkType.Advanced,null,".net"); | ||||||
|         when( _dcDao.findById(1L) ).thenReturn(dcVo); |         Map<String, String> map = new HashMap<String, String>(); | ||||||
|  |         dcVo.setDetails(map); | ||||||
|  |         dcVo.setDetail(ZoneConfig.DnsSearchOrder.getName(), "dummy"); | ||||||
|  |         when(_dcDao.findById(1L)).thenReturn(dcVo); | ||||||
|         DomainRouterVO routerVo = new DomainRouterVO(1L,1L,1L,"brr",1L,HypervisorType.Any,1L,1L,1L,false,0,false,RedundantState.MASTER,false,false,1L); |         DomainRouterVO routerVo = new DomainRouterVO(1L,1L,1L,"brr",1L,HypervisorType.Any,1L,1L,1L,false,0,false,RedundantState.MASTER,false,false,1L); | ||||||
|         when( _routerDao.findById(1L)).thenReturn(routerVo); |         when( _routerDao.findById(1L)).thenReturn(routerVo); | ||||||
| //        when( vpcVirtNetAppMgr.getRouterControlIp(1L)).thenReturn("10.0.0.1"); | //        when( vpcVirtNetAppMgr.getRouterControlIp(1L)).thenReturn("10.0.0.1"); | ||||||
|         when( router.getInstanceName()).thenReturn("r-vm-1"); |         when( router.getInstanceName()).thenReturn("r-vm-1"); | ||||||
|         when( router.getPublicIpAddress()).thenReturn("11.11.11.11"); |         when( router.getPublicIpAddress()).thenReturn("11.11.11.11"); | ||||||
|         when( _nicDao.listByVmId(1L)).thenReturn(new ArrayList<NicVO>()); |         NicVO nicvo = new NicVO("server", 1l, 1l, VirtualMachine.Type.DomainRouter); | ||||||
|  |         nicvo.setNetworkId(1l); | ||||||
|  |         when(_nicDao.findByIp4AddressAndVmId(anyString(), anyLong())).thenReturn(nicvo); | ||||||
|         NetworkManager netMgr = mock(NetworkManager.class); |         NetworkManager netMgr = mock(NetworkManager.class); | ||||||
|         vpcVirtNetAppMgr._networkMgr = netMgr; |         vpcVirtNetAppMgr._networkMgr = netMgr; | ||||||
| 
 |         vpcVirtNetAppMgr._networkModel = _networkmodel; | ||||||
|  |         when(nicVO.getNetworkId()).thenReturn(1l); | ||||||
|  |         when(_networkmodel.isProviderSupportServiceInNetwork(1l, Network.Service.Dhcp, Network.Provider.VirtualRouter)).thenReturn(true); | ||||||
|  |         when(dcVO.getDetail(anyString())).thenReturn(null); | ||||||
|         Commands cmds = new Commands(OnError.Stop); |         Commands cmds = new Commands(OnError.Stop); | ||||||
| 
 | 
 | ||||||
|         vpcVirtNetAppMgr.configDnsMasq(router, cmds); |         vpcVirtNetAppMgr.configDnsMasq(router, cmds); | ||||||
|         Assert.assertEquals("expected one command",1,cmds.size()); |         Assert.assertEquals("expected one command",1, cmds.size()); | ||||||
|          |          | ||||||
|         DnsMasqConfigCommand cmd = cmds.getCommand(DnsMasqConfigCommand.class); |         DnsMasqConfigCommand cmd = cmds.getCommand(DnsMasqConfigCommand.class); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1382,6 +1382,11 @@ public class MockNetworkManagerImpl extends ManagerBase implements NetworkManage | |||||||
|         return null; |         return null; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public Map<Network.Capability, String> getNetworkOfferingServiceCapabilities(NetworkOffering offering, Service service) { | ||||||
|  |         return null;  //To change body of implemented methods use File | Settings | File Templates. | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public String allocatePublicIpForGuestNic(Long networkId, DataCenter dc, |     public String allocatePublicIpForGuestNic(Long networkId, DataCenter dc, | ||||||
|  | |||||||
| @ -25,7 +25,7 @@ region.id=1 | |||||||
| # CloudStack database settings | # CloudStack database settings | ||||||
| db.cloud.username=cloud | db.cloud.username=cloud | ||||||
| db.cloud.password=cloud | db.cloud.password=cloud | ||||||
| db.root.password= | db.root.password=root | ||||||
| db.cloud.host=localhost | db.cloud.host=localhost | ||||||
| db.cloud.port=3306 | db.cloud.port=3306 | ||||||
| db.cloud.name=cloud | db.cloud.name=cloud | ||||||
|  | |||||||
| @ -797,13 +797,20 @@ public class NetUtils { | |||||||
|         return new Pair<String, Integer>(tokens[0], Integer.parseInt(tokens[1])); |         return new Pair<String, Integer>(tokens[0], Integer.parseInt(tokens[1])); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static int isNetowrkASubsetOrSupersetOfNetworkB (String cidrA, String cidrB) { |     public  static enum supersetOrSubset { | ||||||
|  |         isSuperset, | ||||||
|  |         isSubset, | ||||||
|  |         neitherSubetNorSuperset, | ||||||
|  |         sameSubnet, | ||||||
|  |         errorInCidrFormat | ||||||
|  |     } | ||||||
|  |     public static supersetOrSubset isNetowrkASubsetOrSupersetOfNetworkB (String cidrA, String cidrB) { | ||||||
|         Long[] cidrALong = cidrToLong(cidrA); |         Long[] cidrALong = cidrToLong(cidrA); | ||||||
|         Long[] cidrBLong = cidrToLong(cidrB); |         Long[] cidrBLong = cidrToLong(cidrB); | ||||||
|         long shift =0; |         long shift =0; | ||||||
|         if (cidrALong == null || cidrBLong == null) { |         if (cidrALong == null || cidrBLong == null) { | ||||||
|             //implies error in the cidr format |             //implies error in the cidr format | ||||||
|             return -1; |             return supersetOrSubset.errorInCidrFormat; | ||||||
|         } |         } | ||||||
|         if (cidrALong[1] >= cidrBLong[1]) { |         if (cidrALong[1] >= cidrBLong[1]) { | ||||||
|             shift = 32 - cidrBLong[1]; |             shift = 32 - cidrBLong[1]; | ||||||
| @ -815,17 +822,17 @@ public class NetUtils { | |||||||
|         if (result == 0) { |         if (result == 0) { | ||||||
|             if (cidrALong[1] < cidrBLong[1]) { |             if (cidrALong[1] < cidrBLong[1]) { | ||||||
|                 //this implies cidrA is super set of cidrB |                 //this implies cidrA is super set of cidrB | ||||||
|                 return 1; |                 return supersetOrSubset.isSuperset; | ||||||
|             } |             } | ||||||
|             else if (cidrALong[1] == cidrBLong[1]) { |             else if (cidrALong[1] == cidrBLong[1]) { | ||||||
|              //this implies both the cidrs are equal |              //this implies both the cidrs are equal | ||||||
|                 return 3; |                 return supersetOrSubset.sameSubnet; | ||||||
|             } |             } | ||||||
|             // implies cidrA is subset of cidrB |             // implies cidrA is subset of cidrB | ||||||
|             return 2; |             return supersetOrSubset.isSubset; | ||||||
|         } |         } | ||||||
|         //this implies no overlap. |         //this implies no overlap. | ||||||
|         return 0; |         return supersetOrSubset.neitherSubetNorSuperset; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public static boolean isNetworkAWithinNetworkB(String cidrA, String cidrB) { |     public static boolean isNetworkAWithinNetworkB(String cidrA, String cidrB) { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user