use of org.openkilda.model.FlowMirrorPoints in project open-kilda by telstra.
the class FermaFlowMirrorPointsRepositoryTest method createTestFlowMirrorPoints.
private FlowMirrorPoints createTestFlowMirrorPoints() {
FlowMirrorPoints flowMirrorPoints = FlowMirrorPoints.builder().mirrorGroup(mirrorGroup).mirrorSwitch(switchA).build();
flowMirrorPointsRepository.add(flowMirrorPoints);
return flowMirrorPoints;
}
use of org.openkilda.model.FlowMirrorPoints in project open-kilda by telstra.
the class SwitchOperationsService method validateSwitchProperties.
private void validateSwitchProperties(SwitchId switchId, SwitchProperties updatedSwitchProperties) {
if (!updatedSwitchProperties.isMultiTable()) {
String propertyErrorMessage = "Illegal switch properties combination for switch %s. '%s' property " + "can be set to 'true' only if 'multiTable' property is 'true'.";
if (updatedSwitchProperties.isSwitchLldp()) {
throw new IllegalSwitchPropertiesException(format(propertyErrorMessage, switchId, "switchLldp"));
}
if (updatedSwitchProperties.isSwitchArp()) {
throw new IllegalSwitchPropertiesException(format(propertyErrorMessage, switchId, "switchArp"));
}
List<String> flowsWitchEnabledLldp = flowRepository.findByEndpointSwitchWithEnabledLldp(switchId).stream().map(Flow::getFlowId).collect(Collectors.toList());
if (!flowsWitchEnabledLldp.isEmpty()) {
throw new IllegalSwitchPropertiesException(format("Illegal switch properties combination for switch %s. " + "Detect Connected Devices feature is turn on for following flows [%s]. " + "For correct work of this feature switch property 'multiTable' must be set to 'true' " + "Please disable detecting of connected devices via LLDP for each flow before set " + "'multiTable' property to 'false'", switchId, String.join(", ", flowsWitchEnabledLldp)));
}
List<String> flowsWithEnabledArp = flowRepository.findByEndpointSwitchWithEnabledArp(switchId).stream().map(Flow::getFlowId).collect(Collectors.toList());
if (!flowsWithEnabledArp.isEmpty()) {
throw new IllegalSwitchPropertiesException(format("Illegal switch properties combination for switch %s. " + "Detect Connected Devices feature via ARP is turn on for following flows [%s]. " + "For correct work of this feature switch property 'multiTable' must be set to 'true' " + "Please disable detecting of connected devices via ARP for each flow before set " + "'multiTable' property to 'false'", switchId, String.join(", ", flowsWithEnabledArp)));
}
}
if (updatedSwitchProperties.getServer42Port() != null) {
Optional<PhysicalPort> physicalPort = physicalPortRepository.findBySwitchIdAndPortNumber(switchId, updatedSwitchProperties.getServer42Port());
if (physicalPort.isPresent()) {
throw new IllegalSwitchPropertiesException(format("Illegal server42 port '%d' on switch %s. This port is part of LAG '%d'. Please " + "delete LAG port or choose another server42 port.", updatedSwitchProperties.getServer42Port(), switchId, physicalPort.get().getLagLogicalPort().getLogicalPortNumber()));
}
}
if (updatedSwitchProperties.isServer42FlowRtt()) {
String errorMessage = "Illegal switch properties combination for switch %s. To enable property " + "'server42_flow_rtt' you need to specify valid property '%s'";
if (updatedSwitchProperties.getServer42Port() == null) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, "server42_port"));
}
if (updatedSwitchProperties.getServer42MacAddress() == null) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, "server42_mac_address"));
}
if (updatedSwitchProperties.getServer42Vlan() == null) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, "server42_vlan"));
}
}
if (updatedSwitchProperties.getServer42IslRtt() == RttState.ENABLED) {
String errorMessage = "Illegal switch properties combination for switch %s. To enable property " + "'server42_isl_rtt' you need to specify valid property '%s'";
if (updatedSwitchProperties.getServer42Port() == null) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, "server42_port"));
}
if (updatedSwitchProperties.getServer42MacAddress() == null) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, "server42_mac_address"));
}
if (updatedSwitchProperties.getServer42Vlan() == null) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, "server42_vlan"));
}
}
Collection<FlowMirrorPoints> flowMirrorPoints = flowMirrorPointsRepository.findBySwitchId(switchId);
if (!flowMirrorPoints.isEmpty() && (updatedSwitchProperties.isSwitchLldp() || updatedSwitchProperties.isSwitchArp())) {
throw new IllegalSwitchPropertiesException(format("Flow mirror point is created on the switch %s, " + "switchLldp or switchArp can not be set to true.", switchId));
}
if (updatedSwitchProperties.getServer42Port() != null) {
String errorMessage = "SwitchId '%s' and port '%d' belong to the %s endpoint. " + "Cannot specify port '%d' as port for server 42.";
int server42port = updatedSwitchProperties.getServer42Port();
Collection<Flow> flows = flowRepository.findByEndpoint(switchId, server42port);
if (!flows.isEmpty()) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, server42port, "flow", server42port));
}
Collection<FlowMirrorPath> flowMirrorPaths = flowMirrorPathRepository.findByEgressSwitchIdAndPort(switchId, server42port);
if (!flowMirrorPaths.isEmpty()) {
throw new IllegalSwitchPropertiesException(format(errorMessage, switchId, server42port, "flow mirror path", server42port));
}
}
}
use of org.openkilda.model.FlowMirrorPoints in project open-kilda by telstra.
the class SwitchOperationsServiceTest method shouldValidateFlowMirrorPointsWhenUpdatingSwitchLldpProperties.
@Test(expected = IllegalSwitchPropertiesException.class)
public void shouldValidateFlowMirrorPointsWhenUpdatingSwitchLldpProperties() {
Switch mirrorSwitch = Switch.builder().switchId(TEST_SWITCH_ID).status(SwitchStatus.ACTIVE).build();
switchRepository.add(mirrorSwitch);
MirrorGroup mirrorGroup = MirrorGroup.builder().switchId(TEST_SWITCH_ID).groupId(new GroupId(12L)).pathId(new PathId("test_path_id")).flowId(TEST_FLOW_ID_1).mirrorGroupType(MirrorGroupType.TRAFFIC_INTEGRITY).mirrorDirection(MirrorDirection.INGRESS).build();
mirrorGroupRepository.add(mirrorGroup);
FlowMirrorPoints flowMirrorPoints = FlowMirrorPoints.builder().mirrorGroup(mirrorGroup).mirrorSwitch(mirrorSwitch).build();
flowMirrorPointsRepository.add(flowMirrorPoints);
createSwitchProperties(mirrorSwitch, Collections.singleton(FlowEncapsulationType.TRANSIT_VLAN), true, false, false);
SwitchPropertiesDto update = new SwitchPropertiesDto();
update.setSupportedTransitEncapsulation(Collections.singleton(org.openkilda.messaging.payload.flow.FlowEncapsulationType.TRANSIT_VLAN));
update.setMultiTable(true);
update.setSwitchLldp(true);
switchOperationsService.updateSwitchProperties(TEST_SWITCH_ID, update);
}
use of org.openkilda.model.FlowMirrorPoints in project open-kilda by telstra.
the class EgressMirrorRuleGenerator method generateCommands.
@Override
public List<SpeakerData> generateCommands(Switch sw) {
List<SpeakerData> result = new ArrayList<>();
if (flowPath.isOneSwitchFlow() || flowPath.getSegments().isEmpty()) {
return result;
}
FlowMirrorPoints mirrorPoints = flowPath.getFlowMirrorPointsSet().stream().filter(points -> sw.getSwitchId().equals(points.getMirrorSwitchId())).findFirst().orElse(null);
if (mirrorPoints == null) {
return result;
}
PathSegment lastSegment = flowPath.getSegments().get(flowPath.getSegments().size() - 1);
FlowEndpoint egressEndpoint = checkAndBuildEgressEndpoint(flow, flowPath, sw.getSwitchId());
SpeakerData egressCommand = buildEgressCommand(sw, lastSegment.getDestPort(), egressEndpoint, mirrorPoints.getMirrorGroupId());
result.add(egressCommand);
SpeakerData groupCommand = buildGroup(sw, mirrorPoints, egressEndpoint.getPortNumber());
result.add(groupCommand);
egressCommand.getDependsOn().add(groupCommand.getUuid());
return result;
}
use of org.openkilda.model.FlowMirrorPoints in project open-kilda by telstra.
the class Utils method buildMirrorBuckets.
/**
* Builds group buckets for flow mirror points (only for sink endpoints. Flow bucket must be build separately).
*/
public static List<Bucket> buildMirrorBuckets(FlowMirrorPoints flowMirrorPoints) {
List<Bucket> buckets = new ArrayList<>();
Set<MirrorConfigData> mirrorConfigDataSet = flowMirrorPoints.getMirrorPaths().stream().map(mirrorPath -> new MirrorConfigData(mirrorPath.getEgressPort(), mirrorPath.getEgressOuterVlan())).collect(Collectors.toSet());
for (MirrorConfigData mirrorConfig : mirrorConfigDataSet) {
Set<Action> actions = new HashSet<>(makeVlanReplaceActions(new ArrayList<>(), makeVlanStack(mirrorConfig.getMirrorVlan())));
actions.add(new PortOutAction(new PortNumber(mirrorConfig.getMirrorPort())));
buckets.add(Bucket.builder().writeActions(actions).watchGroup(WatchGroup.ANY).watchPort(WatchPort.ANY).build());
}
return buckets;
}
Aggregations