X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?p=controller.git;a=blobdiff_plain;f=opendaylight%2Fnetconf%2Fmdsal-netconf-connector%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fcontroller%2Fnetconf%2Fmdsal%2Fconnector%2FMdsalNetconfOperationServiceFactory.java;h=96244fdc68a366c1e435705a11ac3ad2b60023ad;hp=098f25bf4a9216adeba96833e06d497b65cb4539;hb=a681e6bec3bbd7b536302ee9e083ae04b7f5ebdd;hpb=4f295e3104c4b0c3fccc4f7ac8010dbddf613ef7 diff --git a/opendaylight/netconf/mdsal-netconf-connector/src/main/java/org/opendaylight/controller/netconf/mdsal/connector/MdsalNetconfOperationServiceFactory.java b/opendaylight/netconf/mdsal-netconf-connector/src/main/java/org/opendaylight/controller/netconf/mdsal/connector/MdsalNetconfOperationServiceFactory.java index 098f25bf4a..96244fdc68 100644 --- a/opendaylight/netconf/mdsal-netconf-connector/src/main/java/org/opendaylight/controller/netconf/mdsal/connector/MdsalNetconfOperationServiceFactory.java +++ b/opendaylight/netconf/mdsal-netconf-connector/src/main/java/org/opendaylight/controller/netconf/mdsal/connector/MdsalNetconfOperationServiceFactory.java @@ -8,28 +8,103 @@ package org.opendaylight.controller.netconf.mdsal.connector; +import com.google.common.base.Optional; import com.google.common.base.Preconditions; +import java.util.Collection; +import java.util.Collections; +import java.util.HashSet; +import java.util.Set; import org.opendaylight.controller.md.sal.dom.api.DOMDataBroker; +import org.opendaylight.controller.md.sal.dom.api.DOMRpcService; +import org.opendaylight.controller.netconf.api.Capability; +import org.opendaylight.controller.netconf.api.monitoring.CapabilityListener; import org.opendaylight.controller.netconf.mapping.api.NetconfOperationServiceFactory; +import org.opendaylight.controller.netconf.util.capability.BasicCapability; +import org.opendaylight.controller.netconf.util.capability.YangModuleCapability; +import org.opendaylight.controller.sal.core.api.Broker.ConsumerSession; +import org.opendaylight.controller.sal.core.api.Consumer; import org.opendaylight.controller.sal.core.api.model.SchemaService; +import org.opendaylight.yangtools.yang.model.api.Module; +import org.opendaylight.yangtools.yang.model.api.SchemaContext; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; -public class MdsalNetconfOperationServiceFactory implements NetconfOperationServiceFactory, AutoCloseable { +public class MdsalNetconfOperationServiceFactory implements NetconfOperationServiceFactory, Consumer, AutoCloseable { - private final DOMDataBroker dataBroker; + private static final Logger LOG = LoggerFactory.getLogger(MdsalNetconfOperationServiceFactory.class); + + private ConsumerSession session = null; + private DOMDataBroker dataBroker = null; + private DOMRpcService rpcService = null; private final CurrentSchemaContext currentSchemaContext; - public MdsalNetconfOperationServiceFactory(final SchemaService schemaService, final DOMDataBroker domDataBroker) { + public MdsalNetconfOperationServiceFactory(final SchemaService schemaService) { this.currentSchemaContext = new CurrentSchemaContext(Preconditions.checkNotNull(schemaService)); - this.dataBroker = Preconditions.checkNotNull(domDataBroker); } @Override public MdsalNetconfOperationService createService(final String netconfSessionIdForReporting) { - return new MdsalNetconfOperationService(currentSchemaContext, netconfSessionIdForReporting, dataBroker); + Preconditions.checkState(dataBroker != null, "MD-SAL provider not yet initialized"); + return new MdsalNetconfOperationService(currentSchemaContext, netconfSessionIdForReporting, dataBroker, rpcService); } @Override public void close() throws Exception { currentSchemaContext.close(); } + + @Override + public Set getCapabilities() { + return transformCapabilities(currentSchemaContext.getCurrentContext()); + } + + static Set transformCapabilities(final SchemaContext currentContext) { + final Set capabilities = new HashSet<>(); + // [RFC6241] 8.3. Candidate Configuration Capability + capabilities.add(new BasicCapability("urn:ietf:params:netconf:capability:candidate:1.0")); + + final Set modules = currentContext.getModules(); + for (final Module module : modules) { + Optional cap = moduleToCapability(module); + if(cap.isPresent()) { + capabilities.add(cap.get()); + } + for (final Module submodule : module.getSubmodules()) { + cap = moduleToCapability(submodule); + if(cap.isPresent()) { + capabilities.add(cap.get()); + } + } + } + + return capabilities; + } + + private static Optional moduleToCapability(final Module module) { + final String source = module.getSource(); + if(source !=null) { + return Optional.of(new YangModuleCapability(module, source)); + } else { + LOG.warn("Missing source for module {}. This module will not be available from netconf server", + module); + } + return Optional.absent(); + } + + @Override + public AutoCloseable registerCapabilityListener(final CapabilityListener listener) { + return currentSchemaContext.registerCapabilityListener(listener); + } + + @Override + public void onSessionInitiated(ConsumerSession session) { + this.session = Preconditions.checkNotNull(session); + this.dataBroker = this.session.getService(DOMDataBroker.class); + this.rpcService = this.session.getService(DOMRpcService.class); + } + + @Override + public Collection getConsumerFunctionality() { + return Collections.emptySet(); + } }