NETVIRT-1630 migrate to md-sal APIs
[netvirt.git] / vpnmanager / impl / src / main / java / org / opendaylight / netvirt / vpnmanager / intervpnlink / InterVpnLinkStateCacheFeeder.java
1 /*
2  * Copyright (c) 2016 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.netvirt.vpnmanager.intervpnlink;
10
11 import javax.annotation.PreDestroy;
12 import javax.inject.Inject;
13 import javax.inject.Singleton;
14 import org.opendaylight.infrautils.utils.concurrent.Executors;
15 import org.opendaylight.mdsal.binding.api.DataBroker;
16 import org.opendaylight.mdsal.common.api.LogicalDatastoreType;
17 import org.opendaylight.netvirt.vpnmanager.api.intervpnlink.InterVpnLinkCache;
18 import org.opendaylight.serviceutils.tools.listener.AbstractClusteredAsyncDataTreeChangeListener;
19 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.netvirt.inter.vpn.link.rev160311.InterVpnLinkStates;
20 import org.opendaylight.yang.gen.v1.urn.opendaylight.params.xml.ns.yang.netvirt.inter.vpn.link.rev160311.inter.vpn.link.states.InterVpnLinkState;
21 import org.opendaylight.yangtools.yang.binding.InstanceIdentifier;
22 import org.slf4j.Logger;
23 import org.slf4j.LoggerFactory;
24
25 /**
26  * Clustered listener whose only purpose is to keep global (well, per cluster)
27  * caches updated. Same as InterVpnLinkCacheFeeder but this listens on
28  * InterVpnLinkState changes.
29  */
30 @Singleton
31 public class InterVpnLinkStateCacheFeeder extends AbstractClusteredAsyncDataTreeChangeListener<InterVpnLinkState> {
32
33     private static final Logger LOG = LoggerFactory.getLogger(InterVpnLinkStateCacheFeeder.class);
34
35     private final InterVpnLinkCache interVpnLinkCache;
36     private final DataBroker dataBroker;
37
38     @Inject
39     public InterVpnLinkStateCacheFeeder(final DataBroker dataBroker, final InterVpnLinkCache interVpnLinkCache) {
40         super(dataBroker, LogicalDatastoreType.CONFIGURATION, InstanceIdentifier.create(InterVpnLinkStates.class)
41                 .child(InterVpnLinkState.class),
42                 Executors.newListeningSingleThreadExecutor("InterVpnLinkStateCacheFeeder", LOG));
43         this.dataBroker = dataBroker;
44         this.interVpnLinkCache = interVpnLinkCache;
45     }
46
47     public void init() {
48         LOG.info("{} start", getClass().getSimpleName());
49     }
50
51     @Override
52     @PreDestroy
53     public void close() {
54         super.close();
55         Executors.shutdownAndAwaitTermination(getExecutorService());
56     }
57
58     @Override
59     public void remove(InstanceIdentifier<InterVpnLinkState> identifier, InterVpnLinkState del) {
60         LOG.debug("InterVpnLinkState {} has been removed", del.getInterVpnLinkName());
61         interVpnLinkCache.removeInterVpnLinkStateFromCache(del);
62     }
63
64     @Override
65     public void update(InstanceIdentifier<InterVpnLinkState> identifier, InterVpnLinkState original,
66         InterVpnLinkState update) {
67         LOG.debug("InterVpnLinkState {} has been updated", update.getInterVpnLinkName());
68         interVpnLinkCache.addInterVpnLinkStateToCaches(update);
69     }
70
71     @Override
72     public void add(InstanceIdentifier<InterVpnLinkState> identifier, InterVpnLinkState add) {
73         LOG.debug("InterVpnLinkState {} has been added", add.getInterVpnLinkName());
74         interVpnLinkCache.addInterVpnLinkStateToCaches(add);
75     }
76
77 }