Version bump for vpnservice on master
[vpnservice.git] / fibmanager / fibmanager-impl / src / main / java / org / opendaylight / vpnservice / fibmanager / FibManagerProvider.java
1 /*
2  * Copyright (c) 2015 Ericsson India Global Services Pvt Ltd. 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.vpnservice.fibmanager;
9
10 import java.math.BigInteger;
11 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
12 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
13 import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;
14 import org.opendaylight.fibmanager.api.IFibManager;
15 import org.opendaylight.vpnmanager.api.IVpnManager;
16 import org.opendaylight.vpnservice.mdsalutil.interfaces.IMdsalApiManager;
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.l3nexthop.rev150409.L3nexthopService;
18 import org.opendaylight.yangtools.yang.binding.RpcService;
19 import org.slf4j.Logger;
20 import org.slf4j.LoggerFactory;
21
22 public class FibManagerProvider implements BindingAwareProvider, IFibManager, AutoCloseable {
23
24   private static final Logger LOG = LoggerFactory.getLogger(FibManagerProvider.class);
25
26   private FibManager fibManager;
27   private IMdsalApiManager mdsalManager;
28   private IVpnManager vpnmanager;
29   private FibNodeCapableListener fibNcListener;
30
31   @Override
32   public void onSessionInitiated(ProviderContext session) {
33     LOG.info("FibManagerProvider Session Initiated");
34     try {
35       final  DataBroker dataBroker = session.getSALService(DataBroker.class);
36       final RpcService nexthopService = session.getRpcService(L3nexthopService.class);
37       fibManager = new FibManager(dataBroker, nexthopService);
38       fibManager.setMdsalManager(mdsalManager);
39       fibManager.setVpnmanager(vpnmanager);
40       fibNcListener = new FibNodeCapableListener(dataBroker, fibManager);
41     } catch (Exception e) {
42       LOG.error("Error initializing services", e);
43     }
44   }
45
46   @Override
47   public void close() throws Exception {
48     LOG.info("FibManagerProvider Closed");
49     fibManager.close();
50     fibNcListener.close();
51   }
52
53   public void setMdsalManager(IMdsalApiManager mdsalManager) {
54     this.mdsalManager = mdsalManager;
55   }
56
57   public void setVpnmanager(IVpnManager vpnmanager) {
58     this.vpnmanager = vpnmanager;
59     vpnmanager.setFibService(this);
60   }
61
62   @Override
63   public void populateFibOnNewDpn(BigInteger dpnId, long vpnId, String rd) {
64     fibManager.populateFibOnNewDpn(dpnId, vpnId, rd);
65   }
66
67   @Override
68   public void cleanUpDpnForVpn(BigInteger dpnId, long vpnId, String rd) {
69     fibManager.cleanUpDpnForVpn(dpnId, vpnId, rd);
70   }
71 }