Merge "Remove unnecessary warn log from config subsystem"
[controller.git] / opendaylight / md-sal / samples / toaster-provider / src / main / java / org / opendaylight / controller / sample / toaster / provider / ToasterProvider.java
1 /*
2  * Copyright (c) 2014 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 package org.opendaylight.controller.sample.toaster.provider;
9
10 import java.util.Collection;
11 import java.util.Collections;
12
13 import org.opendaylight.controller.sal.binding.api.AbstractBindingAwareProvider;
14 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker;
15 import org.opendaylight.controller.sal.binding.api.BindingAwareProvider;
16 import org.opendaylight.controller.sal.binding.api.NotificationProviderService;
17 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ConsumerContext;
18 import org.opendaylight.controller.sal.binding.api.BindingAwareBroker.ProviderContext;
19 import org.opendaylight.yang.gen.v1.http.netconfcentral.org.ns.toaster.rev091120.ToasterService;
20 import org.opendaylight.yangtools.yang.binding.RpcService;
21 import org.osgi.framework.BundleActivator;
22 import org.osgi.framework.BundleContext;
23 import org.osgi.framework.ServiceReference;
24 import org.slf4j.Logger;
25 import org.slf4j.LoggerFactory;
26
27 public class ToasterProvider extends AbstractBindingAwareProvider {
28     private static final Logger log = LoggerFactory.getLogger(ToasterProvider.class);
29
30     private ProviderContext providerContext;
31     private OpendaylightToaster toaster;
32
33     public ToasterProvider() {
34         toaster = new OpendaylightToaster();
35     }
36
37     @Override
38     public void onSessionInitiated(ProviderContext session) {
39         log.info("Provider Session initialized");
40
41         this.providerContext = session;
42         toaster.setNotificationProvider(session.getSALService(NotificationProviderService.class));
43         providerContext.addRpcImplementation(ToasterService.class, toaster);
44     }
45
46     @Override
47     public Collection<? extends RpcService> getImplementations() {
48         return Collections.emptySet();
49     }
50
51     @Override
52     public Collection<? extends ProviderFunctionality> getFunctionality() {
53         return Collections.emptySet();
54     }
55 }