X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=opendaylight%2Fblueprint%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fblueprint%2Fext%2FDataStoreAppConfigDefaultXMLReader.java;h=6f323716ee481a2bb5e015b9b57e985fdfaf8d3b;hb=6c95898df7a932ba15f12ca900ed0646a1e165f8;hp=9b55b360d66bab09a531e0174c3ad5fa7166d2d2;hpb=6f3281a884977f857217b0d2b40a84fb70483fec;p=controller.git diff --git a/opendaylight/blueprint/src/main/java/org/opendaylight/controller/blueprint/ext/DataStoreAppConfigDefaultXMLReader.java b/opendaylight/blueprint/src/main/java/org/opendaylight/controller/blueprint/ext/DataStoreAppConfigDefaultXMLReader.java index 9b55b360d6..6f323716ee 100644 --- a/opendaylight/blueprint/src/main/java/org/opendaylight/controller/blueprint/ext/DataStoreAppConfigDefaultXMLReader.java +++ b/opendaylight/blueprint/src/main/java/org/opendaylight/controller/blueprint/ext/DataStoreAppConfigDefaultXMLReader.java @@ -24,6 +24,7 @@ import org.opendaylight.yangtools.yang.common.QName; import org.opendaylight.yangtools.yang.data.api.YangInstanceIdentifier; import org.opendaylight.yangtools.yang.data.api.schema.NormalizedNode; import org.opendaylight.yangtools.yang.model.api.DataSchemaNode; +import org.opendaylight.yangtools.yang.model.api.EffectiveModelContext; import org.opendaylight.yangtools.yang.model.api.Module; import org.opendaylight.yangtools.yang.model.api.SchemaContext; import org.slf4j.Logger; @@ -52,7 +53,7 @@ public class DataStoreAppConfigDefaultXMLReader { @FunctionalInterface public interface FallbackConfigProvider { - NormalizedNode get(SchemaContext schemaContext, DataSchemaNode dataSchema) throws IOException, + NormalizedNode get(EffectiveModelContext schemaContext, DataSchemaNode dataSchema) throws IOException, XMLStreamException, ParserConfigurationException, SAXException, URISyntaxException; } @@ -110,13 +111,16 @@ public class DataStoreAppConfigDefaultXMLReader { checkNotNull(schemaService, "%s: Could not obtain the SchemaService OSGi service", logName); - SchemaContext schemaContext = schemaService.getGlobalContext(); + EffectiveModelContext schemaContext = schemaService.getGlobalContext(); Module module = schemaContext.findModule(bindingContext.bindingQName.getModule()).orElse(null); checkNotNull(module, "%s: Could not obtain the module schema for namespace %s, revision %s", logName, bindingContext.bindingQName.getNamespace(), bindingContext.bindingQName.getRevision()); - DataSchemaNode dataSchema = module.getDataChildByName(bindingContext.bindingQName); + QName qname = bindingContext.bindingQName; + DataSchemaNode dataSchema = module.findDataChildByName(qname).orElseThrow( + () -> new ConfigXMLReaderException(logName + ": Could not obtain the schema for " + qname)); + checkNotNull(dataSchema, "%s: Could not obtain the schema for %s", logName, bindingContext.bindingQName); checkCondition(bindingContext.schemaType.isAssignableFrom(dataSchema.getClass()), @@ -149,7 +153,7 @@ public class DataStoreAppConfigDefaultXMLReader { } } - private NormalizedNode parsePossibleDefaultAppConfigXMLFile(final SchemaContext schemaContext, + private NormalizedNode parsePossibleDefaultAppConfigXMLFile(final EffectiveModelContext schemaContext, final DataSchemaNode dataSchema) throws ConfigXMLReaderException { String appConfigFileName = defaultAppConfigFileName;