RpcRegistration and RpcResult for IdManager.
[vpnservice.git] / idmanager / idmanager-impl / src / main / java / org / opendaylight / idmanager / IdManagerServiceProvider.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
9 package org.opendaylight.idmanager;
10
11 import org.opendaylight.controller.md.sal.binding.api.DataBroker;
12 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
13 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
14 import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;
15
16 import org.opendaylight.controller.sal.binding.api.RpcProviderRegistry;
17 import org.opendaylight.yang.gen.v1.urn.opendaylight.vpnservice.idmanager.rev150403.IdManagerService;
18 import org.slf4j.Logger;
19 import org.slf4j.LoggerFactory;
20
21
22 public class IdManagerServiceProvider implements BindingAwareProvider,
23             AutoCloseable {
24
25         private static final Logger LOG = LoggerFactory.getLogger(IdManagerServiceProvider.class);
26         private IdManager idManager;
27         private RpcProviderRegistry rpcProviderRegistry;
28
29     public RpcProviderRegistry getRpcProviderRegistry() {
30         return rpcProviderRegistry;
31     }
32
33     public void setRpcProviderRegistry(RpcProviderRegistry rpcProviderRegistry) {
34         this.rpcProviderRegistry = rpcProviderRegistry;
35     }
36
37         @Override
38     public void onSessionInitiated(ProviderContext session){
39         LOG.info("IDManagerserviceProvider Session Initiated");
40         try {
41             final  DataBroker dataBroker = session.getSALService(DataBroker.class);
42             idManager = new IdManager(dataBroker);
43             final BindingAwareBroker.RpcRegistration<IdManagerService> rpcRegistration = getRpcProviderRegistry().addRpcImplementation(IdManagerService.class, idManager);
44         } catch (Exception e) {
45             LOG.error("Error initializing services", e);
46         }
47     }
48
49     public IdManagerServiceProvider(RpcProviderRegistry rpcRegistry) {
50         this.rpcProviderRegistry = rpcRegistry;
51     }
52
53     @Override
54     public void close() throws Exception {
55         idManager.close();
56         }
57     }
58
59
60
61
62