Merge "BUG-692 Improve log message when negotiation fails"
[controller.git] / opendaylight / netconf / config-netconf-connector / src / main / java / org / opendaylight / controller / netconf / confignetconfconnector / osgi / YangStoreSnapshotImpl.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.osgi;
10
11 import com.google.common.collect.Maps;
12
13 import java.util.Collections;
14 import java.util.HashMap;
15 import java.util.Map;
16 import java.util.Map.Entry;
17 import java.util.Set;
18
19 import org.opendaylight.controller.config.yangjmxgenerator.ModuleMXBeanEntry;
20 import org.opendaylight.controller.config.yangjmxgenerator.PackageTranslator;
21 import org.opendaylight.controller.config.yangjmxgenerator.ServiceInterfaceEntry;
22 import org.opendaylight.controller.config.yangjmxgenerator.TypeProviderWrapper;
23 import org.opendaylight.yangtools.sal.binding.yang.types.TypeProviderImpl;
24 import org.opendaylight.yangtools.yang.common.QName;
25 import org.opendaylight.yangtools.yang.model.api.IdentitySchemaNode;
26 import org.opendaylight.yangtools.yang.model.api.Module;
27 import org.opendaylight.yangtools.yang.model.api.SchemaContext;
28 import org.slf4j.Logger;
29 import org.slf4j.LoggerFactory;
30
31 public class YangStoreSnapshotImpl implements YangStoreSnapshot {
32     private static final Logger logger = LoggerFactory.getLogger(YangStoreSnapshotImpl.class);
33
34
35     private final Map<String /* Namespace from yang file */,
36     Map<String /* Name of module entry from yang file */, ModuleMXBeanEntry>> moduleMXBeanEntryMap;
37
38
39     private final Map<QName, Map<String, ModuleMXBeanEntry>> qNamesToIdentitiesToModuleMXBeanEntries;
40
41     private final SchemaContext schemaContext;
42
43
44     public YangStoreSnapshotImpl(final SchemaContext resolveSchemaContext) {
45         logger.trace("Resolved modules:{}", resolveSchemaContext.getModules());
46         this.schemaContext = resolveSchemaContext;
47         // JMX generator
48
49         Map<String, String> namespaceToPackageMapping = Maps.newHashMap();
50         PackageTranslator packageTranslator = new PackageTranslator(namespaceToPackageMapping);
51         Map<QName, ServiceInterfaceEntry> qNamesToSIEs = new HashMap<>();
52         Map<IdentitySchemaNode, ServiceInterfaceEntry> knownSEITracker = new HashMap<>();
53         // create SIE structure qNamesToSIEs
54         for (Module module : resolveSchemaContext.getModules()) {
55             String packageName = packageTranslator.getPackageName(module);
56             Map<QName, ServiceInterfaceEntry> namesToSIEntries = ServiceInterfaceEntry
57                     .create(module, packageName, knownSEITracker);
58             for (Entry<QName, ServiceInterfaceEntry> sieEntry : namesToSIEntries.entrySet()) {
59                 // merge value into qNamesToSIEs
60                 if (qNamesToSIEs.containsKey(sieEntry.getKey()) == false) {
61                     qNamesToSIEs.put(sieEntry.getKey(), sieEntry.getValue());
62                 } else {
63                     throw new IllegalStateException("Cannot add two SIE with same qname "
64                             + sieEntry.getValue());
65                 }
66             }
67         }
68
69         Map<String, Map<String, ModuleMXBeanEntry>> moduleMXBeanEntryMap = Maps.newHashMap();
70
71         Map<QName, Map<String /* identity local name */, ModuleMXBeanEntry>> qNamesToIdentitiesToModuleMXBeanEntries = new HashMap<>();
72
73
74         for (Module module : schemaContext.getModules()) {
75             String packageName = packageTranslator.getPackageName(module);
76             TypeProviderWrapper typeProviderWrapper = new TypeProviderWrapper(
77                     new TypeProviderImpl(resolveSchemaContext));
78
79             QName qName = QName.create(module.getNamespace(), module.getRevision(), module.getName());
80
81             Map<String /* MB identity local name */, ModuleMXBeanEntry> namesToMBEs =
82                     Collections.unmodifiableMap(ModuleMXBeanEntry.create(module, qNamesToSIEs, resolveSchemaContext,
83                             typeProviderWrapper, packageName));
84             moduleMXBeanEntryMap.put(module.getNamespace().toString(), namesToMBEs);
85
86             qNamesToIdentitiesToModuleMXBeanEntries.put(qName, namesToMBEs);
87         }
88         this.moduleMXBeanEntryMap = Collections.unmodifiableMap(moduleMXBeanEntryMap);
89         this.qNamesToIdentitiesToModuleMXBeanEntries = Collections.unmodifiableMap(qNamesToIdentitiesToModuleMXBeanEntries);
90
91     }
92
93     @Override
94     public Map<String, Map<String, ModuleMXBeanEntry>> getModuleMXBeanEntryMap() {
95         return moduleMXBeanEntryMap;
96     }
97
98     @Override
99     public Map<QName, Map<String, ModuleMXBeanEntry>> getQNamesToIdentitiesToModuleMXBeanEntries() {
100         return qNamesToIdentitiesToModuleMXBeanEntries;
101     }
102
103     @Override
104     public Set<Module> getModules() {
105         return schemaContext.getModules();
106     }
107
108     @Override
109     public String getModuleSource(final org.opendaylight.yangtools.yang.model.api.ModuleIdentifier moduleIdentifier) {
110         return schemaContext.getModuleSource(moduleIdentifier).get();
111     }
112
113     @Override
114     public void close() {
115
116     }
117 }