/* * Copyright (c) 2015 Intel Corporation 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.List; import java.util.Map; import java.util.Map.Entry; import org.opendaylight.controller.md.sal.common.api.data.AsyncDataChangeEvent; import org.opendaylight.ovsdb.lib.notation.Mutator; import org.opendaylight.ovsdb.lib.operations.TransactionBuilder; import org.opendaylight.ovsdb.lib.schema.typed.TyperUtils; import org.opendaylight.ovsdb.schema.openvswitch.OpenVSwitch; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.OvsdbNodeAugmentation; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.node.attributes.OpenvswitchExternalIds; import org.opendaylight.yangtools.yang.binding.DataObject; import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.ovsdb.rev150105.ovsdb.node.attributes.OpenvswitchOtherConfigs; import org.opendaylight.yangtools.yang.binding.InstanceIdentifier; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import com.google.common.collect.ImmutableMap; public class OvsdbNodeUpdateCommand implements TransactCommand { private AsyncDataChangeEvent, DataObject> changes; private static final Logger LOG = LoggerFactory.getLogger(OvsdbNodeUpdateCommand.class); public OvsdbNodeUpdateCommand(AsyncDataChangeEvent, DataObject> changes) { this.changes = changes; } @Override public void execute(TransactionBuilder transaction) { Map, OvsdbNodeAugmentation> updated = TransactUtils.extractUpdated(changes, OvsdbNodeAugmentation.class); for (Entry, OvsdbNodeAugmentation> ovsdbNodeEntry: updated.entrySet()) { OvsdbNodeAugmentation ovsdbNode = ovsdbNodeEntry.getValue(); LOG.debug("Received request to update ovsdb node ip: {} port: {}", ovsdbNode.getIp(), ovsdbNode.getPort()); // OpenVSwitchPart OpenVSwitch ovs = TyperUtils.getTypedRowWrapper(transaction.getDatabaseSchema(), OpenVSwitch.class); List externalIds = ovsdbNode.getOpenvswitchExternalIds(); if (externalIds != null) { HashMap externalIdsMap = new HashMap(); for (OpenvswitchExternalIds externalId : externalIds) { externalIdsMap.put(externalId.getExternalIdKey(), externalId.getExternalIdValue()); } try { ovs.setExternalIds(ImmutableMap.copyOf(externalIdsMap)); transaction.add(op.mutate(ovs).addMutation(ovs.getExternalIdsColumn().getSchema(), Mutator.INSERT, ovs.getExternalIdsColumn().getData())); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB Node external IDs"); } } List otherConfigs = ovsdbNode.getOpenvswitchOtherConfigs(); if (otherConfigs != null) { HashMap otherConfigsMap = new HashMap(); for (OpenvswitchOtherConfigs otherConfig : otherConfigs) { otherConfigsMap.put(otherConfig.getOtherConfigKey(), otherConfig.getOtherConfigValue()); } try { ovs.setOtherConfig(ImmutableMap.copyOf(otherConfigsMap)); transaction.add(op.mutate(ovs).addMutation(ovs.getOtherConfigColumn().getSchema(), Mutator.INSERT, ovs.getOtherConfigColumn().getData())); } catch (NullPointerException e) { LOG.warn("Incomplete OVSDB Node other_config", e); } } } } }