3 * Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
5 * This program and the accompanying materials are made available under the
6 * terms of the Eclipse Public License v1.0 which accompanies this distribution,
7 * and is available at http://www.eclipse.org/legal/epl-v10.html
10 package org.opendaylight.controller.switchmanager.northbound;
12 import java.util.HashMap;
13 import java.util.HashSet;
16 import javax.xml.bind.annotation.XmlAccessType;
17 import javax.xml.bind.annotation.XmlAccessorType;
18 import javax.xml.bind.annotation.XmlElement;
19 import javax.xml.bind.annotation.XmlElementRef;
20 import javax.xml.bind.annotation.XmlElementWrapper;
21 import javax.xml.bind.annotation.XmlRootElement;
23 import com.fasterxml.jackson.annotation.JsonIgnore;
24 import com.fasterxml.jackson.annotation.JsonProperty;
25 import org.opendaylight.controller.sal.core.Node;
26 import org.opendaylight.controller.sal.core.Property;
29 * The class describes set of properties attached to a node
33 @XmlAccessorType(XmlAccessType.NONE)
34 public class NodeProperties {
40 private Set<Property> properties;
42 // JAXB required constructor
43 private NodeProperties() {
45 this.properties = null;
48 public NodeProperties(Node node, Set<Property> properties) {
50 this.properties = properties;
53 @JsonProperty(value="properties")
54 public Map<String, Property> getMapProperties() {
55 Map<String, Property> map = new HashMap<String, Property>();
56 for (Property p : properties) {
57 map.put(p.getName(), p);
62 public void setMapProperties(Map<String, Property> propertiesMap) {
63 this.properties = new HashSet<Property>(propertiesMap.values());
66 public Set<Property> getProperties() {
70 public void setProperties(Set<Property> properties) {
71 this.properties = properties;
74 public Node getNode() {
78 public void setNode(Node node) {