X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fnetconf%2Fconfig-netconf-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fnetconf%2Fconfignetconfconnector%2Fmapping%2Fconfig%2FInstanceConfig.java;h=7cfeb453bb58f6615d64144bc4e88dd377c7b17e;hb=fb1103606a9ca152725d2b1aae0a9c8f9739faa4;hp=ba7b2f20e44058d7b9af4663003d36e4654400ea;hpb=47ef70359e1a7dc28cb7e080b7fa7aaf060afa0c;p=controller.git diff --git a/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/config/InstanceConfig.java b/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/config/InstanceConfig.java index ba7b2f20e4..7cfeb453bb 100644 --- a/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/config/InstanceConfig.java +++ b/opendaylight/netconf/config-netconf-connector/src/main/java/org/opendaylight/controller/netconf/confignetconfconnector/mapping/config/InstanceConfig.java @@ -33,6 +33,7 @@ import org.opendaylight.controller.netconf.confignetconfconnector.mapping.attrib import org.opendaylight.controller.netconf.confignetconfconnector.mapping.attributes.toxml.ObjectXmlWriter; import org.opendaylight.controller.netconf.confignetconfconnector.operations.editconfig.EditConfig; import org.opendaylight.controller.netconf.confignetconfconnector.operations.editconfig.EditStrategyType; +import org.opendaylight.controller.netconf.confignetconfconnector.osgi.EnumResolver; import org.opendaylight.controller.netconf.util.xml.XmlElement; import org.opendaylight.controller.netconf.util.xml.XmlUtil; import org.slf4j.Logger; @@ -57,11 +58,11 @@ public final class InstanceConfig { this.configRegistryClient = configRegistryClient; } - private Map getMappedConfiguration(ObjectName on) { + private Map getMappedConfiguration(ObjectName on, final EnumResolver enumResolver) { // TODO make field, mappingStrategies can be instantiated only once Map>> mappingStrategies = new ObjectMapper() - .prepareMapping(jmxToAttrConfig); + .prepareMapping(jmxToAttrConfig, enumResolver); Map toXml = Maps.newHashMap(); @@ -87,9 +88,9 @@ public final class InstanceConfig { return toXml; } - public Element toXml(ObjectName on, String namespace, Document document, Element rootElement) { + public Element toXml(ObjectName on, String namespace, Document document, Element rootElement, final EnumResolver enumResolver) { Map strats = new ObjectXmlWriter().prepareWriting(yangToAttrConfig, document); - Map mappedConfig = getMappedConfiguration(on); + Map mappedConfig = getMappedConfiguration(on, enumResolver); Element parentElement; if (nullableDummyContainerName != null) { Element dummyElement = XmlUtil.createElement(document, nullableDummyContainerName, Optional.of(namespace)); @@ -109,11 +110,11 @@ public final class InstanceConfig { return rootElement; } - private void resolveConfiguration(InstanceConfigElementResolved mappedConfig, ServiceRegistryWrapper depTracker) { + private void resolveConfiguration(InstanceConfigElementResolved mappedConfig, ServiceRegistryWrapper depTracker, final EnumResolver enumResolver) { // TODO make field, resolvingStrategies can be instantiated only once Map>> resolvingStrategies = new ObjectResolver( - depTracker).prepareResolving(yangToAttrConfig); + depTracker).prepareResolving(yangToAttrConfig, enumResolver); for (Entry configDefEntry : mappedConfig.getConfiguration().entrySet()) { AttributeConfigElement value = configDefEntry.getValue(); @@ -135,7 +136,7 @@ public final class InstanceConfig { public InstanceConfigElementResolved fromXml(XmlElement moduleElement, ServiceRegistryWrapper services, String moduleNamespace, EditStrategyType defaultStrategy, - Map> identityMap) throws NetconfDocumentedException { + Map> identityMap, final EnumResolver enumResolver) throws NetconfDocumentedException { Map retVal = Maps.newHashMap(); Map strats = new ObjectXmlReader().prepareReading(yangToAttrConfig, identityMap); @@ -188,7 +189,7 @@ public final class InstanceConfig { InstanceConfigElementResolved instanceConfigElementResolved = perInstanceEditStrategy.equals("") ? new InstanceConfigElementResolved( retVal, defaultStrategy) : new InstanceConfigElementResolved(perInstanceEditStrategy, retVal, defaultStrategy); - resolveConfiguration(instanceConfigElementResolved, services); + resolveConfiguration(instanceConfigElementResolved, services, enumResolver); return instanceConfigElementResolved; }