Abort power setup if setting gainloss fails
[transportpce.git] / networkmodel / src / main / java / org / opendaylight / transportpce / networkmodel / NetworkModelProvider.java
1 /*
2  * Copyright © 2016 Orange 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 package org.opendaylight.transportpce.networkmodel;
9
10 import java.util.ArrayList;
11 import java.util.List;
12 import org.opendaylight.mdsal.binding.api.DataBroker;
13 import org.opendaylight.mdsal.binding.api.DataTreeIdentifier;
14 import org.opendaylight.mdsal.binding.api.NotificationService;
15 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
16 import org.opendaylight.transportpce.common.InstanceIdentifiers;
17 import org.opendaylight.transportpce.common.NetworkUtils;
18 import org.opendaylight.transportpce.common.device.DeviceTransactionManager;
19 import org.opendaylight.transportpce.common.mapping.PortMapping;
20 import org.opendaylight.transportpce.common.network.NetworkTransactionService;
21 import org.opendaylight.transportpce.networkmodel.listeners.PortMappingListener;
22 import org.opendaylight.transportpce.networkmodel.listeners.ServiceHandlerListener;
23 import org.opendaylight.transportpce.networkmodel.service.FrequenciesService;
24 import org.opendaylight.transportpce.networkmodel.service.NetworkModelService;
25 import org.opendaylight.transportpce.networkmodel.util.TpceNetwork;
26 import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev231221.Network;
27 import org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev231221.mapping.Mapping;
28 import org.opendaylight.yang.gen.v1.urn.tbd.params.xml.ns.yang.network.topology.rev131021.network.topology.topology.Node;
29 import org.opendaylight.yangtools.concepts.Registration;
30 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
31 import org.osgi.service.component.annotations.Activate;
32 import org.osgi.service.component.annotations.Component;
33 import org.osgi.service.component.annotations.Deactivate;
34 import org.osgi.service.component.annotations.Reference;
35 import org.slf4j.Logger;
36 import org.slf4j.LoggerFactory;
37
38 @Component
39 public class NetworkModelProvider {
40
41     private static final Logger LOG = LoggerFactory.getLogger(NetworkModelProvider.class);
42     private static final InstanceIdentifier<Mapping> MAPPING_II = InstanceIdentifier.create(Network.class)
43         .child(org.opendaylight.yang.gen.v1.http.org.opendaylight.transportpce.portmapping.rev231221.network
44                 .Nodes.class)
45         .child(Mapping.class);
46
47     private final DataBroker dataBroker;
48     private final NetConfTopologyListener topologyListener;
49     private List<Registration> listeners;
50     private TpceNetwork tpceNetwork;
51     private Registration serviceHandlerListenerRegistration;
52     private NotificationService notificationService;
53     private FrequenciesService frequenciesService;
54     private PortMappingListener portMappingListener;
55
56     @Activate
57     public NetworkModelProvider(@Reference NetworkTransactionService networkTransactionService,
58             @Reference final DataBroker dataBroker,
59             @Reference final NetworkModelService networkModelService,
60             @Reference DeviceTransactionManager deviceTransactionManager,
61             @Reference PortMapping portMapping,
62             @Reference NotificationService notificationService,
63             @Reference FrequenciesService frequenciesService) {
64         this.dataBroker = dataBroker;
65         this.notificationService = notificationService;
66         this.frequenciesService = frequenciesService;
67         this.listeners = new ArrayList<>();
68         this.topologyListener = new NetConfTopologyListener(networkModelService, dataBroker, deviceTransactionManager,
69             portMapping);
70         this.tpceNetwork = new TpceNetwork(networkTransactionService);
71         this.portMappingListener = new PortMappingListener(networkModelService);
72         this.init();
73     }
74
75     /**
76      * Method called when the blueprint container is created.
77      */
78     private void init() {
79         LOG.info("NetworkModelProvider Session Initiated");
80         tpceNetwork.createLayer(NetworkUtils.CLLI_NETWORK_ID);
81         tpceNetwork.createLayer(NetworkUtils.UNDERLAY_NETWORK_ID);
82         tpceNetwork.createLayer(NetworkUtils.OVERLAY_NETWORK_ID);
83         tpceNetwork.createLayer(NetworkUtils.OTN_NETWORK_ID);
84         listeners.add(dataBroker.registerTreeChangeListener(
85                 DataTreeIdentifier.of(LogicalDatastoreType.OPERATIONAL,
86                     InstanceIdentifiers.NETCONF_TOPOLOGY_II.child(Node.class)),
87                 topologyListener));
88         listeners.add(dataBroker.registerTreeChangeListener(
89                 DataTreeIdentifier.of(LogicalDatastoreType.CONFIGURATION, MAPPING_II), portMappingListener));
90         serviceHandlerListenerRegistration = notificationService.registerCompositeListener(
91             new ServiceHandlerListener(frequenciesService).getCompositeListener());
92     }
93
94         /**
95          * Method called when the blueprint container is destroyed.
96          */
97     @Deactivate
98     public void close() {
99         LOG.info("NetworkModelProvider Closed");
100         listeners.forEach(lis -> lis.close());
101         listeners.clear();
102         serviceHandlerListenerRegistration.close();
103     }
104 }