BUG-2453 (De)Serialize enum values as defined in yang
[controller.git] / opendaylight / netconf / config-netconf-connector / src / main / java / org / opendaylight / controller / netconf / confignetconfconnector / osgi / YangStoreSnapshot.java
index 283ec424badac4a18703044cd95175f5b0aeef88..c798da7f7629a4ac4783900a65c56895cc925543 100644 (file)
@@ -9,7 +9,9 @@
 package org.opendaylight.controller.netconf.confignetconfconnector.osgi;
 
 import com.google.common.base.Optional;
+import com.google.common.base.Preconditions;
 import com.google.common.base.Predicate;
+import com.google.common.collect.BiMap;
 import com.google.common.collect.Iterables;
 import com.google.common.collect.Maps;
 import com.google.common.collect.Sets;
@@ -23,6 +25,7 @@ import org.opendaylight.controller.config.yangjmxgenerator.ModuleMXBeanEntry;
 import org.opendaylight.controller.config.yangjmxgenerator.PackageTranslator;
 import org.opendaylight.controller.config.yangjmxgenerator.ServiceInterfaceEntry;
 import org.opendaylight.controller.config.yangjmxgenerator.TypeProviderWrapper;
+import org.opendaylight.yangtools.sal.binding.generator.util.BindingRuntimeContext;
 import org.opendaylight.yangtools.sal.binding.yang.types.TypeProviderImpl;
 import org.opendaylight.yangtools.yang.common.QName;
 import org.opendaylight.yangtools.yang.model.api.IdentitySchemaNode;
@@ -32,19 +35,21 @@ import org.opendaylight.yangtools.yang.parser.builder.impl.ModuleIdentifierImpl;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
-final class YangStoreSnapshot implements YangStoreContext {
+final class YangStoreSnapshot implements YangStoreContext, EnumResolver {
     private static final Logger LOG = LoggerFactory.getLogger(YangStoreSnapshot.class);
 
 
     private final Map<String /* Namespace from yang file */,
-    Map<String /* Name of module entry from yang file */, ModuleMXBeanEntry>> moduleMXBeanEntryMap;
+        Map<String /* Name of module entry from yang file */, ModuleMXBeanEntry>> moduleMXBeanEntryMap;
 
 
     private final Map<QName, Map<String, ModuleMXBeanEntry>> qNamesToIdentitiesToModuleMXBeanEntries;
 
     private final SchemaContext schemaContext;
+    private final BindingRuntimeContext bindingContextProvider;
 
-    public YangStoreSnapshot(final SchemaContext resolveSchemaContext) {
+    public YangStoreSnapshot(final SchemaContext resolveSchemaContext, final BindingRuntimeContext bindingContextProvider) {
+        this.bindingContextProvider = bindingContextProvider;
         LOG.trace("Resolved modules:{}", resolveSchemaContext.getModules());
         this.schemaContext = resolveSchemaContext;
         // JMX generator
@@ -132,6 +137,11 @@ final class YangStoreSnapshot implements YangStoreContext {
         }
     }
 
+    @Override
+    public EnumResolver getEnumResolver() {
+        return this;
+    }
+
     @Override
     public boolean equals(final Object o) {
         if (this == o) return true;
@@ -149,4 +159,21 @@ final class YangStoreSnapshot implements YangStoreContext {
     public int hashCode() {
         return schemaContext != null ? schemaContext.hashCode() : 0;
     }
+
+    @Override
+    public String fromYang(final String enumClass, final String enumYangValue) {
+        Preconditions.checkState(bindingContextProvider != null, "Binding context provider was not set yet");
+        final BiMap<String, String> enumMapping = bindingContextProvider.getEnumMapping(enumClass);
+        final String javaName = enumMapping.get(enumYangValue);
+        return Preconditions.checkNotNull(javaName, "Unable to resolve enum value %s for enum class %s with assumed enum mapping: %s", enumYangValue, enumClass, enumMapping);
+    }
+
+    @Override
+    public String toYang(final String enumClass, final String enumJavaValue) {
+        Preconditions.checkState(bindingContextProvider != null, "Binding context provider was not set yet");
+        final BiMap<String, String> enumMapping = bindingContextProvider.getEnumMapping(enumClass);
+        final String javaName = enumMapping.inverse().get(enumJavaValue);
+        return Preconditions.checkNotNull(javaName, "Unable to map enumcd .." +
+                "cd  value %s for enum class %s with assumed enum mapping: %s", enumJavaValue, enumClass, enumMapping.inverse());
+    }
 }