/* * Copyright (c) 2015, 2016 Brocade Communications Systems, Inc. and others. All rights reserved. * * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 which accompanies this distribution, * and is available at http://www.eclipse.org/legal/epl-v10.html */ package org.opendaylight.ovsdb.southbound.ovsdb.transact; import static org.opendaylight.ovsdb.lib.operations.Operations.op; import java.util.HashMap; import java.util.HashSet; import java.util.List; import java.util.Map; import java.util.Map.Entry; import java.util.Set; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeEvent; import org.opendaylight.ovsdb.lib.error.SchemaVersionMismatchException; import org.opendaylight.ovsdb.lib.notation.UUID; import org.opendaylight.ovsdb.lib.operations.TransactionBuilder; import org.opendaylight.ovsdb.lib.schema.typed.TyperUtils; import org.opendaylight.ovsdb.schema.openvswitch.Interface; import org.opendaylight.ovsdb.schema.openvswitch.Port; import org.opendaylight.ovsdb.southbound.SouthboundConstants; import org.opendaylight.ovsdb.utils.yang.YangUtils; import org.opendaylight.yang.gen.v1.urn.ietf.params.xml.ns.yang.ietf.yang.types.rev130715.Uuid; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbPortInterfaceAttributes.VlanMode; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbTerminationPointAugmentation; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.InterfaceExternalIds; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.InterfaceLldp; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.InterfaceOtherConfigs; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.Options; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.PortExternalIds; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.PortOtherConfigs; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.port._interface.attributes.Trunks; import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.node.TerminationPoint; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.google.common.collect.Sets; public class TerminationPointUpdateCommand extends AbstractTransactCommand { private static final Logger LOG = LoggerFactory.getLogger(TerminationPointUpdateCommand.class); public TerminationPointUpdateCommand(BridgeOperationalState state, AsyncDataChangeEvent, DataObject> changes) { super(state, changes); } @Override public void execute(TransactionBuilder transaction) { LOG.trace("TerminationPointUpdateCommand called"); Map, OvsdbTerminationPointAugmentation> created = TransactUtils.extractCreated(getChanges(),OvsdbTerminationPointAugmentation.class); for (Entry, OvsdbTerminationPointAugmentation> terminationPointEntry : created.entrySet()) { updateTerminationPoint(transaction, terminationPointEntry.getKey(), terminationPointEntry.getValue()); } Map, OvsdbTerminationPointAugmentation> updated = TransactUtils.extractUpdated(getChanges(), OvsdbTerminationPointAugmentation.class); for (Entry, OvsdbTerminationPointAugmentation> terminationPointEntry : updated.entrySet()) { updateTerminationPoint(transaction, terminationPointEntry.getKey(), terminationPointEntry.getValue()); } } public void updateTerminationPoint(TransactionBuilder transaction, InstanceIdentifier iid, OvsdbTerminationPointAugmentation terminationPoint) { if (terminationPoint instanceof OvsdbTerminationPointAugmentation) { LOG.debug("Received request to update termination point {}", terminationPoint.getName()); // Update interface Interface ovsInterface = TyperUtils.getTypedRowWrapper(transaction.getDatabaseSchema(), Interface.class); updateInterface(terminationPoint, ovsInterface); Interface extraInterface = TyperUtils.getTypedRowWrapper( transaction.getDatabaseSchema(), Interface.class); extraInterface.setName(""); transaction.add(op.update(ovsInterface) .where(extraInterface.getNameColumn().getSchema().opEqual(terminationPoint.getName())) .build()); TerminationPointCreateCommand.stampInstanceIdentifier(transaction, iid.firstIdentifierOf(TerminationPoint.class), terminationPoint.getName()); // Update port Port port = TyperUtils.getTypedRowWrapper( transaction.getDatabaseSchema(), Port.class); updatePort(terminationPoint,port); Port extraPort = TyperUtils.getTypedRowWrapper( transaction.getDatabaseSchema(), Port.class); extraPort.setName(""); transaction.add(op.update(port) .where(extraPort.getNameColumn().getSchema().opEqual(terminationPoint.getName())) .build()); } } private void updateInterface( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { updateOfPort(terminationPoint, ovsInterface); updateOfPortRequest(terminationPoint, ovsInterface); updateInterfaceOptions(terminationPoint, ovsInterface); updateInterfaceOtherConfig(terminationPoint, ovsInterface); updateInterfaceExternalIds(terminationPoint, ovsInterface); updateInterfaceLldp(terminationPoint, ovsInterface); } private void updatePort( final OvsdbTerminationPointAugmentation terminationPoint, final Port port) { updatePortOtherConfig(terminationPoint, port); updatePortVlanTag(terminationPoint, port); updatePortVlanTrunk(terminationPoint, port); updatePortVlanMode(terminationPoint, port); updatePortExternalIds(terminationPoint, port); updatePortQos(terminationPoint, port); } private void updatePortQos( final OvsdbTerminationPointAugmentation terminationPoint, final Port port) { Set uuidSet = Sets.newHashSet(); Uuid qosUuid = terminationPoint.getQos(); if (qosUuid != null) { uuidSet.add(new UUID(qosUuid.getValue())); } port.setQos(uuidSet); } private void updateOfPort( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { Long ofPort = terminationPoint.getOfport(); if (ofPort != null) { ovsInterface.setOpenFlowPort(Sets.newHashSet(ofPort)); } } private void updateOfPortRequest( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { Integer ofPortRequest = terminationPoint.getOfportRequest(); if (ofPortRequest != null) { ovsInterface.setOpenFlowPortRequest(Sets.newHashSet(ofPortRequest.longValue())); } } private void updateInterfaceOptions( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { //Configure optional input if (terminationPoint.getOptions() != null) { try { ovsInterface.setOptions(YangUtils.convertYangKeyValueListToMap(terminationPoint.getOptions(), Options::getOption, Options::getValue)); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB interface options", e); } } } private void updateInterfaceExternalIds( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { List interfaceExternalIds = terminationPoint.getInterfaceExternalIds(); if (interfaceExternalIds != null && !interfaceExternalIds.isEmpty()) { try { ovsInterface.setExternalIds(YangUtils.convertYangKeyValueListToMap(interfaceExternalIds, InterfaceExternalIds::getExternalIdKey, InterfaceExternalIds::getExternalIdValue)); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB interface external_ids", e); } } } private void updateInterfaceLldp( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { try { List interfaceLldpList = terminationPoint.getInterfaceLldp(); if (interfaceLldpList != null && !interfaceLldpList.isEmpty()) { try { ovsInterface.setLldp(YangUtils.convertYangKeyValueListToMap(interfaceLldpList, InterfaceLldp::getLldpKey, InterfaceLldp::getLldpValue)); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB interface lldp", e); } } } catch (SchemaVersionMismatchException e) { LOG.debug("lldp column for Interface Table unsupported for this version of ovsdb schema", e); } } private void updateInterfaceOtherConfig( final OvsdbTerminationPointAugmentation terminationPoint, final Interface ovsInterface) { List interfaceOtherConfigs = terminationPoint.getInterfaceOtherConfigs(); if (interfaceOtherConfigs != null && !interfaceOtherConfigs.isEmpty()) { Map otherConfigsMap = new HashMap<>(); for (InterfaceOtherConfigs interfaceOtherConfig : interfaceOtherConfigs) { otherConfigsMap.put(interfaceOtherConfig.getOtherConfigKey(), interfaceOtherConfig.getOtherConfigValue()); } try { ovsInterface.setOtherConfig(otherConfigsMap); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB interface other_config", e); } } } private void updatePortExternalIds( final OvsdbTerminationPointAugmentation terminationPoint, final Port port) { List portExternalIds = terminationPoint.getPortExternalIds(); if (portExternalIds != null && !portExternalIds.isEmpty()) { try { port.setExternalIds(YangUtils.convertYangKeyValueListToMap(portExternalIds, PortExternalIds::getExternalIdKey, PortExternalIds::getExternalIdValue)); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB port external_ids", e); } } } private void updatePortVlanTag( final OvsdbTerminationPointAugmentation terminationPoint, final Port port) { if (terminationPoint.getVlanTag() != null) { Set vlanTag = new HashSet<>(); vlanTag.add(terminationPoint.getVlanTag().getValue().longValue()); port.setTag(vlanTag); } } private void updatePortVlanTrunk( final OvsdbTerminationPointAugmentation terminationPoint, final Port port) { if (terminationPoint.getTrunks() != null && terminationPoint.getTrunks().size() > 0) { Set portTrunks = new HashSet<>(); List modelTrunks = terminationPoint.getTrunks(); for (Trunks trunk: modelTrunks) { if (trunk.getTrunk() != null) { portTrunks.add(trunk.getTrunk().getValue().longValue()); } } port.setTrunks(portTrunks); } } private void updatePortVlanMode( final OvsdbTerminationPointAugmentation terminationPoint, final Port port) { if (terminationPoint.getVlanMode() != null) { Set portVlanMode = new HashSet<>(); VlanMode modelVlanMode = terminationPoint.getVlanMode(); portVlanMode.add(SouthboundConstants.VLANMODES.values()[modelVlanMode.getIntValue() - 1].getMode()); port.setVlanMode(portVlanMode); } } private void updatePortOtherConfig( final OvsdbTerminationPointAugmentation terminationPoint, final Port ovsPort) { List portOtherConfigs = terminationPoint.getPortOtherConfigs(); if (portOtherConfigs != null && !portOtherConfigs.isEmpty()) { try { ovsPort.setOtherConfig(YangUtils.convertYangKeyValueListToMap(portOtherConfigs, PortOtherConfigs::getOtherConfigKey, PortOtherConfigs::getOtherConfigValue)); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB port other_config", e); } } } }