mirror of
				https://github.com/apache/cloudstack.git
				synced 2025-10-26 08:42:29 +01:00 
			
		
		
		
	[CORE] Add Force UDP Encapsulation option to Site2Site VPN
This commit is contained in:
		
							parent
							
								
									3ee53d3f53
								
							
						
					
					
						commit
						6da3bc1237
					
				| @ -39,6 +39,8 @@ public interface Site2SiteCustomerGateway extends ControlledEntity, Identity, In | |||||||
| 
 | 
 | ||||||
|     public Boolean getDpd(); |     public Boolean getDpd(); | ||||||
| 
 | 
 | ||||||
|  |     public Boolean getEncap(); | ||||||
|  | 
 | ||||||
|     public Date getRemoved(); |     public Date getRemoved(); | ||||||
| 
 | 
 | ||||||
|     String getName(); |     String getName(); | ||||||
|  | |||||||
| @ -492,6 +492,7 @@ public class ApiConstants { | |||||||
|     public static final String IKE_LIFETIME = "ikelifetime"; |     public static final String IKE_LIFETIME = "ikelifetime"; | ||||||
|     public static final String ESP_LIFETIME = "esplifetime"; |     public static final String ESP_LIFETIME = "esplifetime"; | ||||||
|     public static final String DPD = "dpd"; |     public static final String DPD = "dpd"; | ||||||
|  |     public static final String FORCE_ENCAP = "forceencap"; | ||||||
|     public static final String FOR_VPC = "forvpc"; |     public static final String FOR_VPC = "forvpc"; | ||||||
|     public static final String SHRINK_OK = "shrinkok"; |     public static final String SHRINK_OK = "shrinkok"; | ||||||
|     public static final String NICIRA_NVP_DEVICE_ID = "nvpdeviceid"; |     public static final String NICIRA_NVP_DEVICE_ID = "nvpdeviceid"; | ||||||
|  | |||||||
| @ -75,6 +75,9 @@ public class CreateVpnCustomerGatewayCmd extends BaseAsyncCmd { | |||||||
|     @Parameter(name = ApiConstants.DPD, type = CommandType.BOOLEAN, required = false, description = "If DPD is enabled for VPN connection") |     @Parameter(name = ApiConstants.DPD, type = CommandType.BOOLEAN, required = false, description = "If DPD is enabled for VPN connection") | ||||||
|     private Boolean dpd; |     private Boolean dpd; | ||||||
| 
 | 
 | ||||||
|  |     @Parameter(name = ApiConstants.FORCE_ENCAP, type = CommandType.BOOLEAN, required = false, description = "Force Encapsulation for NAT traversal") | ||||||
|  |     private Boolean encap; | ||||||
|  | 
 | ||||||
|     @Parameter(name = ApiConstants.ACCOUNT, type = CommandType.STRING, description = "the account associated with the gateway. Must be used with the domainId parameter.") |     @Parameter(name = ApiConstants.ACCOUNT, type = CommandType.STRING, description = "the account associated with the gateway. Must be used with the domainId parameter.") | ||||||
|     private String accountName; |     private String accountName; | ||||||
| 
 | 
 | ||||||
| @ -129,6 +132,8 @@ public class CreateVpnCustomerGatewayCmd extends BaseAsyncCmd { | |||||||
|         return dpd; |         return dpd; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public Boolean getEncap() { return encap; } | ||||||
|  | 
 | ||||||
|     public String getAccountName() { |     public String getAccountName() { | ||||||
|         return accountName; |         return accountName; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -81,6 +81,9 @@ public class UpdateVpnCustomerGatewayCmd extends BaseAsyncCmd { | |||||||
|     @Parameter(name = ApiConstants.DPD, type = CommandType.BOOLEAN, required = false, description = "If DPD is enabled for VPN connection") |     @Parameter(name = ApiConstants.DPD, type = CommandType.BOOLEAN, required = false, description = "If DPD is enabled for VPN connection") | ||||||
|     private Boolean dpd; |     private Boolean dpd; | ||||||
| 
 | 
 | ||||||
|  |     @Parameter(name = ApiConstants.FORCE_ENCAP, type = CommandType.BOOLEAN, required = false, description = "Force encapsulation for Nat Traversal") | ||||||
|  |     private Boolean encap; | ||||||
|  | 
 | ||||||
|     @Parameter(name = ApiConstants.ACCOUNT, type = CommandType.STRING, description = "the account associated with the gateway. Must be used with the domainId parameter.") |     @Parameter(name = ApiConstants.ACCOUNT, type = CommandType.STRING, description = "the account associated with the gateway. Must be used with the domainId parameter.") | ||||||
|     private String accountName; |     private String accountName; | ||||||
| 
 | 
 | ||||||
| @ -135,6 +138,8 @@ public class UpdateVpnCustomerGatewayCmd extends BaseAsyncCmd { | |||||||
|         return dpd; |         return dpd; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public Boolean getEncap() { return encap; } | ||||||
|  | 
 | ||||||
|     ///////////////////////////////////////////////////// |     ///////////////////////////////////////////////////// | ||||||
|     /////////////// API Implementation/////////////////// |     /////////////// API Implementation/////////////////// | ||||||
|     ///////////////////////////////////////////////////// |     ///////////////////////////////////////////////////// | ||||||
|  | |||||||
| @ -74,6 +74,10 @@ public class Site2SiteCustomerGatewayResponse extends BaseResponse implements Co | |||||||
|     @Param(description = "if DPD is enabled for customer gateway") |     @Param(description = "if DPD is enabled for customer gateway") | ||||||
|     private Boolean dpd; |     private Boolean dpd; | ||||||
| 
 | 
 | ||||||
|  |     @SerializedName(ApiConstants.FORCE_ENCAP) | ||||||
|  |     @Param(description = "if Force NAT Encapsulation is enabled for customer gateway") | ||||||
|  |     private Boolean encap; | ||||||
|  | 
 | ||||||
|     @SerializedName(ApiConstants.ACCOUNT) |     @SerializedName(ApiConstants.ACCOUNT) | ||||||
|     @Param(description = "the owner") |     @Param(description = "the owner") | ||||||
|     private String accountName; |     private String accountName; | ||||||
| @ -142,6 +146,8 @@ public class Site2SiteCustomerGatewayResponse extends BaseResponse implements Co | |||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public void setEncap(Boolean encap) { this.encap = encap; } | ||||||
|  | 
 | ||||||
|     public void setRemoved(Date removed) { |     public void setRemoved(Date removed) { | ||||||
|         this.removed = removed; |         this.removed = removed; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -87,6 +87,11 @@ public class Site2SiteVpnConnectionResponse extends BaseResponse implements Cont | |||||||
|     //from CustomerGateway |     //from CustomerGateway | ||||||
|     private Boolean dpd; |     private Boolean dpd; | ||||||
| 
 | 
 | ||||||
|  |     @SerializedName(ApiConstants.FORCE_ENCAP) | ||||||
|  |     @Param(description = "if Force NAT Encapsulation is enabled for customer gateway") | ||||||
|  |     //from CustomerGateway | ||||||
|  |     private Boolean encap; | ||||||
|  | 
 | ||||||
|     @SerializedName(ApiConstants.STATE) |     @SerializedName(ApiConstants.STATE) | ||||||
|     @Param(description = "State of vpn connection") |     @Param(description = "State of vpn connection") | ||||||
|     private String state; |     private String state; | ||||||
| @ -175,6 +180,10 @@ public class Site2SiteVpnConnectionResponse extends BaseResponse implements Cont | |||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public void setEncap(Boolean encap) { | ||||||
|  |         this.encap = encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public void setState(String state) { |     public void setState(String state) { | ||||||
|         this.state = state; |         this.state = state; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -34,6 +34,7 @@ public class Site2SiteVpnCfgCommand extends NetworkElementCommand { | |||||||
|     private long espLifetime; |     private long espLifetime; | ||||||
|     private boolean dpd; |     private boolean dpd; | ||||||
|     private boolean passive; |     private boolean passive; | ||||||
|  |     private boolean encap; | ||||||
| 
 | 
 | ||||||
|     @Override |     @Override | ||||||
|     public boolean executeInSequence() { |     public boolean executeInSequence() { | ||||||
| @ -45,7 +46,7 @@ public class Site2SiteVpnCfgCommand extends NetworkElementCommand { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public Site2SiteVpnCfgCommand(boolean create, String localPublicIp, String localPublicGateway, String localGuestCidr, String peerGatewayIp, String peerGuestCidrList, |     public Site2SiteVpnCfgCommand(boolean create, String localPublicIp, String localPublicGateway, String localGuestCidr, String peerGatewayIp, String peerGuestCidrList, | ||||||
|             String ikePolicy, String espPolicy, String ipsecPsk, Long ikeLifetime, Long espLifetime, Boolean dpd, boolean passive) { |             String ikePolicy, String espPolicy, String ipsecPsk, Long ikeLifetime, Long espLifetime, Boolean dpd, boolean passive, boolean encap) { | ||||||
|         this.create = create; |         this.create = create; | ||||||
|         this.setLocalPublicIp(localPublicIp); |         this.setLocalPublicIp(localPublicIp); | ||||||
|         this.setLocalPublicGateway(localPublicGateway); |         this.setLocalPublicGateway(localPublicGateway); | ||||||
| @ -59,6 +60,7 @@ public class Site2SiteVpnCfgCommand extends NetworkElementCommand { | |||||||
|         this.espLifetime = espLifetime; |         this.espLifetime = espLifetime; | ||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|         this.passive = passive; |         this.passive = passive; | ||||||
|  |         this.encap = encap; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public boolean isCreate() { |     public boolean isCreate() { | ||||||
| @ -117,6 +119,14 @@ public class Site2SiteVpnCfgCommand extends NetworkElementCommand { | |||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public Boolean getEncap() { | ||||||
|  |         return encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setEncap(Boolean encap) { | ||||||
|  |         this.encap = encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     public String getLocalPublicIp() { |     public String getLocalPublicIp() { | ||||||
|         return localPublicIp; |         return localPublicIp; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -36,7 +36,7 @@ public class Site2SiteVpnConfigItem extends AbstractConfigItemFacade { | |||||||
| 
 | 
 | ||||||
|         final Site2SiteVpn site2siteVpn = new Site2SiteVpn(command.getLocalPublicIp(), command.getLocalGuestCidr(), command.getLocalPublicGateway(), command.getPeerGatewayIp(), |         final Site2SiteVpn site2siteVpn = new Site2SiteVpn(command.getLocalPublicIp(), command.getLocalGuestCidr(), command.getLocalPublicGateway(), command.getPeerGatewayIp(), | ||||||
|                 command.getPeerGuestCidrList(), command.getEspPolicy(), command.getIkePolicy(), command.getIpsecPsk(), command.getIkeLifetime(), command.getEspLifetime(), command.isCreate(), command.getDpd(), |                 command.getPeerGuestCidrList(), command.getEspPolicy(), command.getIkePolicy(), command.getIpsecPsk(), command.getIkeLifetime(), command.getEspLifetime(), command.isCreate(), command.getDpd(), | ||||||
|                 command.isPassive()); |                 command.isPassive(), command.getEncap()); | ||||||
|         return generateConfigItems(site2siteVpn); |         return generateConfigItems(site2siteVpn); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -23,7 +23,7 @@ public class Site2SiteVpn extends ConfigBase { | |||||||
| 
 | 
 | ||||||
|     private String localPublicIp, localGuestCidr, localPublicGateway, peerGatewayIp, peerGuestCidrList, espPolicy, ikePolicy, ipsecPsk; |     private String localPublicIp, localGuestCidr, localPublicGateway, peerGatewayIp, peerGuestCidrList, espPolicy, ikePolicy, ipsecPsk; | ||||||
|     private Long ikeLifetime, espLifetime; |     private Long ikeLifetime, espLifetime; | ||||||
|     private boolean create, dpd, passive; |     private boolean create, dpd, passive, encap; | ||||||
| 
 | 
 | ||||||
|     public Site2SiteVpn() { |     public Site2SiteVpn() { | ||||||
|         super(ConfigBase.SITE2SITEVPN); |         super(ConfigBase.SITE2SITEVPN); | ||||||
| @ -31,7 +31,7 @@ public class Site2SiteVpn extends ConfigBase { | |||||||
| 
 | 
 | ||||||
|     public Site2SiteVpn(String localPublicIp, String localGuestCidr, String localPublicGateway, String peerGatewayIp, String peerGuestCidrList, String espPolicy, |     public Site2SiteVpn(String localPublicIp, String localGuestCidr, String localPublicGateway, String peerGatewayIp, String peerGuestCidrList, String espPolicy, | ||||||
|  String ikePolicy, |  String ikePolicy, | ||||||
|             String ipsecPsk, Long ikeLifetime, Long espLifetime, boolean create, Boolean dpd, boolean passive) { |             String ipsecPsk, Long ikeLifetime, Long espLifetime, boolean create, Boolean dpd, boolean passive, boolean encap) { | ||||||
|         super(ConfigBase.SITE2SITEVPN); |         super(ConfigBase.SITE2SITEVPN); | ||||||
|         this.localPublicIp = localPublicIp; |         this.localPublicIp = localPublicIp; | ||||||
|         this.localGuestCidr = localGuestCidr; |         this.localGuestCidr = localGuestCidr; | ||||||
| @ -46,6 +46,7 @@ public class Site2SiteVpn extends ConfigBase { | |||||||
|         this.create = create; |         this.create = create; | ||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|         this.passive = passive; |         this.passive = passive; | ||||||
|  |         this.encap = encap; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public String getLocalPublicIp() { |     public String getLocalPublicIp() { | ||||||
| @ -152,4 +153,12 @@ public class Site2SiteVpn extends ConfigBase { | |||||||
|         this.passive = passive; |         this.passive = passive; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public boolean getEncap() { | ||||||
|  |         return encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setEncap(boolean encap) { | ||||||
|  |         this.encap = encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -70,6 +70,9 @@ public class Site2SiteCustomerGatewayVO implements Site2SiteCustomerGateway { | |||||||
|     @Column(name = "dpd") |     @Column(name = "dpd") | ||||||
|     private boolean dpd; |     private boolean dpd; | ||||||
| 
 | 
 | ||||||
|  |     @Column(name = "force_encap") | ||||||
|  |     private boolean encap; | ||||||
|  | 
 | ||||||
|     @Column(name = "domain_id") |     @Column(name = "domain_id") | ||||||
|     private Long domainId; |     private Long domainId; | ||||||
| 
 | 
 | ||||||
| @ -83,7 +86,7 @@ public class Site2SiteCustomerGatewayVO implements Site2SiteCustomerGateway { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     public Site2SiteCustomerGatewayVO(String name, long accountId, long domainId, String gatewayIp, String guestCidrList, String ipsecPsk, String ikePolicy, |     public Site2SiteCustomerGatewayVO(String name, long accountId, long domainId, String gatewayIp, String guestCidrList, String ipsecPsk, String ikePolicy, | ||||||
|             String espPolicy, long ikeLifetime, long espLifetime, boolean dpd) { |             String espPolicy, long ikeLifetime, long espLifetime, boolean dpd, boolean encap) { | ||||||
|         this.name = name; |         this.name = name; | ||||||
|         this.gatewayIp = gatewayIp; |         this.gatewayIp = gatewayIp; | ||||||
|         this.guestCidrList = guestCidrList; |         this.guestCidrList = guestCidrList; | ||||||
| @ -93,6 +96,7 @@ public class Site2SiteCustomerGatewayVO implements Site2SiteCustomerGateway { | |||||||
|         this.ikeLifetime = ikeLifetime; |         this.ikeLifetime = ikeLifetime; | ||||||
|         this.espLifetime = espLifetime; |         this.espLifetime = espLifetime; | ||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|  |         this.encap = encap; | ||||||
|         uuid = UUID.randomUUID().toString(); |         uuid = UUID.randomUUID().toString(); | ||||||
|         this.accountId = accountId; |         this.accountId = accountId; | ||||||
|         this.domainId = domainId; |         this.domainId = domainId; | ||||||
| @ -193,6 +197,15 @@ public class Site2SiteCustomerGatewayVO implements Site2SiteCustomerGateway { | |||||||
|         this.dpd = dpd; |         this.dpd = dpd; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     @Override | ||||||
|  |     public Boolean getEncap() { | ||||||
|  |         return encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     public void setEncap(boolean encap) { | ||||||
|  |         this.encap = encap; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     @Override |     @Override | ||||||
|     public String getUuid() { |     public String getUuid() { | ||||||
|         return uuid; |         return uuid; | ||||||
|  | |||||||
| @ -3001,7 +3001,7 @@ public class ApiResponseHelper implements ResponseGenerator { | |||||||
|         response.setIkeLifetime(result.getIkeLifetime()); |         response.setIkeLifetime(result.getIkeLifetime()); | ||||||
|         response.setEspLifetime(result.getEspLifetime()); |         response.setEspLifetime(result.getEspLifetime()); | ||||||
|         response.setDpd(result.getDpd()); |         response.setDpd(result.getDpd()); | ||||||
| 
 |         response.setEncap(result.getEncap()); | ||||||
|         response.setRemoved(result.getRemoved()); |         response.setRemoved(result.getRemoved()); | ||||||
|         response.setObjectName("vpncustomergateway"); |         response.setObjectName("vpncustomergateway"); | ||||||
| 
 | 
 | ||||||
| @ -3041,6 +3041,7 @@ public class ApiResponseHelper implements ResponseGenerator { | |||||||
|                 response.setIkeLifetime(customerGateway.getIkeLifetime()); |                 response.setIkeLifetime(customerGateway.getIkeLifetime()); | ||||||
|                 response.setEspLifetime(customerGateway.getEspLifetime()); |                 response.setEspLifetime(customerGateway.getEspLifetime()); | ||||||
|                 response.setDpd(customerGateway.getDpd()); |                 response.setDpd(customerGateway.getDpd()); | ||||||
|  |                 response.setEncap(customerGateway.getEncap()); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -857,9 +857,10 @@ public class CommandSetupHelper { | |||||||
|         final Long ikeLifetime = gw.getIkeLifetime(); |         final Long ikeLifetime = gw.getIkeLifetime(); | ||||||
|         final Long espLifetime = gw.getEspLifetime(); |         final Long espLifetime = gw.getEspLifetime(); | ||||||
|         final Boolean dpd = gw.getDpd(); |         final Boolean dpd = gw.getDpd(); | ||||||
|  |         final Boolean encap = gw.getEncap(); | ||||||
| 
 | 
 | ||||||
|         final Site2SiteVpnCfgCommand cmd = new Site2SiteVpnCfgCommand(isCreate, localPublicIp, localPublicGateway, localGuestCidr, peerGatewayIp, peerGuestCidrList, ikePolicy, |         final Site2SiteVpnCfgCommand cmd = new Site2SiteVpnCfgCommand(isCreate, localPublicIp, localPublicGateway, localGuestCidr, peerGatewayIp, peerGuestCidrList, ikePolicy, | ||||||
|                 espPolicy, ipsecPsk, ikeLifetime, espLifetime, dpd, conn.isPassive()); |                 espPolicy, ipsecPsk, ikeLifetime, espLifetime, dpd, conn.isPassive(), encap); | ||||||
|         cmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId())); |         cmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId())); | ||||||
|         cmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId())); |         cmd.setAccessDetail(NetworkElementCommand.ROUTER_IP, _routerControlHelper.getRouterControlIp(router.getId())); | ||||||
|         cmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); |         cmd.setAccessDetail(NetworkElementCommand.ROUTER_NAME, router.getInstanceName()); | ||||||
|  | |||||||
| @ -218,6 +218,11 @@ public class Site2SiteVpnManagerImpl extends ManagerBase implements Site2SiteVpn | |||||||
|             dpd = false; |             dpd = false; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         Boolean encap = cmd.getEncap(); | ||||||
|  |         if (encap == null) { | ||||||
|  |             encap = false; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         long accountId = owner.getAccountId(); |         long accountId = owner.getAccountId(); | ||||||
|         if (_customerGatewayDao.findByGatewayIpAndAccountId(gatewayIp, accountId) != null) { |         if (_customerGatewayDao.findByGatewayIpAndAccountId(gatewayIp, accountId) != null) { | ||||||
|             throw new InvalidParameterValueException("The customer gateway with ip " + gatewayIp + " already existed in the system!"); |             throw new InvalidParameterValueException("The customer gateway with ip " + gatewayIp + " already existed in the system!"); | ||||||
| @ -229,7 +234,7 @@ public class Site2SiteVpnManagerImpl extends ManagerBase implements Site2SiteVpn | |||||||
|         checkCustomerGatewayCidrList(peerCidrList); |         checkCustomerGatewayCidrList(peerCidrList); | ||||||
| 
 | 
 | ||||||
|         Site2SiteCustomerGatewayVO gw = |         Site2SiteCustomerGatewayVO gw = | ||||||
|             new Site2SiteCustomerGatewayVO(name, accountId, owner.getDomainId(), gatewayIp, peerCidrList, ipsecPsk, ikePolicy, espPolicy, ikeLifetime, espLifetime, dpd); |             new Site2SiteCustomerGatewayVO(name, accountId, owner.getDomainId(), gatewayIp, peerCidrList, ipsecPsk, ikePolicy, espPolicy, ikeLifetime, espLifetime, dpd, encap); | ||||||
|         _customerGatewayDao.persist(gw); |         _customerGatewayDao.persist(gw); | ||||||
|         return gw; |         return gw; | ||||||
|     } |     } | ||||||
| @ -467,6 +472,11 @@ public class Site2SiteVpnManagerImpl extends ManagerBase implements Site2SiteVpn | |||||||
|             dpd = false; |             dpd = false; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         Boolean encap = cmd.getEncap(); | ||||||
|  |         if (encap == null) { | ||||||
|  |             encap = false; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         checkCustomerGatewayCidrList(guestCidrList); |         checkCustomerGatewayCidrList(guestCidrList); | ||||||
| 
 | 
 | ||||||
|         long accountId = gw.getAccountId(); |         long accountId = gw.getAccountId(); | ||||||
| @ -488,6 +498,7 @@ public class Site2SiteVpnManagerImpl extends ManagerBase implements Site2SiteVpn | |||||||
|         gw.setIkeLifetime(ikeLifetime); |         gw.setIkeLifetime(ikeLifetime); | ||||||
|         gw.setEspLifetime(espLifetime); |         gw.setEspLifetime(espLifetime); | ||||||
|         gw.setDpd(dpd); |         gw.setDpd(dpd); | ||||||
|  |         gw.setEncap(encap); | ||||||
|         _customerGatewayDao.persist(gw); |         _customerGatewayDao.persist(gw); | ||||||
|         return gw; |         return gw; | ||||||
|     } |     } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user