Merge "Use Java 7 new method getLoopbackAddress in ClusterManager"
[controller.git] / opendaylight / netconf / config-netconf-connector / src / main / java / org / opendaylight / controller / netconf / confignetconfconnector / mapping / attributes / mapping / ObjectNameAttributeMappingStrategy.java
1 /*
2  * Copyright (c) 2013 Cisco Systems, Inc. and others.  All rights reserved.
3  *
4  * This program and the accompanying materials are made available under the
5  * terms of the Eclipse Public License v1.0 which accompanies this distribution,
6  * and is available at http://www.eclipse.org/legal/epl-v10.html
7  */
8
9 package org.opendaylight.controller.netconf.confignetconfconnector.mapping.attributes.mapping;
10
11 import com.google.common.base.Optional;
12 import com.google.common.base.Preconditions;
13 import org.opendaylight.controller.config.api.jmx.ObjectNameUtil;
14 import org.opendaylight.controller.netconf.confignetconfconnector.mapping.config.ServiceRegistryWrapper;
15 import org.opendaylight.controller.netconf.confignetconfconnector.util.Util;
16
17 import javax.management.ObjectName;
18 import javax.management.openmbean.SimpleType;
19
20 public class ObjectNameAttributeMappingStrategy extends
21         AbstractAttributeMappingStrategy<ObjectNameAttributeMappingStrategy.MappedDependency, SimpleType<?>> {
22
23     private final ServiceRegistryWrapper tracker;
24     private final String serviceName;
25     private final String namespace;
26
27     public ObjectNameAttributeMappingStrategy(SimpleType<?> openType, ServiceRegistryWrapper dependencyTracker, String serviceName, String namespace) {
28         super(openType);
29         this.tracker = dependencyTracker;
30         this.serviceName = serviceName;
31         this.namespace = namespace;
32     }
33
34     @Override
35     public Optional<MappedDependency> mapAttribute(Object value) {
36         if (value == null)
37             return Optional.absent();
38
39         String expectedClass = getOpenType().getClassName();
40         String realClass = value.getClass().getName();
41         Preconditions.checkArgument(realClass.equals(expectedClass), "Type mismatch, expected " + expectedClass
42                 + " but was " + realClass);
43         Util.checkType(value, ObjectName.class);
44
45         ObjectName on = (ObjectName) value;
46
47         String refName = ObjectNameUtil.getReferenceName(on);
48
49         return Optional.of(new MappedDependency(namespace, serviceName, refName));
50     }
51
52     public static class MappedDependency {
53         private final String namespace, serviceName, refName;
54
55         public MappedDependency(String namespace, String serviceName, String refName) {
56             this.serviceName = serviceName;
57             this.refName = refName;
58             this.namespace = namespace;
59         }
60
61         public String getServiceName() {
62             return serviceName;
63         }
64
65         public String getRefName() {
66             return refName;
67         }
68
69         public String getNamespace() {
70             return namespace;
71         }
72
73         @Override
74         public String toString() {
75             final StringBuffer sb = new StringBuffer("MappedDependency{");
76             sb.append("namespace='").append(namespace).append('\'');
77             sb.append(", serviceName='").append(serviceName).append('\'');
78             sb.append(", refName='").append(refName).append('\'');
79             sb.append('}');
80             return sb.toString();
81         }
82     }
83
84 }