Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix(eos_designs): Use CP-Profile for WAN HA when DP-Profile is not configured #4309

Merged
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ router path-selection
tcp mss ceiling ipv4 ingress
!
path-group CUSTOM_LAN_HA id 65535
ipsec profile DP-PROFILE
ipsec profile ONE-PROFILE-TO-CONTROL-THEM-ALL
flow assignment lan
!
local interface Ethernet52
Expand Down Expand Up @@ -200,35 +200,20 @@ ip security
ike policy CP-IKE-POLICY
local-id 192.168.142.3
!
ike policy DP-IKE-POLICY
local-id 192.168.142.3
!
sa policy CP-SA-POLICY
esp encryption aes256gcm128
pfs dh-group 14
!
sa policy DP-SA-POLICY
esp encryption aes256gcm128
pfs dh-group 14
!
profile CP-PROFILE
profile ONE-PROFILE-TO-CONTROL-THEM-ALL
ike-policy CP-IKE-POLICY
sa-policy CP-SA-POLICY
connection start
shared-key 7 ABCDEF1234567890
dpd 10 50 clear
mode transport
!
profile DP-PROFILE
ike-policy DP-IKE-POLICY
sa-policy DP-SA-POLICY
connection start
shared-key 7 ABCDEF1234567890666
dpd 10 50 clear
mode transport
!
key controller
profile DP-PROFILE
profile ONE-PROFILE-TO-CONTROL-THEM-ALL
!
interface Dps1
description DPS Interface
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -420,31 +420,15 @@ ip_extcommunity_lists:
extcommunities: soo 192.168.42.2:423
ip_security:
ike_policies:
- name: DP-IKE-POLICY
local_id: 192.168.142.3
- name: CP-IKE-POLICY
local_id: 192.168.142.3
sa_policies:
- name: DP-SA-POLICY
esp:
encryption: aes256gcm128
pfs_dh_group: 14
- name: CP-SA-POLICY
esp:
encryption: aes256gcm128
pfs_dh_group: 14
profiles:
- name: DP-PROFILE
ike_policy: DP-IKE-POLICY
sa_policy: DP-SA-POLICY
connection: start
shared_key: ABCDEF1234567890666
dpd:
interval: 10
time: 50
action: clear
mode: transport
- name: CP-PROFILE
- name: ONE-PROFILE-TO-CONTROL-THEM-ALL
ike_policy: CP-IKE-POLICY
sa_policy: CP-SA-POLICY
connection: start
Expand All @@ -455,7 +439,7 @@ ip_security:
action: clear
mode: transport
key_controller:
profile: DP-PROFILE
profile: ONE-PROFILE-TO-CONTROL-THEM-ALL
management_security:
ssl_profiles:
- name: profileA
Expand Down Expand Up @@ -595,7 +579,7 @@ router_path_selection:
ipv4_addresses:
- 172.17.0.5
- 172.17.0.7
ipsec_profile: DP-PROFILE
ipsec_profile: ONE-PROFILE-TO-CONTROL-THEM-ALL
load_balance_policies:
- name: LB-DEFAULT-AVT-POLICY-CONTROL-PLANE
path_groups:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,6 @@
# Make sure to set the cv_token var on the molecule command line like:
# molecule converge -s eos_designs_unit_tests -- --limit cv-pathfinder-edge1 -e cv_token=$CV_TOKEN -v

# serial_number: mockZscaler
# cv_server: "www.cv-play.corp.arista.io"
# zscaler_endpoints: null

# Testing multiple pathinfders on one device
wan_route_servers:
- hostname: cv-pathfinder-pathfinder1
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,11 @@

wan_ha:
lan_ha_path_group_name: CUSTOM_LAN_HA

# Testing having only control_plane ipsec profile and making sure it is used for
# HA path-group. Yes it makes for asymmetric config with 2A but this is a unit
# test.
wan_ipsec_profiles:
control_plane:
profile_name: ONE-PROFILE-TO-CONTROL-THEM-ALL
shared_key: ABCDEF1234567890
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ def ip_security(self: AvdStructuredConfigOverlay) -> dict | None:
return strip_null_from_data(ip_security)

def _append_data_plane(self: AvdStructuredConfigOverlay, ip_security: dict, data_plane_config: dict) -> None:
"""In place update of ip_security."""
"""In place update of ip_security for DataPlane."""
gmuloc marked this conversation as resolved.
Show resolved Hide resolved
ike_policy_name = get(data_plane_config, "ike_policy_name", default="DP-IKE-POLICY") if self.shared_utils.wan_ha_ipsec else None
sa_policy_name = get(data_plane_config, "sa_policy_name", default="DP-SA-POLICY")
profile_name = get(data_plane_config, "profile_name", default="DP-PROFILE")
Expand All @@ -66,7 +66,7 @@ def _append_control_plane(self: AvdStructuredConfigOverlay, ip_security: dict, c
"""
In place update of ip_security for control plane data.

expected to be called AFTER _append_data_plane
expected to be called AFTER _append_data_plane as CP is used for data-plane as well if not configured.
"""
ike_policy_name = get(control_plane_config, "ike_policy_name", default="CP-IKE-POLICY")
sa_policy_name = get(control_plane_config, "sa_policy_name", default="CP-SA-POLICY")
Expand All @@ -78,7 +78,7 @@ def _append_control_plane(self: AvdStructuredConfigOverlay, ip_security: dict, c
ip_security["profiles"].append(self._profile(profile_name, ike_policy_name, sa_policy_name, key))

if not ip_security.get("key_controller"):
# If there is not data plane IPSec profile, use the control plane one for key controller
# If there is no data plane IPSec profile, use the control plane one for key controller
ip_security["key_controller"] = self._key_controller(profile_name)

def _ike_policy(self: AvdStructuredConfigOverlay, name: str) -> dict | None:
Expand Down Expand Up @@ -126,7 +126,4 @@ def _profile(self: AvdStructuredConfigOverlay, profile_name: str, ike_policy_nam

def _key_controller(self: AvdStructuredConfigOverlay, profile_name: str) -> dict | None:
"""Return a key_controller structure if the device is not a RR or pathfinder."""
if self.shared_utils.is_wan_server:
return None

return {"profile": profile_name}
return None if self.shared_utils.is_wan_server else {"profile": profile_name}
Original file line number Diff line number Diff line change
Expand Up @@ -45,9 +45,13 @@ def _cp_ipsec_profile_name(self: AvdStructuredConfigOverlay) -> str:

@cached_property
def _dp_ipsec_profile_name(self: AvdStructuredConfigOverlay) -> str:
"""Returns the IPsec profile name to use for Data-Plane."""
# TODO: need to use CP one if 'wan_ipsec_profiles.data_plane' not present
return get(self._hostvars, "wan_ipsec_profiles.data_plane.profile_name", default="DP-PROFILE")
"""Returns the IPsec profile name to use for Data-Plane.

If no data-plane config is present for IPsec, default to _cp_ipsec_profile_name
"""
if (data_plane := get(self._hostvars, "wan_ipsec_profiles.data_plane")) is not None:
ClausHolbechArista marked this conversation as resolved.
Show resolved Hide resolved
return get(data_plane, "profile_name", default="DP-PROFILE")
return self._cp_ipsec_profile_name

def _get_path_groups(self: AvdStructuredConfigOverlay) -> list:
"""Generate the required path-groups locally."""
Expand Down
Loading